This document contains brief information on OAuth, reveals the new approach to OAuth utilization within the platform and explains how to use OAuth clients for components in a tenant.
This document contains brief information on OAuth, reveals the new approach to OAuth utilization within the platform and explains how to use OAuth clients for components in a tenant.
Some integration components use OAuth client to provide accessibility. However, our legacy implementation restricted the user to a single OAuth client per component per tenant. The OAuth client for component was defined in the component’s environment variables.
For example, for Salesforce component the following environment variables were
required in its component.json file:
"envVars": {
   "OAUTH_CLIENT_ID": {
     "required": true,
     "description": "Your Salesforce OAuth client key"
   },
   "OAUTH_CLIENT_SECRET": {
     "required": true,
     "description": "Your Salesforce OAuth client secret"
   }
},
Obviously, "OAUTH_CLIENT_ID" defines Oauth key for Salesforce component, and
"OAUTH_CLIENT_SECRET" defines Oauth secret.
This way global access to the component could not be enabled, because users in
other tenants would see the component with its keys and secrets.
NOTE: A refresh_token is required for every OAuth 2.0 key.
OAuth clients are defined separately from the components’ environment variables
and belong to tenants rather than components. This means that even if we make a
component globally accessible, its OAuth client will still remain in our tenant.
Users in other tenants will not be able to see or use this global component
until they define a component-specific OAuth client for their tenant.
To manage OAuth clients the user requires the following permissions:
tenants.oauth_clients.gettenants.oauth_clients.edittenants.oauth_clients.createtenants.oauth_clients.deleteTo acquire these permissions, please contact support.
To define OAuth client for a component, be sure to specify "useOAuthClient": true
in the component.json file. For compatibility reasons, we should also create a
link between the new implementation and environment variables if they were present.
You can find the corresponding code in the example below.
EXAMPLE:
If you had the following defined for environment variables:
"envVars": {
    "PIZZAVAN_KEY": {
      "required": true,
      "description": "Your Pizza Van OAuth client key"
    },
    "PIZZAVAN_SECRET": {
      "required": true,
      "description": "Your Pizza Van OAuth client secret"
    }
  }
Add the following object to component.json:
"oauth2": {
      "client_id": "",
      "client_secret": "",
      "auth_uri": "https://auth_uri",
      "token_uri": "https://token_uri"
    },
    "useOAuthClient": true
  },
OAuth client management includes the following actions:
You can create one OAuth client per component in a tenant. Also, OAuth client can only be defined for a component that exists in the tenant, and is visible.
To create OAuth clients, use the following API request:
POST https://api.thatapp.io/v2/tenants/{TENANT_ID}/oauth-clients
Below are request parameters:
| URL Parameter | Required | Description | 
|---|---|---|
| TENANT_ID | yes | Tenant ID | 
| Payload Parameter | Required | Description | 
|---|---|---|
| attributes.client_id | yes | OAuth client ID | 
| attributes.client_secret | yes | OAuth client secret | 
| type | yes | The value should be flow | 
| relationships.component.data.id | yes | Component ID | 
| relationships.component.data.type | yes | The value should be component | 
EXAMPLE:
 curl https://api.thatapp.io/v2/tenants/{TENANT_ID}/oauth-clients \
   -X POST \
   -u {EMAIL}:{APIKEY} \
   -H 'Content-Type: application/json' -d '
   {
     "data":{
       "type":"oauth-client",
       "attributes":{
         "client_id":"{CLIENT_ID}",
         "client_secret":"{CLIENT_SECRET}"
       },
       "relationships":{
         "component":{
           "data":{
             "id":"{COMPONENT_ID}",
             "type":"component"
           }
         }
       }
     }
   }'
To retrieve OAuth clients in a tenant, use the following API request:
GET https://api.thatapp.io/v2/tenants/{TENANT_ID}/oauth-clients
Below are request parameters:
| URL Parameter | Required | Description | 
|---|---|---|
| TENANT_ID | yes | Tenant ID | 
| filter[component] | no | Filter by component ID | 
EXAMPLES:
The first example is without filtering by component ID.
curl https://api.thatapp.io/v2/tenants/{TENANT_ID}/oauth-clients \   -u
{EMAIL}:{APIKEY}
The second example includes filtering by component ID.
curl
https://api.thatapp.io/v2/tenants/{TENANT_ID}/oauth-clients/?filter[component]=
\    -u {EMAIL}:{APIKEY}
OAuth clients can also be retrieved by their own ID, using the following API request:
curl
https://api.thatapp.io/v2/tenants/{TENANT_ID}/oauth-clients/{OAUTH-CLIENT_ID} \
-u {EMAIL}:{APIKEY}
Below are request parameters:
| URL Parameter | Required | Description | 
|---|---|---|
| TENANT_ID | yes | Tenant ID | 
| OAUTH-CLIENT_ID | yes | The ID of the OAuth client | 
EXAMPLE:
curl
https://api.thatapp.io/v2/tenants/{TENANT_ID}/oauth-clients/{OAUTH-CLIENT_ID} \
-u {EMAIL}:{APIKEY}
To update OAuth clients in a tenant, use the following API request:
PATCH
https://api.thatapp.io/v2/tenants/{TENANT_ID}/oauth-clients/{OAUTH-CLIENT_ID}
Below are request parameters:
| URL Parameter | Required | Description | 
|---|---|---|
| TENANT_ID | yes | Tenant ID | 
| OAUTH-CLIENT_ID | yes | The ID of Oauth Client | 
| Payload Parameter | Required | Description | 
|---|---|---|
| type | yes | The value should be oauth-client | 
| attributes.client_id | yes | Oauth-client ID | 
| attributes.client_secret | yes | Oauth-client secret | 
| relationships.component.data.id | yes | Component ID | 
| relationships.component.data.type | yes | The value should be component | 
EXAMPLE:
curl https://api.thatapp.io/v2/tenants/{TENANT_ID}/oauth-clients/{OAUTH-CLIENT_ID} \
  -X PATCH \
  -u {EMAIL}:{APIKEY} \
  -H 'Content-Type: application/json' -d '
  {
    "data":{
      "type":"oauth-client",
      "attributes":{
        "client_id":"{CLIENT_ID}",
        "client_secret":"{CLIENT_SECRET}"
      },
      "relationships":{
        "component":{
          "data":{
            "id":"{COMPONENT_ID}",
            "type":"component"
          }
        }
      }
    }
  }'
You can only delete an OAuth client that is not used. An OAuth client is considered used when at least one integration flow in the tenant includes the component with this OAuth client. In case you delete a component with a defined OAuth client, this client will remain on the platform. However, it will not be usable. A user with corresponding permissions can remove this OAuth client, if required.
To delete an OAuth client, use the following API request:
DELETE
https://api.thatapp.io/v2/tenants/{TENANT_ID}/oauth-clients/{OAUTH-CLIENT_ID}
\\
Below are request payload parameters:
| URL Parameter | Description | 
|---|---|
| TENANT_ID | Tenant ID | 
| OAUTH-CLIENT_ID | The ID of the OAuth client | 
EXAMPLE:
curl -i
https://api.thatapp.io/v2/tenants/{TENANT_ID}/oauth-clients/{OAUTH-CLIENT_ID} \
-X DELETE \  -u {EMAIL}:{APIKEY}
You can only delete an OAuth client that is not used. An OAuth client is considered used when at least one integration flow in the tenant includes the component with this OAuth client. In case you delete a component with a defined OAuth client, this client will remain on the platform. However, it will not be usable. A user with corresponding permissions can remove this OAuth client, if required.