The HasOffers API provides a remote authentication protocol that will allow you to implement a single sign-on or remote login solution where partners or advertisers can access the platform without manually applying their login credentials. This is especially useful when having users jump from one platform into HasOffers without having the user log in to both systems.
The remote authentication uses a unique, hashed value to log in a user to the platform for each unique session. This token is generated with the Authentication::findUserByCredentials API call. To have this token created, the set_token value must be passed and set to '1' for the token to be generated. The call structure for retrieving the token:
https://NETWORKID.api.hasoffers.com/Apiv3/json?NetworkToken=NETWORKTOKEN
The user’s email and password are required in the API call. When this call has been made, this will be the response:
"data": {
"user_type": "affiliate_user",
"user_id": "2",
"user_status": "active",
"account_status": "active",
"hash": "e864f39cf0521423ce697db1652e216",
"token": "2t434ReL9XHPnQ2eoTLOrBWPvD"
},
In the response is the generated single-session token that can be used to log in to the platform. Logging into the platform simply means passing the token on the end of your application URL:
https://NETWORKID.hasoffers.com/remote_login/{login_token}
If your network uses a custom application domain you will want to use that domain for the call instead of the NETWORKID.hasoffers.com domain.
https://affiliates.customdomain.com/remote_login/{login_token}
An example of the completed login url is:
https://demo.hasoffers.com/remote_login/2t434ReL9XHPnQ2eoTLOrBWPvD
When fired, the above URL will log the user into your network. When the token is unique for each login, expiring after its use. A new token will need to be generated for future remote logins to the app.