- @adobe/aio-lib-ims
The
@adobe/aio-lib-ims
module offers three kinds of elements:- Managing configuration contexts for token creation and use
- Creating and invalidating tokens
- Providing low level access to IMS API
- Ims
The
Ims
class wraps the IMS API.- ConfigCliContext
The
ConfigCliContext
class stores IMScontexts
for the Adobe I/O CLI in the local file system using the Adobe I/O Core Configuration Library.- Context
The
Context
abstract class provides an interface to manage the IMS configuration contexts on behalf of the Adobe I/O Lib IMS Library.- StateActionContext
The
StateActionContext
class stores IMScontexts
for Adobe I/O Runtime Actions in the cloud using the Adobe I/O State Library.
- TYPE_ACTION
Name of context type action
- TYPE_CLI
Name of context type cli
- IMS
Name of the IMS configuration context data structure
- CONTEXTS
Property holding an object with all contexts
- CONFIG
Property holding an object with context management configuration
- CLI
Property holding the cli context name
- CURRENT
Property holding the current context name
- ACCESS_TOKEN
The constant string
access_token
.- REFRESH_TOKEN
The constant string
refresh_token
.- AUTHORIZATION_CODE
The constant string
authorization_code
.- CLIENT_ID
The constant string
client_id
.- CLIENT_SECRET
The constant string
client_secret
.- SCOPE
The constant string
scope
.
- _sendPost(postUrl, token, postData) ⇒
Promise
Send a request via POST.
- getTokenData(token) ⇒
object
Returns the decoded token value as JavaScript object.
The @adobe/aio-lib-ims
module offers three kinds of elements:
- Managing configuration contexts for token creation and use
- Creating and invalidating tokens
- Providing low level access to IMS API
Kind: static property of @adobe/aio-lib-ims
See: getTokenData
Kind: static property of @adobe/aio-lib-ims
See: Ims
Kind: static property of @adobe/aio-lib-ims
See: ACCESS_TOKEN
Kind: static property of @adobe/aio-lib-ims
See: REFRESH_TOKEN
Kind: static property of @adobe/aio-lib-ims
See: AUTHORIZATION_CODE
Kind: static property of @adobe/aio-lib-ims
See: CLIENT_ID
Kind: static property of @adobe/aio-lib-ims
See: CLIENT_SECRET
Kind: static property of @adobe/aio-lib-ims
See: SCOPE
Kind: static property of @adobe/aio-lib-ims
See: Context
Returns an access token for the given context name. When running in Adobe I/O Runtime
tokens will be persisted in the State SDK
.
Kind: static method of @adobe/aio-lib-ims
Returns: Promise
- Resolving to an access token (string)
Param | Type | Description |
---|---|---|
contextName | string |
The name of the IMS context for which to return the access token. If this is empty, the token(s) of the current IMS context are invalidated. |
[force] | boolean |
Forces a login in the selected plugin's imslogin function. See Forced imsLogin for more information on this flag. The default value is false . |
Invalidates the access and optionally refresh of an IMS context. The name of the IMS context is given as its first parameter and defaults to the current context if missing or empty. The force parameter indicates whether only the access token is invalidated (force=false) or the refresh token (if existing) is also invalidated (force=true). If the refresh token exists and is validated, all access tokens which have been created with this refresh token will automatically become invalid as well.
Kind: static method of @adobe/aio-lib-ims
Returns: Promise
- Promise that resolves with the request data
Param | Type | Description |
---|---|---|
contextName | string |
The name of the IMS context for which to invalidate the token(s). If this is empty, the token(s) of the current IMS context are invalidated. |
[force] | boolean |
Whether to invalidate just the access token or to also invalidate the refresh token. Defaults to false . |
The Ims
class wraps the IMS API.
Kind: global class
- Ims
- new Ims(env)
- instance
- .getApiUrl(api) ⇒
string
- .getSusiUrl(clientId, scopes, callbackUrl, state) ⇒
string
- .get(api, token, parameters) ⇒
Promise
- .post(api, token, parameters) ⇒
Promise
- .getAccessToken(authCode, clientId, clientSecret, scopes) ⇒
Promise
- .exchangeJwtToken(clientId, clientSecret, signedJwtToken) ⇒
Promise
- .invalidateToken(token, clientId, clientSecret) ⇒
Promise
- .validateToken(token, [clientId]) ⇒
object
- .getOrganizations(token) ⇒
object
- .toTokenResult(token) ⇒
Promise
- .getApiUrl(api) ⇒
- static
- .fromToken(token) ⇒
Promise
- .fromToken(token) ⇒
Creates a new IMS connector instance for the stage or prod environment
Param | Type | Description |
---|---|---|
env | string |
The name of the environment. prod and stage are the only values supported. prod is default and any value other than prod or stage stage is assumed to be the default value of prod . |
Returns the absolute URL to call the indicated API.
The API is expected to be the API absolute path, such as /ims/profile
.
To form the absolute URL, the scheme (https
) and fully qualified
domain of the IMS host for this instance's environment is prepended
to the path.
Kind: instance method of Ims
Returns: string
- The absolute URI for the IMS API
Param | Type | Description |
---|---|---|
api | string |
The API (path) for which to return the URL |
Returns the URL for the environment of this instance which allows for OAuth2 based three-legged authentication with a browser for an end user.
Kind: instance method of Ims
Returns: string
- the OAuth2 login URL
Param | Type | Description |
---|---|---|
clientId | string |
The Client ID |
scopes | string |
The list of scopes to request as a blank separated list |
callbackUrl | string |
The callback URL after the user signed in |
state | string |
Any state value which is passed back from sign in |
Send a GET
request to an IMS API with the access token sending
the parameters
as request URL parameters.
Kind: instance method of Ims
Returns: Promise
- a promise resolving to the result of the request
Param | Type | Description |
---|---|---|
api | string |
The IMS API to GET from, e.g. /ims/profile/v1 |
token | string |
The IMS access token to call the API |
parameters | Map |
A map of request parameters |
Send a POST
request to an IMS API with the access token sending
the parameters
as form data.
Kind: instance method of Ims
Returns: Promise
- a promise resolving to the result of the request
Param | Type | Description |
---|---|---|
api | string |
The IMS API to POST to, e.g. /ims/profile/v1 |
token | string |
The IMS access token to call the API |
parameters | Map |
A map of request parameters |
Request the access token for the given client providing the access
grant in the authCode
.
The promise resolve to the token result JavaScript object as follows:
{
access_token: {
token: "eyJ4NXUiOi...6ZodTesbag",
expiry: 1566242851048
},
refresh_token: {
token: "eyJ4NXUiOi...YbT1_szWZA",
expiry: 1567366051050
},
payload: {
...full api response...
}
}
Kind: instance method of Ims
Returns: Promise
- a promise resolving to a tokens object as described in the
toTokenResult or rejects to an error message.
Param | Type | Description |
---|---|---|
authCode | string |
The authorization code received from the OAuth2 sign in page or by some other means. This may also be a refresh token which may be traded for a new access token. |
clientId | string |
The Client ID |
clientSecret | string |
The Client Secrete proving client ID ownership |
scopes | string |
The list of scopes to request as a blank separated list |
Asks for the signed JWT token to be exchanged for a valid access token as well as a refresh token. The promise resolve to the token result JavaScript object as follows:
{
access_token: {
token: "eyJ4NXUiOi...6ZodTesbag",
expiry: 1566242851048
},
payload: {
...full api response...
}
}
Note that there is no refresh_token
in a JWT tokan exchange.
Kind: instance method of Ims
Returns: Promise
- returns a Promise that resolves to the token result object
Param | Type | Description |
---|---|---|
clientId | string |
The client ID of the owning application |
clientSecret | string |
The client's secret |
signedJwtToken | string |
The properly signed JWT token for the JWT token exchange |
Invalidates the given token. If the token is a refresh token, all the access tokens created with that refresh token will also be invalidated at the same time.
Kind: instance method of Ims
Returns: Promise
- Promise that resolves with the request data
Param | Type | Description |
---|---|---|
token | string |
the access token |
clientId | string |
the client id |
clientSecret | string |
the client secret |
Verifies a given token.
Kind: instance method of Ims
Returns: object
- the server response
Param | Type | Description |
---|---|---|
token | string |
the access token |
[clientId] | string |
the client id, optional |
Gets the IMS organizations attached to the given token.
Kind: instance method of Ims
Returns: object
- the server response
Param | Type | Description |
---|---|---|
token | string |
the access token |
Converts the access token to a token result object as follows:
{
access_token: {
token: "eyJ4NXUiOi...6ZodTesbag",
expiry: 1566242851048
}
}
The expiry
property is the expiry time of the token in milliseconds
since the epoch.
Kind: instance method of Ims
Returns: Promise
- a Promise
resolving to an object as described.
Param | Type | Description |
---|---|---|
token | string |
The access token to wrap into a token result |
Creates an instance of the Ims
class deriving the instance's
environment from the as
claim in the provided access token.
Kind: static method of Ims
Returns: Promise
- A Promise
resolving to the Ims
instance.
Param | Type | Description |
---|---|---|
token | string |
The access token from which to extract the environment to setup the Ims instancee. |
The ConfigCliContext
class stores IMS contexts
for the Adobe I/O CLI in the local file
system using the Adobe I/O Core Configuration Library.
Kind: global class
- ConfigCliContext
- .getCli() ⇒
Promise.<any>
- .setCli(contextData, [local], [merge])
- .getCli() ⇒
Gets the cli context data
Kind: instance method of ConfigCliContext
Returns: Promise.<any>
- the cli context data
Sets the cli context data
Kind: instance method of ConfigCliContext
Param | Type | Default | Description |
---|---|---|---|
contextData | object |
the data to save | |
[local] | boolean |
false |
set to true to save to local config, false for global config |
[merge] | boolean |
true |
set to true to merge existing data with the new data |
The Context
abstract class provides an interface to manage the IMS configuration contexts on behalf of
the Adobe I/O Lib IMS Library.
Kind: global class
- Context
- .getCurrent() ⇒
Promise.<string>
- .setCurrent(contextName) ⇒
Promise.<any>
- .get(contextName) ⇒
Promise.<object>
- .set(contextName, contextData, local)
- .keys() ⇒
Promise.<Array.<string>>
- .getCurrent() ⇒
Gets the current context name.
Kind: instance method of Context
Returns: Promise.<string>
- the current context name
Sets the current context name in the local configuration
Kind: instance method of Context
Returns: Promise.<any>
- returns an instance of the Config object
Param | Type | Description |
---|---|---|
contextName | string |
The name of the context to use as the current context |
Returns an object representing the named context. If the contextName parameter is empty or missing, it defaults to the current context name. The result is an object with two properties:
name
: The actual context name useddata
: The IMS context data
Kind: instance method of Context
Returns: Promise.<object>
- The configuration object
Param | Type | Description |
---|---|---|
contextName | string |
Name of the context information to return. |
Updates the named configuration with new configuration data. If a configuration object for the named context already exists it is completely replaced with this new configuration.
Kind: instance method of Context
Param | Type | Default | Description |
---|---|---|---|
contextName | string |
Name of the context to update | |
contextData | object |
The configuration data to store for the context | |
local | boolean |
false |
Persist in local or global configuration. When running in Adobe I/O Runtime, this has no effect unless contextData contains an access_token or refresh_token field, in which case setting local=true will prevent the persistence of those fields in the State SDK . Please note that when calling getToken in an I/O Runtime Action, generated tokens will always be persisted as getToken internally calls context.set with local=false . |
Returns the names of the configured contexts as an array of strings.
Kind: instance method of Context
Returns: Promise.<Array.<string>>
- The names of the currently known configurations.
The StateActionContext
class stores IMS contexts
for Adobe I/O Runtime Actions in the
cloud using the Adobe I/O State Library.
Name of context type action
Name of context type cli
Name of the IMS configuration context data structure
Property holding an object with all contexts
Property holding an object with context management configuration
Property holding the cli context name
Property holding the current context name
The constant string access_token
.
The constant string refresh_token
.
The constant string authorization_code
.
The constant string client_id
.
The constant string client_secret
.
The constant string scope
.
Send a request via POST.
Kind: global function
Returns: Promise
- Promise that resolves with the request data
Param | Type | Description |
---|---|---|
postUrl | string |
the url endpoint |
token | string |
the authorization token |
postData | object |
the data to send |
Returns the decoded token value as JavaScript object.
Kind: global function
Returns: object
- The decoded token payload data without header and signature
Param | Type | Description |
---|---|---|
token | string |
The token to decode and extract the token value from |