Deploying a Webapp
GitHub Repository
The code for your Application needs to live in a GitHub repository within the Ministry of Justice organisation.
If you don’t already have a repository, create one from the Data Platfrom App Template following the steps below. By using the template you will be set up with GitHub Actions files that will deploy a dev
and prod
environment of your application.
If you already have a repository you will need to copy these files manually.
Overview of steps
- Setup your repository
- Update the repository teams
- Check your environments
- Next steps
Create a Repository from the Template
- Visit https://github.com/ministryofjustice/data-platform-app-template in your browser
- Click the “Use this template” button in the top right corner
- On the “Create a new repository” form, ensure the
ministryofjustice/data-platform-app-template
template is selected - Enter a repository name of your choosing make sure to use hypens and not underscores. NOTE: the name of the repository will later be used to create your Cloud Platform namespace, and will be used in the URL to access your deployed app.
- Select “Internal” so that only members of the
ministryofjustice
organisation can see your repository - Click the “Create repository” button and wait for your repository to be created
Using an Existing Repository
If you already have a repository and do not wish to create a new one with the ministryofjustice/data-platform-app-template
you will need to manually copy the contents of the .github/workflows
directory into your existing repository. These files are required to deploy the application.
You will need to create a pull request adding the files and merge to your main
branch. The CI will fail at this point, but merging will ensure that the dev
and prod
repository environments are created.
Click here for further information about deployments.
Update Repository Teams
The analytics-hq
team must be added as a repository admin. This change is required or your application will later fail to deploy. Follow these steps:
- From the main page of your repo, click the “Settings” tab on the nav bar underneath your repo name
- Under the “Access” subheading, click “Collaborators and teams” from the left-hand menu
- Click the “Add teams” button
- Search for
ministryofjustice/analytics-hq
, choose “Admin” access and submit the form - Repeat this process for any other GitHub teams that need access
Environments
By default, your repository is configured to deploy a dev
and prod
environments. These will be used to store environment variables and secrets used in the deployment workflows.
The environments are created on the initial run of the .github/workflows/build-push-deploy-dev.yml
and .github/workflows/build-push-deploy-prod.yml
workflows. The dev
workflow is set to run when a PR is created. The prod
workflow will run when changes are published to the main
branch.
Check your environments in your repository settings:
- From the main page of your repo, click the “Settings” tab on the nav bar underneath your repo name
- Under the “Code and automation” subheading, click “Environments” from the left-hand menu
- If the
dev
orprod
environments are missing, create them using the “New Environment” button - There are no further changes required (i.e. you do not need to add any variables or secrets), but you can configure settings such as “Deployment protection rules” as required by your team
If you do not require one of the environments, you should delete it before proceeding to register your application with Control Panel and creating your Cloud Platform namespace.
Follow these steps to delete an environment:
1. Delete the relevant GitHub action workflow file for dev
or prod
from your repository
2. Then go to the “Environments” settings in your GitHub repository (steps above) and delete the appropriate environment
Next steps
Once you have your repository, you can clone it to your local machine and start writing your application, or copy existing code to push to the repository.
You will need to create a Dockerfile
that builds and runs your application. You can define this yourself entirely, however we recommend you use the open-source Shiny Server image managed by the Analytical Platform. Click here to see further documentation about this, including an example Dockerfile. The webapp_examples repo may contain applications built using other languages and frameworks too.
Note: The healthcheck and other endpoints are sent to port 9999 your application will need this set to work.
When ready to deploy, you can move on to:
- Create Cloud Platform namespace(s) for your environments
- Register the application within Control Panel
Cloud Platform Environments
Repeat the following process for each of the environments (dev
, prod
) that you require.
You can follow the instructions for each step individually, with a pull request for each, or complete all steps and include all the files in a single pull request.
NOTE: Wait for CI checks to pass before requesting a review on your pull requests. Request a review by sending a message including a link to your PR in the
#ask-cloud-platform
slack channel.
Overview
- Create a Namespace
- Create a ECR repository
- Create a Service Account
Creating a Namespace
Note: It is important you create the namespace with the correct name to begin with. Changing the namespace afterwards will likely cause breaking changes on deployment.
Follow the “Creating a Cloud Platform environment” instructions to create your namespace. Your namespace must meet the Ministry of Justice’s guidance on naming things.
In addition, you will need to update the generated 01-rbac.yaml
file in your namespace directory to add the analytics-hq
team. Open the file, and under the subjects
section, add the following below the existing entry:
- kind: Group
name: "github:analytics-hq"
apiGroup: rbac.authorization.k8s.io
Create a Container Repository
Note: It is important you create the ecr.tf correctly to begin with. Changing the anything afterwards will likely cause breaking changes on deployment, and you may need to remove the variables and secrets from your code repository.
Follow the instructions in the Cloud Platform user guidance to add a container repository.
IMPORTANT: Amend the created
ecr.tf
file to add the following settings.
github_repositories
should include the name of your repository e.g. `github_repositories = [“] github_environments
should include the name of the environment you are setting up e.g.github_environments = ["dev"]
github_actions_prefix
is set to the environment you are setting up e.g.github_actions_prefix = "dev"
You can find further details about these settings in the Cloud Platform documentation.
Create a Service Account
Follow the instructions in the Cloud Platform user guidance to create a service account. You will need to amend the generated resources/serviceaccount.tf
file:
- Uncomment the
github_repositories
setting and check the repository name is correct. - On a new line, add
github_environments = ["<env>"]
where<env>
isdev
orprod
, depending on which environment you are setting up - On a new line, copy and paste the following variable in its entirety:
serviceaccount_rules = [
{
api_groups = [""]
resources = [
"pods/portforward",
"deployment",
"secrets",
"services",
"pods",
"serviceaccounts",
"configmaps",
"persistentvolumeclaims",
]
verbs = [
"update",
"patch",
"get",
"create",
"delete",
"list",
"watch",
]
},
{
api_groups = [
"extensions",
"apps",
"batch",
"networking.k8s.io",
"rbac.authorization.k8s.io",
"policy",
]
resources = [
"deployments",
"ingresses",
"cronjobs",
"jobs",
"replicasets",
"statefulsets",
"networkpolicies",
"servicemonitors",
"roles",
"rolebindings",
"poddisruptionbudgets",
]
verbs = [
"get",
"update",
"delete",
"create",
"patch",
"list",
"watch",
]
},
{
api_groups = [
"monitoring.coreos.com",
]
resources = [
"prometheusrules",
]
verbs = [
"*",
]
},
]
Further details about these settings can be found in the Cloud Platform documentation.
Reference
You can see a full example of a namespace directory used to host an Analytical Platform application here, with all the above amends made. There are also many other data-platform-app-
namespaces within the cloud platform environments repo, although as these are managed by the app owners, there may be some custom changes. For a list of deployed applications you may also view the webapp_examples repo.
Register the Application in Control Panel
IMPORTANT: You will need to have setup your GitHub repository to complete ths step
- Login to the Control Panel
- Click the “Webapps” link in the main navigation, and click the “Register app” button at the bottom of the page
- Enter the full URL of your GitHub repository
- Enter your Cloud Platform namespace, without any env suffix
- Choose to create a new webapp data source (S3 bucket), connect an existing data source, or choose to do this later. > NOTE: > If you choose “Do this later” you will be able to create a Webapp data source by clicking the “Webapp data” button in the main navigation after registering your app. You will then need to come back to the “Manage app” page to link it to your Application.
Manage the Application
After registering the Application, you will be redirected to the “Manage app” page where you will find details about your app and can update deployment settings.
IMPORTANT: Any settings changes made via the “Manage app” page in Control Panel require the application to be redeployed before coming into effect
You will need to create an Auth0 client to handle authentication for each environment that you setup.
- For each environment, click the “Create auth0 client” button underneath the deployment settings. This will:
- Create an Auth0 client and user group for specific to the Application environment
- Store the
AUTH0_CLIENT_ID
andAUTH0_CLIENT_SECRET
as environment secrets in your GitHub repository
- By default authentication is enabled, with passwordless login by email via Auth0. You can now use the “Manage customers” button from the previous screen to add users for your Application. See the section below for more details..
The AUTH0_CLIENT_ID
and AUTH0_CLIENT_SECRET
that have been added will be used the next time you deploy your Application. In order to deploy a new version of the Application, you will need to create a pull request in your repository. The GitHub actions jobs will redeploy the dev environment when the PR is opened. The prod environment is deployed when the PR has been merged.
Click here for further information about deployments.
Accessing the Application
URLs for respective environments are as follows:
- Development:
<repository-name>-dev.apps.live.cloud-platform.service.justice.gov.uk
. - Production:
<repository-name>.apps.live.cloud-platform.service.justice.gov.uk
.
NOTE: The environment is not explicitly stated in the production URL.
Example URLs
For an example project with a repo called “example-webapp”, the respective deployment URLs would be:
- Development: https://example-webapp-dev.apps.live.cloud-platform.service.justice.gov.uk
- Production: https://example-webapp.apps.live.cloud-platform.service.justice.gov.uk
Note that characters that are not compatible with website URLs are converted. Therefore repositories with underscores in their name (e.g. repository_name.apps...
) will be converted to dashes for the URL (e.g. repository-name.apps...
).