/v1/authorizations/applyToken
POST /v1/authorizations/applyToken
The applyToken
interface is used to obtain the access token. This interface can be used in the following cases:
- After the merchant receives authCode from Mini-Program, the merchant uses this interface to request the access token from e-wallet. In this scenario, the interface generally needs to be used with the Authorization Prepare Interface.
- When the original token expires, the merchant requests a new access token by using the refresh token. In this scenario, this interface can be used independently.
Message structure
Request
Property | Data type | Required | Description |
referenceClientId | String | No | In Mini-Program scenario, it is the unique identifier of the Mini-Program authorized by the user.
The referenceClientId represents the next-level clien id. When multiple auth codes need to be assigned to the same client, different referenceClientIds can be passed in to distinguish them. Max. length: 128 characters. |
grantType | String | Yes | Indicates which parameter is to be used to obtain the access token. Possible values are:
Max. length: 16 characters. |
authCode | String | No | Is required when grantType is AUTHORIZATION_CODE. The authorization code, which is used by confidential and public clients to exchange an authorization code for an access token. After the user returns to the client via the Mini-program API, the Mini-program will get the authorization code from the response of and use it to request an access token. Max. length: 32 characters. |
refreshToken | String | No | refreshToken is required when grantType is REFRESH_TOKEN. The refresh token, which is used by the auth client to exchange for a new access token when the access token expires. By using the refresh token, new access tokens can be obtained without further interaction with the user. Max. length: 128 characters. |
extendInfo | String | No | The extend information,wallet and merchant can put extend info here. Max. length: 4096 characters. |
Response
Property | Data type | Required | Description |
result | Yes | The request result, which contains information related to the request result, such as status and error codes. | |
accessToken | String | No | An access token that can be used to access the user resource scope. When authorization application is successful [result.resultStatus == S], the auth client might use accessToken to acccess the corresponding user's resource scope. Max. length: 128 characters. |
accessTokenExpiryTime | String/Datetime | No | Access token expiration time, which follows the ISO 8601 standard. After this time, authClient will not be able to use this token to deduct from user's account. This parameter must be returned when authorization application is successful [result.resultStatus == S], and the accessToken will be invalid after accessTokenExpiryTime. |
refreshToken | String | No | The refresh token that is used by the auth client to exchange for a new access token when the access token expires. By using the refresh token, new access tokens can be obtained without further interaction with the user. This parameter must be returned when authorization application is successful [result.resultStatus == S], and the merchant can use the refreshToken to request for a new accessToken. Max. length: 128 characters. |
refershTokenExpiryTime | String/Datetime | No | Refresh token expiration time, after which the auth client cannot use this token to retrieve a new access token. The value follows the ISO 8601 standard. This parameter must be returned when authorization application is successful [result.resultStatus == S], and the merchant will not be able to use the refreshToken to retrieve a new accessToken after refreshTokenExpiryTime. |
customerId | String | No | Resource owner id, maybe user id, app id of merchant's application, merchant id. Max. length: 64 characters. |
extendInfo | String | No | The extend information,wallet and merchant can put extend info here. Max. length: 4096 characters. |
Result process logic
For different request results, different actions are to be performed. See the following list for details:
- If the value of result.resultStatus is S, the authorization token application request is successful. The merchant can use the access token to access the corresponding user resource scope.
- If the value of result.resultStatus is F or U, AuthClient may guide user to try again.
Result
resultStatus | resultCode | resultMessage |
S | SUCCESS | Success. |
U | UNKNOWN_EXCEPTION | An API calling is failed, which is caused by unknown reasons. |
U | REQUEST_TRAFFIC_EXCEED_LIMIT | The request traffic exceeds the limit. |
F | PROCESS_FAIL | A general business failure occurred. Don't retry. |
F | PARAM_ILLEGAL | Illegal parameters exist. For example, a non-numeric input, or an invalid date. |
F | ACCESS_DENIED | The access is denied. |
F | INVALID_API | The called API is invalid or not active. |
F | AUTH_CLIENT_UNSUPPORTED_GRANT_TYPE | The auth client do not support this grant type. |
F | INVALID_AUTH_CLIENT | The auth client is invalid. |
F | INVALID_AUTH_CLIENT_STATUS | Invalid auth client status. |
F | INVALID_REFRESH_TOKEN | The refresh token is invalid. |
F | EXPIRED_REFRESH_TOKEN | The refresh token is expired. |
F | USED_REFRESH_TOKEN | The refresh token has been used. |
F | INVALID_CODE | The authorization code is invalid. |
F | USED_CODE | The authorization code has been used. |
F | EXPIRED_CODE | The authorization code is expired. |
F | REFERENCE_CLIENT_ID_NOT_MATCH | The reference client id does not match. |
F | EXPIRED_AGENT_TOKEN | The access token of mini program is expired. |
F | INVALID_AGENT_TOKEN | The access token of mini program is invalid. |
Sample
The authorization token application is used to exchange the access token based on the auth code after obtaining the auth code.
- The Mini Program calls my.getAuthCode interface to obtain the authorization code from e-wallet. (Step 1)
- E-wallet returns the authorization code to the Mini Program (Step 7)
- The Mini Program sends authorization code to the merchant server (Step 8)
- The merchant server calls /v1/authorizations/applyToken interface to obtain the access token from e-wallet server and e-wallet server returns the access token and customer ID to the merchant server (Step 9 and Step 11).
Note: Other steps are covered by e-wallet.
Request
A. Retrieving accessToken
with authCode
{
"referenceClientId": "305XST2CSG0N4P0xxxx",
"grantType": "AUTHORIZATION_CODE",
"authCode": "2810111301lGZcM9CjlF91WH00039190xxxx",
"extendInfo": "{\"customerBelongsTo\":\"siteNameExample\"}"
}
B. Retrieving accessToken
with refreshToken
{
"grantType": "REFRESH_TOKEN",
"refreshToken": "2810111301lGZcM9CjlF91WH00039190xxxx",
"extendInfo": "{\"customerBelongsTo\":\"siteNameExample\"}"
}
- authCode is from the my.getAuthCode JS-API, you can obtain the
authCode
in the success callback. when grantType == AUTHORIZATION_CODE means that we are requesting for the accessToken by theauthCode
. - refreshToken is obtained from the response of the previous accessToken Application call. while grantType == REFRESH_TOKEN means that we are requesting for the accessToken by providing the refreshToken.
- extendInfo, includes key - customerBelongsTo the e-wallet that the customer uses. Corresponding to the field 'siteName' that obtained from the API 'my.getSiteInfo', in the Mini Program scenario this is mandatory.
Response
{
"result": {
"resultCode": "SUCCESS",
"resultStatus": "S",
"resultMessage": "success"
},
"accessToken": "281010033AB2F588D14B43238637264FCA5AAF35xxxx",
"accessTokenExpiryTime": "2019-06-06T12:12:12+08:00",
"refreshToken": "2810100334F62CBC577F468AAC87CFC6C9107811xxxx",
"refreshTokenExpiryTime": "2019-06-08T12:12:12+08:00",
"customerId":"1000001119398804xxxx"
}
- result.resultStatus==S shows that the application is successful,
- AuthClient can make use of accessToken to access the user's resource scope before 2019-06-06T12:12:12+08:00[accessTokenExpiryTime].
- AuthClient can make use of refreshToken to request for a new accessToken before 2019-06-08T12:12:12+08:00[refreshTokenExpiryTime].