Adding Wage Budgets to Deputy
You can add the following types of wage budgets to Deputy:
Weekly - The budget is set for the week and the user has to distribute amongst the days in the Deputy UI
Daily - Using the specific timestamp in the API call you can set the daily budgets using the API. We suggest the midnight timestamp for the day when using this option.
Daily vs Weekly
Users of Deputy are able to change the settings for wage budgets between Daily and Weekly at will. Data is retained and segmented as appropriate. Due to this it is best practice for integrations to always send the relevant daily timestamp instead of a single post for the week. This allows users the most flexibility when using the feature in Deputy.
Adding wage budgets via the API is a relatively simple option but there is some information you will require before you can successfully save the data:
area - In the Deputy application, this is called an Area. If you want to track wage budgets against a specific Area in Deputy you will need to include this item. In other API requests this is called the OperationalUnit. To get a list of areas use the Get Operational Units endpoint.
timestamp - The timestamp for the wage budget to be set in epoch time. Even if your user is only intending to use weekly not daily budgets, it is important to set the timestamp specifically as users are able to change from weekly to daily budgets at any time.
value - The amount to set as the wage budget. It should be noted that this is not a cumulative calculation and whatever you set will be overwritten. So for example if you had previously set $2,000 and you need it to be $10,000 dollars your request needs to be 10000 not 8000 as the original 2000 will be overwritten.
type - When adding wage budgets the type is budget_wage
.
reference - You can choose to set a reference for the record when being saved into the database.
location - This is the location within Deputy where the sale should be attributed. In other API requests you may see this referred to as Company. To get a list of locations use the Get Locations endpoint.
Adding wage budgets via the API
URL
curl --request POST --url 'https://{install}.{geo}.deputy.com/api/v2/metrics
{
"data": [
{
"timestamp": 1660272300,
"area": 2,
"type": "budget_wage",
"reference": "wages-ManualEntry-1660272300",
"value": 100.30,
"location": 1
}
]
}
If the wage data is added successfully, you will get a response including information about the data that was saved, including an id of the record.
{
"success": true,
"data": [
{
"timestamp": "1660272300",
"employee": 0,
"area": 1,
"type": "budget_Wage",
"reference": "Sales-ManualEntry-1660272300",
"value": 91400.300000000003,
"state": "ACTUAL",
"location": 1,
"id": "2TBYvxelKDN1GBoriNkZljJaNZK",
"created": "2023-07-28T04:22:54Z",
"modified": "",
"payload": "{\"timestamp\":1690437981,\"employee\":0,\"area\":1,\"type\":\"budget_Wage\",\"reference\":\"Sales-ManualEntry-1660272300\",\"value\":91400.3,\"state\":0,\"location\":1}"
}
]
}
You can also added many wage budgets at once by appending :bulk
to the end of the API url. When this is the case just include multiple objects in the array.
Bulk API
When using the bulk API method, the data may not be ready for retrieval or display within Deputy immediately. If you need real-time saving you should use the regular API url
## Data Elements
Data Element | Info |
---|---|
timestamp | The timestamp of the wage budget in unix time |
employee | If the wage budget was saved against an employee id it would appear here. 0 means not saved against employee |
area | The id of the area the wage budget has been saved for |
location | The id of the location the wage budget has been saved for |
reference | The reference that was saved against the wage budget entry |
value | The value of the wage budget |
state | If the state is ACTUAL it means that this is considered the wage budget and not in draft |
created | The created time for the record in zulu time |
modified | The last modified time for the record in zulu time |
payload | Deputy now saves the payload that was sent to the API against the record for troubleshooting purposes. This allows you to see the exact payload that was received into the system. |
Updated over 1 year ago