Authorization
To access Mergado API, clients (e.g. an application) are authenticated using OAuth 2.0. Each application is required to have its OAuth credentials which can be obtained from the Mergado developers center (when you register your application, a client ID and a secret key is assigned to your application).
Grant Types
If you are familiar with the OAuth protocol, you already know that with every access to a protected resource (our API), clients need to provide an access token. Our authorization server supports two authorization grants which can be used to obtain access tokens:
- Online mode, which is similar to the authorization_codegrant in OAuth 2.0.
- Offline mode, which is similar to the refresh_tokengrant type.
Online mode
An access token is obtained using the authorization_code grant defined in the OAuth 2.0 authorization framework. This mode is used when the end-user (aka the resource owner) is capable of receiving incoming requests (typically via redirection in a web browser). If the end-user is not interacting with a web browser (i.e. is not currently working in Mergado) but an application needs to access a protected resource, the refresh_token grant described in the Offline Mode section must be used.
To obtain an access token using the authorization_code grant type, the following steps need to be taken:
- A client (application) sends a GET request to https://app.mergado.com/oauth2/authorize/with the following query string parameters:- client_id– An OAuth client ID.
- redirect_uri– Redirection URI to which the authorization server will send the end-user back once access is granted (or denied).
- grant_type–- authorization_code.
- response_type–- code, this tells the authorization server that we want to return an authorization code which will be exchanged with an access token.
- entity_id– ID of the entity the client wants access to.- entity_idmust be provided if your app is of- projector- shoptype.- entity_idmust not be provided if your app is of the- usertype. In that case- entity_idwill be the same as ID of the end-user that is currently logged in.
 Example: https://app.mergado.com/oauth2/authorize/ ?client_id=123 &redirect_uri=https://appcloud.mergado.com &response_type=code &grant_type=authorization_code &entity_id=456
- Authorization server redirects to the given redirection URI with a newly created authorization code (e.g. https://app.mergado.com/?code=jkl).
- A client (application) sends a POST request to https://app.mergado.com/oauth2/token/with the following JSON encoded fields:- client_id– An OAuth client ID.
- client_secret– An OAuth secret key.
- redirect_uri– Redirection URI to which the authorization server will send the end-user back once access is granted (or denied).
- grant_type–- authorization_code.
- code– Authorization code obtained in the previous step.
 
- 
    The authorization server responses with an access token (if the access is granted): { "access_token": "ras11", "expires_in": 3600, "token_type": "bearer", "entity_id": "5", "user_id": "1" }
Offline mode
An access token is obtained using the refresh_token grant type. When an application needs to access protected resource (e.g. to hide/unhide some products) but the end-user cannot interact with Mergado in a web browser, we say that it works in the offline mode.
In offline mode, the access token is obtained by the following steps:
- A client (application) sends a POST request to https://app.mergado.com/oauth2/token/with the following JSON encoded fields:- client_id– An OAuth client ID.
- client_secret– An OAuth secret key.
- grant_type–- refresh_token.
- refresh_token– Entity ID encoded in base64, i.e. if entity ID is- 5, the refresh token is- NQ==(if you are wondering why we require the entity ID to be encoded in base64: there is no rational reason, it probably just looks better).
 
- 
    The authorization server responses with an access token (if the access is granted): { "access_token": "f192d", "expires_in": 3600, "token_type": "bearer", "entity_id": "5" }
Important! Access tokens obtained in the offline mode have somewhat different permissions than tokens obtained in the online mode. Permissions in the offline mode depend on the type of application (or the entity type). For example, if an application is created for eshops (entity type is shop) in the offline mode, it won’t be able to access information of any user since the access token is created on behalf of an eshop. In the online mode, a protected resource is always accessed on behalf of an end-user - this means that with the appropriate scope, an application can access this user’s information.
Implicit
The implicit grant type is used to obtain access tokens (it does not support the issuance of refresh tokens) and is optimized for public clients known to operate a particular redirection URI. These clients are typically implemented in a browser using a scripting language such as JavaScript.
To obtain an access token using the Implicit grant type, the following steps need to be taken:
- A client (application) sends a GETrequest tohttps://app.mergado.com/oauth2/authorize/with the following query string parameters:- response_type-- token, this tells the authorization server that we want to use an implicit grant type, which will return an access token in the fragment of the URL.
- client_id– An OAuth client ID.
- redirect_uri– Redirection URI to which the authorization server will send the end-user back once access is granted (or denied).
- entity_id– ID of the entity the client wants access to.
 Example: https://app.mergado.com/oauth2/authorize/ ?response_type=token &client_id=123 &entity_id=123 &redirect_uri=https://appcloud.mergado.com
- 
    The authorization server redirects to redirect_uriwith an access token in the fragment of URL.Example: https://appcloud.mergado.com/ &access_token=f841a16676a2fa66222a3d70faae92c70f78fc65 &expires_in=3600 &token_type=bearer&entity_id=123 &user_id=456
Using Access Tokens
Whichever method you used to authorize your client, you obtained an access_token. This access token is used to sign requests to access protected resources. So let’s you want to show information about the authenticated user this token is assigned to. You would call the /me/ URL with the following header:
Accept: application/json
Authorization: Bearer <your_access_token>
And that’s it, the server would respond with a JSON document containing the user’s information (provided the token is not expired and has the correct access rights).