Skip to content

NASA-IMPACT/csdap-cumulus

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CSDAP Cumulus

The purpose of CSDAP Cumulus is to ingest granule data (previously obtained from vendors, such as Planet and Maxar) into the Earthdata Cloud. In conjunction with such ingestion, granule metadata (in UMM-G format) is published to the NASA CMR (Content Metadata Repository) for discovery.

Prerequisites

The following steps are required prerequisites for deploying Cumulus using this repository:

  • Install Docker Engine

    Follow the steps appropriate for your operating system to install Docker Engine.

    To simplify setup and deployment of Cumulus, this project uses a Docker container with the necessary tools already installed, including the AWS CLI (since Cumulus will be deployed to AWS) and Terraform (since Cumulus AWS resources are deployed via Terraform).

  • Populate Environment Variables

    Copy the file named .env.example (at the root of this project) to a file named .env (also placing it at the root of this project).

    Using a text editor, set values within your .env file according to the instructions provided within the file. These environment variables will be used within the Docker container to properly configure the AWS CLI and Terraform.

If you also wish to contribute changes, you should also do the following:

  • Install pre-commit

    If you don't already have pre-commit installed on your development machine, please install pre-commit.

  • Install the pre-commit hooks

    Once pre-commit is installed, install the pre-commit hooks defined in the .pre-commit-config.yaml file by running the following command:

    pre-commit install --install-hooks
    

    This will cause the configured hooks to run whenever you run git commit. If any hooks fail, the commit is aborted, requiring you to fix the problem(s) that caused the hook(s) to fail. Often, hooks automatically fix problems (such as file formatting), and thus you may simply need to git add the automatically fixed files and run git commit again.

    Further, you can run pre-commit hooks without running git commit if you wish to, which can be handy when you want to perform actions such as file formatting prior to adding files to git:

    pre-commit run -a
    

Infrastructure Management

This section assumes that you have completed all prerequisite steps as detailed above.

Cumulus uses Terraform to manage AWS infrastructure. However, because using Terraform directly is somewhat cumbersome, we leverage Terraspace to make use of Terraform a bit easier. In addition, we use Docker to simplify local development and deployment.

Docker for Development

To avoid having to install Terraform, Terraspace, and other tools locally, we use a Docker container to package all of our tooling requirements. Further, make is used for easily running docker run commands on your behalf and also ensuring that the Docker image is built prior to running any docker run commands.

Therefore, there should be no need to directly build the Docker image, but to do so, you can run the following command, but this should generally be unnecessary:

make docker

Further, if you need to open a bash shell in a Docker container using the image, you can use the following command:

make bash

To see all of the available targets in Makefile, run make without any arguments:

make

This will output a list of targets with short descriptions.

Initial Cumulus Deployment

Prior to your first deployment of Cumulus, you must perform some setup. Run the following command to set things up, which will take a bit of time (perhaps 10-15 minutes):

make pre-deploy-setup

Once the setup is complete, deploy all of the Terraform modules with the following command, which will deploy the modules in the correct order of their dependencies:

make all-up-yes

The first time you run the make all-up-yes command, you will be prompted to supply values for a number of secrets, which will be stored as AWS SSM Parameters of type SecureString.

If you are unsure of what value to supply for a prompt, consult a team member who has already deployed Cumulus from this repository. If you cannot immediately obtain an appropriate value for a prompt, you may simply supply an empty value (i.e., simply press Enter/Return). This will allow you to continue with deployment, and add the secret value at a later point. The next time you deploy Cumulus, you will be reprompted for any values that you have not yet supplied.

Initial deployment will take roughly 2 hours in total, but close to the end of the process, the deployment might fail with several error messages of the following form:

Error: error creating Lambda Function (1): InvalidParameterValueException: The provided execution role does not have permissions to call CreateNetworkInterface on EC2
{
   RespMetadata: {
      StatusCode: 400,
      RequestID: "2215b3d5-9df6-4b27-8b3b-57d76a64a4cc"
   },
   Message_: "The provided execution role does not have permissions to call CreateNetworkInterface on EC2",
   Type: "User"
}

If this occurs, simply run the previous command again, as this typically arises from a race condition where one resource depends upon another resource that is not yet fully ready. Typically, by the time you rerun the command, the required resource is ready. See Deploying Cumulus Troubleshooting for more information.

Secondary Cumulus Deployment

After your initial, successful deployment, one of the listed deployment outputs will be cumulus_distribution_api_uri. To locate this output value, run the following command:

make output-cumulus

You should see the output similar to the following:

$ make output-cumulus
Building .terraspace-cache/us-west-2/${TS_ENV}/stacks/cumulus
Current directory: .terraspace-cache/us-west-2/${TS_ENV}/stacks/cumulus
=> terraform output
archive_api_redirect_uri = https://***.execute-api.us-west-2.amazonaws.com:8000/dev/token
archive_api_uri = https://***.execute-api.us-west-2.amazonaws.com:8000/dev/
cumulus_distribution_api_redirect_uri = https://***.execute-api.us-west-2.amazonaws.com/dev/login
cumulus_distribution_api_uri = https://***.execute-api.us-west-2.amazonaws.com/dev/
report_executions_sns_topic_arn = arn:aws:sns:us-west-2:***:cumulus-${TS_ENV}-report-executions-topic
report_granules_sns_topic_arn = arn:aws:sns:us-west-2:***:cumulus-${TS_ENV}-report-granules-topic
report_pdrs_sns_topic_arn = arn:aws:sns:us-west-2:***:cumulus-${TS_ENV}-report-pdrs-topic
stepfunction_event_reporter_queue_url = https://sqs.us-west-2.amazonaws.com/***/cumulus-${TS_ENV}-sfEventSqsToDbRecordsInputQueue

Add (or uncomment) the following line to your .env file (which should already be commented out at the bottom of the file, if you originally copied your .env file from .env.example):

TF_VAR_cumulus_distribution_url=

Set the value of this variable to the value of the cumulus_distribution_api_uri output given in the output from the command above.

Then, to apply the value, redploy the cumulus module, as follows:

make up-cumulus-yes

Cumulus Smoke Test

Finally, populate your development deployment with some data that will allow you to perform a small smoke test to verify that your deployment is operating properly:

make create-test-data

To run a smoke test, follow the instructions output by the command above.

Destroying a Deployment

See Destroying a Deployment in Operating CSDAP Cumulus.