iFrames
The Worklio Embedded Payroll iFrames allow you to integrate the white-label solution within your existing platform.
1. Client Authorization Token
First, you need to get a "client" JWT token to be able to call the user token endpoint. You can obtain this client token with Client credentials authorization flow at /connect/token
endpoint using the client_id
and client_secret
assigned to your application and user_token api
scopes, like this:
2. User Token endpoint
The user token endpoint generates an output that is used to access the embedded payroll application on the client side. With the Client JWT token used as the Bearer token in the request header, you can make an API call to /token/user/
endpoint to obtain appUrl
and userToken
result.
The appUrl
property contains the URL to the embedded payroll application and the userToken
property is an authentication token in JWT format created on behalf of the user specified by the endpoint parameters.
This endpoint is called by the POST method and its content is generated based on parameters in the request body as a JSON object with the following properties:
- email : The user's email for whom the token is to be generated; this token will contain user identifications (such as loginId and role/roleId) according to other parameters.
- token : Instead of the "email" parameter, a "token" parameter can be used with the value of the user's authenticated JWT token from another trusted authentication server.
- mode : Mode of the application container in which the generated token will be used. This is an optional parameter, if specified the mode will be included as a claim in the user token.
Int | Mode |
---|---|
1 | Browser |
2 | Iframe |
- page : The type of page to be included as a claim in the user token:
Int | Page Name | Accessible for Roles | Required Properties |
---|---|---|---|
1 | Multi-Admin Dashboard | Multi-Admin | |
2 | Multi-Admin Companies | Multi-Admin | |
3 | Multi-Admin Payrolls | Multi-Admin | |
4 | Multi-Admin Payroll History | Multi-Admin | |
5 | Multi-Admin Reports | Multi-Admin | |
6 | App Settings | Multi-Admin | |
1001 | Company Dashboard | Admin, Multi-Admin | company-id - if accessed as Multi-Admin |
1002 | Company Info | Admin, Multi-Admin | company-id - if accessed as Multi-Admin |
1003 | Company Team | Admin, Multi-Admin | company-id - if accessed as Multi-Admin |
1004 | Company Team Member | Admin, Multi-Admin | employee-id , company-id - if accessed as Multi-Admin |
1005 | Company Payroll | Admin, Multi-Admin | company-id - if accessed as Multi-Admin |
1006 | Company Payroll History | Admin, Multi-Admin | company-id - if accessed as Multi-Admin |
1007 | Company Benefits | Admin, Multi-Admin | company-id - if accessed as Multi-Admin |
1008 | Company Reports | Admin, Multi-Admin | company-id - if accessed as Multi-Admin |
1009 | Company Time Off | Admin, Multi-Admin | company-id - if accessed as Multi-Admin |
1010 | Company Integrations | Admin, Multi-Admin | company-id - if accessed as Multi-Admin |
1011 | Company Premium ATS | Admin, Multi-Admin | company-id - if accessed as Multi-Admin |
10001 | Employee Dashboard | Employee | |
10002 | Employee Personal Info | Employee | |
10003 | Employee Contract | Employee | |
10004 | Employee Tax Setup | Employee | |
10005 | Employee Deductions | Employee | |
10006 | Employee Pay Statements | Employee | |
10007 | Company Info | Employee | |
10008 | Documents | Employee | |
10009 | Time Off | Employee |
- roleAccess : Specifies the type of access control, determining which login role of the user will be selected for the user token; its values have the following meanings:
Int | Role |
---|---|
null | selects the highest role from all existing user roles |
1 | System |
2 | Admin |
3 | Employee |
- company <int>: For the login roles that a user may have been assigned more than one for different companies, it is possible to explicitly select a role for a specific company with this parameter.
This is an optional parameter that applies to Client Admin and Employee roles. - customAppClaims array(type , value ): An array of application properties that are required according to the requested page.
Example:
curl --request POST
--url /token/user/ \
--header 'Authorization: Bearer ' \
--header 'content-type: application/*+json' \
--data '
{
"page": 4,
"email": "[email protected]",
"roleAccess": 2,
"customAppClaims": [
{
"type": "employeeId",
"value": "123"
}
]
}
'
Endpoint output:
{
"email": "[email protected]",
"appUrl": "https://your_app_domain",
"userToken": "eyJhbGciOiJSUzI..."
}
3. Embed iFrame Into Your Page
Finally, you can embed an iframe into your application using the appUrl
and userToken
properties, you received from the User token API call.
<iframe src="@Url.Content(appUrl+userToken)"></iframe>
Here's a refined version of the text with improved clarity and structure:
Displaying Custom Flows in an iframe
WEP iframes support displaying specific sections of a page, not just the entire page. To achieve this, you need to include the appropriate flow value in the customAppClaims
.
Supported Flows and Required Properties
Flow Name | Required Properties |
---|---|
custom-fields-employee-view | company-id , employee-id |
custom-fields-employee-edit | company-id , employee-id |
custom-fields-company | company-id |
custom-fields-employee-onboarding-phase1 | company-id , onboarding-id |
custom-fields-employee-onboarding-phase2 | company-id , ercu |
Example:
curl --request POST \
--url /token/user/ \
--header 'Authorization: Bearer <token>' \
--header 'Content-Type: application/*+json' \
--data '{
"email": "[email protected]",
"customAppClaims": [
{
"type": "flow",
"value": "custom-fields-employee-view"
},
{
"type": "company-id",
"value": 1
},
{
"type": "employee-id",
"value": 1
}
]
}'
Configuration note
To successfully call a User token endpoint, you need to get the external client configuration for your application, the client_id
and client_secret
mentioned in the first chapter.
The URL for the application and API endpoints must also be properly configured for your instance environment.
This configuration is provided by Worklio and please contact us in case of missing or incorrect configuration.
Updated 4 months ago