OAuth 1.0
Connection is a link between Make and a third-party service or app. The OAuth 1.0 connection handles the token exchange automatically.
While OAuth 1.0 is supported, it is not commonly used. Unless you are dealing with a legacy platform, we suggest you use a basic connection or OAuth 2.0.
Before you start to configure your OAuth 1.0 connection, you need to create an app on a third-party service. When creating an app, use https://www.integromat.com/oauth/cb/app-oauth1
as a callback URL.
Components
Communication
For more information, see the communication documentation.
aws
directive is not availableCommunication is extended with
oauth
pagination
directive is not availableresponse.limit
is not availableresponse.iterate
directive is not availableresponse.output
is not availableresponse
is extended withdata
oauth
It is sometimes tedious and difficult to generate an OAuth 1.0 Authorization header. Below are all the properties that you can use to customize the header generation.
consumer_key
IML String
Your consumer key
consumer_secret
IML String
Your consumer secret
private_key
IML String
Instead of consumer_secret
you can specify a private_key
string in PEM format
token
IML String
An expression that parses the oauth_token
string.
token_secret
IML String
An expression that parses the oauth_token_secret
string.
verifier
IML String
An expression that parses the oauth_verifier
string.
signature_method
String
Specifies the desired method to use when calculating the signature. Can be either HMAC-SHA1
, RSA-SHA1
, PLAINTEXT
. Default is HMAC-SHA1
.
transport_method
String
Specifies how OAuth parameters are sent: via query params, header or in a POST body. Can be either query
, body
or header
. Default is header
body_hash
IML String
To use Request Body Hash, you can either manually generate it, or you can set this directive to true
and the body hash will be generated automatically
response.data
The data
directive saves data to the connection so that it can be later accessed from a module through the connection
variable. It functions similarly to the temp
directive, except that data
is persisted to the connection.
{
"response": {
"data": {
"accessToken": "{{body.token}}"
}
}
}
Parameters
Parameters the user needs to provide when setting up a new connection.
Default scope
Default scope for every new connection.
Scope list
Collection of available scopes.
Common data
Non-user-specific sensitive values like secrets.
OAuth 1.0 authentication process
The OAuth 1.0 authentication process consists of multiple steps. You can select the steps you need and ignore the steps that you don’t. Fill in the needed sections and delete unneeded ones.
oauth
OAuth 1 parameters specification
Allows you to specify special OAuth 1.0 properties to simplify OAuth 1.0 header generation.
requestToken
Request specification
Describes a request that retrieves the request token
authorize
Request specification
Describes the authorization process.
accessToken
Request specification
Describes a request that exchanges credentials and the request token for the access token.
info
Request specification
Describes a request that validates a connection. The most common way to validate the connection is to call a method to get user’s information. Most of the APIs have such a method.
When using an OAuth 1.0 connection there is a special object available globally: the oauth
object. You can use it in the connection specification as well as in module specifications to avoid generating the OAuth 1.0 header yourself. This object is available at the root of the connection specification, in the Base and in Request Specification.
If the oauth
object is present in the root of the connection specification, it will be merged with each of the directives described above. If you wish to override some properties of the root object, you can do so in the respective directive by specifying the oauth
object and overriding the properties.
Available IML variables
These IML variables are available for you to use everywhere in this module:
now
Current date and time
environment
TBD
temp
Contains custom variables created via temp
directive.
parameters
Contains the connection’s input parameters.
common
Contains the connection’s common data collection.
data
Contains the connection's data collection.
oauth.scope
Contains an array of scope required to be passed to the OAuth 1.0 authorization process.
oauth.redirectUri
Contains the redirect URL for the OAuth 1.0 authorization process.
Last updated