Skip to content
This repository has been archived by the owner on Sep 12, 2022. It is now read-only.

Latest commit

 

History

History
68 lines (47 loc) · 5.51 KB

README.md

File metadata and controls

68 lines (47 loc) · 5.51 KB

Auth0 Setup

This project is a set of tools made for programmatically setting up Auth0 tenants for local, Development, Staging, and Production environments. This repo is set up to set up Auth0 for the SmartColumbusOS project. Once you follow the steps below, you can change the URLs, Client ID, and other configuration settings to suite your project and then run the script against your Auth0 tenants.

Q. What is Auth0 and why would I want to use this? A. Auth0 is an technology that "Auth0 provides authentication and authorization as a service." https://auth0.com/docs/getting-started/overview

Auth0 provides "tenants" which are independent isolated environments that each have their own set of configuration, users, and endpoints. Their recommendation is to set up one tenant per environment: Development, Staging (aka Testing), and Production.

Setting Up New Auth0 Tenants

Before the tools in this repo can be used, you first need to set up the new tenants. There is not an API for creating new tenants. However, the following steps will set up a tenant in the simplest way possible allowing the tenant to be managed by these tools.

  1. Create tenant and pick a name - example smartcolumbusos-dev IMPORTANT THE TENANT NAME CANNOT BE CHANGED This is the subdomain used by auth0 for the endpoint. tenantname.auth0.com
  2. Go to https://support.auth0.com/tenants/public and verify the correct environment is set (Development, Staging, Production) Auth0 defaults new tenants to be in the "Development" environment.
  3. Login to the new tenant. Go to the "Applications" section. Create a new "Machine to Machine" application and call it Auth0 Management. Select all permissions. This will be the "application" we use to set up the rest of the tenant.
  4. Copy the Client ID from the application you created in the previous step. This will be the ID to use for the API to update the Auth0 configuration
  5. Save this id as the client ID in the Auth0 setup JSON file for the current environment for example config/dev.json.
  6. In the Auth0 management page, delete the Default Application named "Default App" This is not needed.
  7. Go to the Auth0 Management application you created and find the Client Secret. Copy this, it is required to communicate with the Auth0 API.
  8. Once you have the json files setup and have the Client Secret, you can run the auth0_setup script. You will need the JSON file for whichever tenant you want to setup and the CLIENT_SECRET from the previous step.
// Tested with node v14.17.5 Jan2022
npm install
node auth0_setup.js config/dev.json
Enter client secret for 'Auth0 Management' access: CLIENT_SECRET
  1. Repeat the above steps for each tenant you want for your environments.

Note: In step 3 above, if all permissions were not selected, it may be necessary to go back and add additional permissions at a later date. If you start seeing messages that include insufficient scope returned by the API, you are likely missing necessary permissions. To do this: navigate to Applications -> APIs -> Auth0 Management API. On the Auth0 Management API menu, select "Machine to Machine Applications." Click the down arrow next to the "Auth0 Management list item and check the additional required permissions.

Manual Steps

For some pieces of configuration, Auth0 does not support API based updates.

CloudWatch Logging Extension - Install and Configure

Before you start, make sure that AWS has been set up with the appropriate logging user, group and stream for Auth0 to point to. This should be done if common is up to date and run against an environment. In this case, for example, the staging environment should have:

  • a user with a name of staging-auth0-logger (as well as a generated access key id and secret access key)
  • a log group with a name of staging-auth0
  • a log stream with a name of staging-auth0

After you have that set up, keep those details handy, and, after navigating and logging into the auth0 site, switch to the relevant tenant and dashboard by clicking on your username, then the tenant name (in this case scos-staging), then the dashboard: image image image

Once you're at the dashboard, click on the Extensions button on the left navigation bar: image

Once you're in the Extensions section, click into the search bar, enter cloudwatch and click on the Logs to CloudWatch item. image

This should pop open a model where you can scroll down to enter details for the environment (once again, staging, in this case) and click on the Install button:

  • the log group staging-auth0
  • the log stream staging-auth0
  • an access key id for the staging-auth0-logger user
  • a secret access key for the staging-auth0-logger user
  • the region where the log and user were setup (in this case, us-west-2) image

Once you've completed these steps, within 5 minutes you should see logs flows to the CloudWatch log group in question.