By using our API, it's possible to create your own custom login page on your website.
Benefits of creating your own custom login page include:
Tie into your existing website or CRM (client relationship management) software
Style your login area to match your exact design specifications
Change the behavior of the way your clients log in and which page they land on
You will need access to the API which is only available on some plans.
βView the API information here.
Note: Due to the unique ways in which a website can be set up to use the API, our Support staff do not assist with API troubleshooting. We recommend to hire a professional Web Developer to handle the API for you.
How to create your own custom login page
First, you will need to find your API key in order to make API requests.
This is located under your profile settings. For more information view this resource article.
The basic process to create a functioning custom login page is as follows:
Authenticate the user on your end
Get the user list from your AgencyAnalytics account using the API
Match the user ID
Generate the login grant for that user ID via the API
Redirect to the URL provided by the API response
Authenticate the user on your end
This step is entirely dependent on the way your existing website is setup, and what CMS (content management system) it is using.
For example, for a Wordpress CMS, you can use the wp_authenticate function to check whether the login is valid or not; and if the user logs in successfully, continue.
wp_authenticate($username, $password);
Get the user list from your AgencyAnalytics account using the API
Perform a request to list all users.
{
"provider": "agency-analytics-v2",
"asset": "user",
"operation": "read",
"fields": [
"id",
"campaign_id",
"date_created",
"date_modified",
"email",
"first_name",
"last_name",
"role",
"campaign_access",
"status",
"account_id"
],
"sort": [
{
"id": "desc"
}
],
"offset": 0,
"limit": 50
}
The response will be in JSON format and will be similar to the below:
{
"metadata": {
"total_pages": 1,
"total_records": 2
},
"data": [
{
"id": 123,
"date_created": "2015-03-30 10:06:24",
"email": "bob@myagency.com",
"username": "bob@myagency.com",
"password": null,
"first_name": "Bob",
"last_name": "Doe",
"role": "client",
"campaign_access": "restricted",
"account_id": 1
},
{
"id": 124,
"date_created": "2015-03-30 10:06:25",
"email": "alice@myagency.com",
"username": "alice@myagency.com",
"password": null,
"first_name": "Alice",
"last_name": "Citizen",
"role": "client",
"campaign_access": "restricted",
"account_id": 1
}
]
}
Match the user ID
Here is where you will need to match the username that was entered into your form with the username from the user list that was provided by the API response.
It's recommended to use email addresses as the usernames, because AgencyAnalytics uses them and therefore they will match up quite easily. However this will not be possible in every circumstance (depending how your own customer database is set up).
Generate the login grant for that user ID via the API
Now that the user ID (123) has been retrieved for the specific user that is trying to login, you can generate the login grant via the API.
{
"provider": "agency-analytics-v2",
"asset": "login-grant",
"operation": "create",
"rows": [
{
"user_id": "123"
}
]
}
Response:
{
"metadata": {
"total_pages": 1,
"total_records": 1
},
"data": {
"token": "tkn.7bf94c2ks9f2e7d86174a4b3fc01c5ae",
"time": "2015-04-13 16:34:57",
"login_url": "http:\/\/reports.myagency.com\/login-token\/tkn.c6e1768b8e01ddwq2461ace8886b",
"user_id": 123,
"origin_user_id": 1
}
}
Redirect to the URL provided by the API response
With that API response you can extract the login URL.
http://reports.myagency.com/login-token/tkn.c6e1768b8e01ddwq2461ace8886b
Finally, the user can be sent to their client area by using one of the many redirect methods.