The ADP_API_Script is a Python script that retrieves timecards and employee information from ADP using the ADP API. The script can be scheduled to run daily at a specific time to fetch the latest data.
Before running the script, ensure you have the following:
- Python installed (version 3.7 or higher)
- ADP API credentials (client ID and client secret) obtained from ADP
- Certificates (PEM and KEY files) required for authentication
- Access to a SQL database to store the retrieved data
- Environment variables set up in a
.env
file (refer to the.env.example
file for the required variables)
-
Clone or download the ADP_API_Script project from the repository.
git clone https://github.com/fsantamaria1/ADP_API_Script.git
-
Open a terminal or command prompt and navigate to the project directory.
cd ADP_API_Script
-
Create a virtual environment (optional but recommended):
- Run
shell python -m venv venv
to create a new virtual environment. - Activate the virtual environment:
- On Windows: ```shell venv\Scripts\activate````
- On Unix or Linux: ```shell source venv/bin/activate````
- Run
-
Install the required dependencies by running the following command:
pip install -r requirements.txt
Before running the script, configure the following settings:
- Update the
.env
file:- Set the
client_id
andclient_secret
variables with your ADP API credentials. - Set the
main_associate_id
variable with the ID of the main associate. - Specify the paths to the PEM and KEY files (
cert_file_path
andkey_file_path
variables). - Set the database credentials (
server
,user
,password
,database
,default_schema
,adp_schema
variables).
- Set the
- Modify the
run.py
file if you want to change the scheduled time for running the script. By default, it is set to run at 10 PM daily.
To run the script manually, execute the following command in the project directory:
python main.py
The script will connect to the ADP API, retrieve employee information, retrieve timecards, and update the database tables accordingly.
To schedule the script to run automatically at the specified time (the default is 10 PM), run the following command:
python run.py
The script will run in the background and execute at the scheduled time every day until stopped.
You can run the GUI version by executing this command:
python simple_ui.py
Additionally, you can create an executable of the GUI version of the script by running the following command:
python build_simple_ui.py
The project structure is organized as follows:
ADP_API_Script/
|- main.py
|- run.py
|- simple_ui.py
|- build_simple_ui.py
|- requirements.txt
|- .env
|- .env.example
|- resources/
|- adp_requests.py
|- config.py
|- database.py
|- database_functions.py
|- date_util.py
|- models.py
|- response_filter.py
main.py
: Contains the main logic for fetching and processing data from the ADP API.run.py
: Entry point script to schedule the main script to run at a specific time.simple_ui.py
: Contains the tkinter code to run the GUI version.build_simple_ui.py
: Provides functionality to create an executable of thesimple_ui.py
.requirements.txt
: List of Python dependencies required by the project..env.example
: Example file for setting up the environment variables. Rename it to.env
and update the values accordingly.resources/
: Directory containing various modules used by the main script:adp_requests.py
: Handles the ADP API requests and authentication.config.py
: Contains configuration settings for the script.database.py
: Handles the connection and interaction with the SQL database.database_functions.py
: Contains functions to execute SQL queries and stored procedures.date_util.py
: Provides utility functions for date manipulation.models.py
: Defines the unnormalized data models for timecards and employees.response_filter.py
: Filters and transforms the API response data.