-
Notifications
You must be signed in to change notification settings - Fork 451
Reference : Integrations
Integrations in Pizzly are derived from individual JSON configuration files, located in the /integrations
directory at the root of the Pizzly project. For example, the GitHub integration is configured at /integrations/github.json
and looks like this:
{
"name": "GitHub",
"auth": {
"authorizationURL": "https://github.com/login/oauth/authorize",
"tokenURL": "https://github.com/login/oauth/access_token",
"authType": "OAUTH2",
"tokenParams": {},
"authorizationParams": {},
"auth": { "accessType": "offline" }
},
"request": {
"baseURL": "https://api.github.com/",
"headers": {
"Accept": "application/vnd.github.v3+json",
"Authorization": "token ${auth.accessToken}",
"User-Agent": "Pizzly"
}
}
}
All requests sent to the third-party APIs are made based on the content of the relevant configuration file.
There are dozens of APIs pre-configured with Pizzly (full list here). But if the API you are looking for is not listed yet, you can create a new JSON configuration file with the name of the API.
To add a new integration, whether for your own project or to publicly share the configuration with the community, follow this guide.
Each API has a configuration JSON file associated with it. The file is located within the /integrations/
directory and is named afterward the API name (in lowercase).
API Name | Configuration file name | OAuth Type |
---|---|---|
GitHub | github.json | OAuth 2.0 |
reddit.json | OAuth 2.0 | |
twitter.json | OAuth 1.0a |
In case the API name has several words, use an hyphen between each word (e.g google-calendar.json).
Each JSON file has four top-level keys: name
, image
, auth
, and request
.
{
// The name of the integration
"name": "API Name",
// Image URL for API logo (optional)
"image": "https://path.to.image.url.jpg"
// All authorization-related settings
"auth": {}
// Defines how to perform API requests
"request": {}
}
The name and image keys define how the API will be displayed in the Pizzly dashboard. Image is optional, and will be picked up by Clearbit's image API if omitted. If you notice an image not showing up adding an image URL is recommended. (As can be seen in the Google Calendar integration file)
The next main section is the auth
key. This object contains all the necessary information needed for Pizzly to perform the OAuth dance with the API provider. These values can often be found at the authentication page of the API provider's documentation. Some are specific to the authentication type.
-
authType
: The authentication type, eitherOAUTH1
orOAUTH2
. -
authorizationURL
(OAUTH2): The URL that users are redirected to when asked to authorize your application. Usually the provider's auth endpoint, such ashttps://github.com/login/oauth/authorize
. -
tokenURL
(OAUTH2): The URL used to exchange the auth code for the token during the auth flow. For example:https://github.com/login/oauth/access_token
. -
requestTokenURL
(OAUTH1): The URL provided by the API for retrieving the request token. -
accessTokenURL
(OAUTH1): The URL provided by the API for retrieving the access token. -
userAuthorizationURL
(OAUTH1): The URL provided by the API for authorizing the user. -
signatureMethod
(OAUTH1): The method used by the API to sign requests. -
authorizationParams
: This object contains any static parameters that need to be passed in during authorization. For example, the Discord API expects"response_type": "code"
and"grant_type": "authorization_code"
to be sent during authorization. Pizzly will send common dynamic values back to the API. -
tokenParams
: Similar to theauthorizationParams
key, this object contains any required static parameters that need to be sent to the token URL. For example, GitLab expects theresponse_type
with the authorization URL, butgrant_type
with the token URL.
In cases where authorizationParams
or tokenParams
are not required, they can be left as empty objects or omitted completely.
{
"name": "API Name",
"image": "https://path.to.image.url.jpg",
// All authorization-related settings
"auth": {
// This is the URL that user's will be directed to when
// initiating the authorization flow.
"authorizationURL": "https://example.api/oauth",
// The URL used for exchanging the auth code for a token
"tokenURL": "https://example.api/oauth/token",
// Set to either OAUTH1 or OAUTH2
"authType": "OAUTH2",
// Any fixed parameters that the API expects during token exchange
"tokenParams": {
// The grant_type is a common token parameter
"grant_type": "authorization_code"
},
// Set any required, fixed, parameters to be passed during authorization
// ex. state, access_type, prompt, etc
"authorizationParams": {
"response_type": "code"
}
}
}
The final part of the config file is the request
key. It takes the baseURL
, an object of headers
, and an object of params
. This is also where you will need to take advantage of the variable interpolations that Pizzly offers. You may have seem them in the other config files, such as ${auth.accessToken}
. These properties are dependant on the API provider and auth type. For example:
{
"name": "API Name",
"image": "https://path.to.image.url.jpg",
"auth": {},
"request": {
// The API base URL
"baseURL": "https://api.example.com/",
// Extra headers that will be passed with each request
"headers": {
"Accept": "application/json",
"Authorization": "Bearer ${auth.accessToken}",
"User-Agent": "Pizzly"
},
// Extra parameters that will be passed in the body of each API call
"params": {
"example": "value"
}
}
}
Some APIs require extra information than Pizzly supports per se. To support this APIs, the configuration file can use extra variable interpolations.
You might have notice the ${auth.accessToken}
which is used in all integration's configurations. The other available interpolation object is the ${headers.[...]}
.
This can be used for APIs that require more information than Pizzly currently supports. For example, an API that requires a custom base URL can be accessed by passing a header with each API call. Pizzly's proxy will make sure to replace the variable from the configuration with the value provided in the header, e.g. : "baseURL":"https://${headers.api_account_name}.example.com"
Make sure that your integration works locally. To start testing a new integration, follow the instructions for Running Pizzly on your machine. Confirm that Pizzly is working locally by visiting http://localhost:8080
before attempting to add a new integration.
Most settings are described in this page, but we recommend using an existing API's configuration file that matches the auth type of the new API.