Skip to content

Latest commit

 

History

History
85 lines (70 loc) · 2.46 KB

README.md

File metadata and controls

85 lines (70 loc) · 2.46 KB

Field Campaign Explorer Backend

This repository contains scripts to deploy FCX backend infrastructure to AWS Cloud.

Currently, this is work-in-progress and scripts are hardcoded to process files for GOES-R PLT Field Campaign. In future, these scripts will be refactored to make them modular and follow proper coding convention.

Following dataset processing scripts are available. More information about these datasets can be found at https://ghrc.nsstc.nasa.gov/uso/ds_details/collections/goesrpltC.html

  • ABI
  • CRS
  • FEGS
  • GLM
  • ISS LIS
  • LIP
  • LMA
  • NEXRAD
  • CPL
  • HIWRAP
  • NPOL
  • DROPSONDE

Local Run

  • Create a sws credentials or export the following as the environment variables
    • AWS_REGION
    • AWS_ACCESS_KEY_ID
    • AWS_SECRET_ACCESS_KEY
  • Each python script for every instruments of various campaigns are directly executable.
  • Some campaign instrument also has a interactive python notebook to quickly check and test the validity of conversion before applying to all available datasets.

Deployment

  • Create a new EC2 instance or use an existing EC2 instance

  • Create a file called env.sh and export following values

    • AWS_REGION
    • AWS_ACCESS_KEY_ID
    • AWS_SECRET_ACCESS_KEY
    • AWS_SESSION_TOKEN
    • RAW_DATA_BUCKET
    • OUTPUT_DATA_BUCKET
    • OUTPUT_DATA_BUCKET_KEY
    • ZAPPA_ROLE_ARN
    • SUBNET_ID
    • SECURITY_GROUP_ID

    environmental variables

  • Create a role to execute Zappa as shown below with permission boundary set to NGAPShRoleBoundary. Then create NASD ticket to request adding following trust relationship environmental variables

{
   "Version":"2012-10-17",
   "Statement":[
      {
         "Sid":"",
         "Effect":"Allow",
         "Principal":{
            "Service":[
               "apigateway.amazonaws.com",
               "events.amazonaws.com",
               "lambda.amazonaws.com"
            ]
         },
         "Action":"sts:AssumeRole"
      }
   ]
}
  • Add CORS rules to the bucket where processed data is stored
<?xml version="1.0" encoding="UTF-8"?>
<CORSConfiguration xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
<CORSRule>
<AllowedOrigin>*</AllowedOrigin>
<AllowedMethod>GET</AllowedMethod>
</CORSRule>
</CORSConfiguration>
  • Run deploy.sh
  • Processed data will be uploaded into specified S3 bucket. Enter this information in FCX Frontend configuration file.