Authentication

Dev Portal Clerk Setup

Clerk Setup

If you don't have an Clerk account, you can sign up for a free Clerk account that will provide you will 10,000 monthly active users.

1/ Create OAuth Application

Create a new OAuth application using the Clerk API.

The API request can be called using the curl command below. You will need to retrieve the Clerk secret key from the Dashboard.

The callback_url value must be set to the url of your Zuplo Dev Portal with the base path (this defaults to /docs/). Make sure you have the trailing slash set.

curl
 -X POST https://api.clerk.com/v1/oauth_applications \
 -H "Authorization: Bearer <CLERK_SECRET_KEY>"  \
 -H "Content-Type: application/json" \
 -d {"callback_url":"https://my-dev-portal.zuplo.app/docs/", "name": "zuplo_dev_portal", "scopes": "profile email"}
bash

The response of this request will return a JSON object that will contain the values for client_id and client_secret. Inside of the Zuplo Portal create two environment variables:

Create a new environment variable named ZUPLO_PUBLIC_CLERK_CLIENT_ID and set the value to the client_id value in the API response. Create a new environment variable, this one needs to be a secret, named CLERK_CLIENT_SECRET and set it to the value of the client_secret value in the API response.

2/ Configure the Developer Portal

Inside of the Zuplo Developer portal navigate to the Code Editor tab and open the dev-portal.json file. Open the JSON tab and edit the file to look like the following.

{
  "$schema": "https://cdn.zuplo.com/schemas/dev-portal.json",
  "enabled": true,
  "enableAuthentication": true,
  "requireAuthentication": false,
  "authentication": {
    "provider": "clerk",
    "issuer": "https://your-url.clerk.accounts.dev",
    "clientId": "$env(ZUPLO_PUBLIC_CLERK_CLIENT_ID)",
    "clientSecret": "$env(CLERK_CLIENT_SECRET)",
    "scope": "openid profile email"
  }
}
json