Skip to content

Latest commit

 

History

History
159 lines (109 loc) · 6.65 KB

README.md

File metadata and controls

159 lines (109 loc) · 6.65 KB

Auth0 Custom Lock

Build Status

Build tools

This project uses Gulp to run a number of automated tasks, including one that grabs our source files (HTML, Sass, JS) and compiles them into a single JS file which is deployed to a CDN and referenced by the hosted HTML page in Auth0.

This project is also meant to be built in a Docker container to ensure you have all the necessary dependencies. This is done by calling a tool named dmake. If you wish not to use the container, you can also simply call make directly.

For a list of all targets, simply type make.

When the project was built successfully, you should get a dist folder, with the generated HTML.

Building the page

For development:

./dmake build

For production:

./dmake build-prod

Deploying code

For local development:

./dmake start

This should start a local server and open it in the browser. It also starts a watch task. If you make any changes in source files (HTML, Sass or JS), the dist folder will get rebuilt.

Make sure your AWS credentials are set correctly and use the proper role when deploying to these environment.

Deploying to Auth0-Dev automatically

An AWS CodeBuild Project is deployed in the infosec-dev AWS account. This is used to build and deploy the NLX code.

The CodeBuild Project is provisioned with the codebuild-job.yml CloudFormation template. The CodeBuild Project uses an IAM Role, which gives it permissions to execute. That IAM Role is provisioned with the codebuild-role.yml CloudFormation template.

The CodeBuild Project uses an environment image of mozillaiam/auth0-custom-lock-builder. This is a docker image built from the Dockerfile. This docker image is created with the dkrbuild target of the Makefile and uploaded to Docker Hub with the hub target. This docker image has, among other things, the mozilla-iam/auth0-ci python module installed which will be used to make changes to Auth0 as well as locally cached versions of js dependencies.

The mozilla-iam/auth0-custom-lock GitHub repository has a GitHub webhook configured which will contact AWS CodeBuild each time someone does a git push to the repo. This webhook makes this contact to https://codebuild.us-west-2.amazonaws.com/webhooks

The CodeBuild Project is configured with a branchFilter of master so that, only pushes to the master branch in the git repo trigger a CodeBuild run. The branchFilter is configured manually at the moment (not in the CloudFormation template) as CloudFormation doesn't support it.

When the webhook triggers CodeBuild, CodeBuild executes the instructions in the buildspec.yml file. These buildspec.yml instructions tell CodeBuild to call the build target of the Makefile followed by the copy-to-cdn target and then the deploy target.

The build uses npm and gulp to build the NLX code.

The copy-to-cdn uploads the built artifacts to the S3 CDN bucket sso-dashboard.configuration

The deploy calls the 03-deploy-to-auth0.sh script which, using the mozilla-iam/auth0-ci python module installed in the mozillaiam/auth0-custom-lock-builder environment image, calls the uploader_login_page.py tool.

uploader_login_page.py calls the Auth0 API to update the client attributes of a special "Default Client" in Auth0. This special reserved client (a relying party) has a special attribute called custom_login_page which, when updated, updates the hosted login page which is sourced from src/html/index.html.

This HTML page references the S3 CDN URL now containing the built javascript artifacts.

Deploying to Auth0-Dev manually

For development:

./dmake deploy

Deploying to Auth0-Prod

For production:

./dmake deploy-prod

Coding standards

This project contains config files for the editor, ESLint and SCSS-Lint.

Environment variables

Throughout the project, we have some variables that are environment specific, for example the URL that Auth0 connects to. They are set in the config folder, following environment-name.json as a naming pattern. Note that these are no "shell environment variable".

We can then use them anywhere in the codebase, as index.html is ran through Mustache, which will replace the variables with the values the environment needs.

Using the variables in JavaScript

All variables are assigned to the global NLX object in main.js and are be used throughout the JavaScript as NLX.variable.

Boolean variables

Because only in strings the Mustache syntax can produce valid JavaScript, we save booleans as strings ('true' and 'false'). They can then easily be turned into booleans:

NLX.variable === 'true' // true or false

Adding a new environment variable

Add new variables in two places:

  • in any config you use, by default that is config/development.json and config/production.json
  • in index.html, all the way at the bottom of the file. We print the variable values there, so that we can merge them into one settings file with the settings Auth0 provides through @@config@@.

Maintenance banner

NLX comes with a maintenance banner that can be triggered by setting the features.maintenance_mode to "true". If you need a maintenance banner, build NLX again with that variable set to "true", or, even quicker, set the variable to "true" in the already built HTML file.

Parameters for special screens

When you call NLX with one of the following parameters, the standard interactive screen is not shown, instead you will get a special screen.

action=autologin_settings

Auto-login Settings screen. Allows user to enable or disable auto-login.

account_verification=true

This is a specific parameter that is set when the log in screen is used for account verification.