Skip to content

Latest commit

 

History

History
131 lines (80 loc) · 5.03 KB

README.md

File metadata and controls

131 lines (80 loc) · 5.03 KB

Overview

Infrastructure to support the iAtlas project

Architecture

alt text

These resources are created by sceptre:

  • config/common includes the vpc and network attachments for the project. Also launches the GitLab runner instance.

  • config/staging launches an aurora postgresql resource, kms key, and the api app for the staging environment.

  • config/prod launches an aurora postgresql resource, kms key, and the api app for the production environment.

TODO

Setup

Environment Variables

The config.yaml picks up a number of environment variables. All have defaults to ensure the build runs with meaningful error messages. Some of the environment variables MUSt be set.

Manual Deploys

The following MUST be created initially:

  • staging/iatlas-runner.yaml

    The staging GitLab runner is used for general and staging environment builds in GitLab. Creating it will also create:

    • common/iatlasvpc.yaml
    • common/maintenance.yaml
    • staging/iatlas-kms.yaml
    • staging/iatlas-api-db.yaml
    • staging/iatlas-runner-s3-bucket.yaml
    • staging/iatlas-runner-roles.yaml

    The database instance is needed so that the host values may be passed to the GitLab Runner. The host is a subnet and not available outside the VPC.

    The KMS stack is needed for the Database.

    The VPC is needed for the Runner and the Database.

  • prod/iatlas-runner.yaml

    The prod GitLab runner is used for prod environment builds only. Creating it will also create:

    • common/iatlasvpc.yaml

    • common/maintenance.yaml

      (these should already be created by the staging stack above)

    • prod/iatlas-kms.yaml

    • prod/iatlas-api-db.yaml

    • prod/iatlas-runner-s3-bucket.yaml

    • prod/iatlas-runner-roles.yaml

    The database instance is needed so that the host values may be passed to the GitLab Runner. The host is a subnet and not available outside the VPC.

    The KMS stack is needed for the Database.

    The VPC is needed for the Runner and the Database.

  • staging/iatlas-api-hostedzone.yaml

  • prod/iatlas-api-hostedzone.yaml

    Once the HostedZones are created for Staging and Production, NS records may be created in the domain registrar with values from the respective HostedZones.

    ie - If the domain staging.example.com is to be used for the Staging API, create an NS record for the staging subdomain in the domain registrar for each of the nameservers created in the HostedZone for that domain - route53.

Contributing

  • Install pre-commit app
  • Clone this repo
  • Run pre-commit install to install the git hook

Test Deployment

Install aws cli

Create credentials file in your local user folder. The file should be called credentials located in ~/.aws.

The contents should look like:

[iAtlas]
aws_access_key_id = {ACCESS_KEY}
aws_secret_access_key = {SECRET_ACCESS_KEY}
aws_session_token = {SESSION_TOKEN}
region = us-east-1

Create config file in your local user folder. The file should be called config located in ~/.aws.

The contents should look like:

[default]
region = us-east-1

Install Python

See https://packaging.python.org/guides/installing-using-pip-and-virtual-environments/ for information on installing Python packages for a specific project.