Landsat-9
Goal
Run the app-water-body.1.0.0.cwl
released application package using cwltool
on a staged Landsat-9 acquisition.
Lab
This step has a dedicated lab available at /workspace/mastering-app-package/practice-labs/Workflows/staged.ipynb
Step 1 - Configure the workspace
The results produced will be available in the local folder /workspace/mastering-app-package/runs
terminal | |
---|---|
1 2 3 4 |
|
source /workspace/mastering-app-package/scripts/setup.sh
Step 2 - Download the released Application package
scripts/download-app-water-body.sh | |
---|---|
1 2 3 4 5 |
|
sh ${WORKSPACE}/scripts/download-app-water-body.sh
Step 3 - Stage-in the Landsat-9 acquisition
The Landsat-9 acquistion "https://planetarycomputer.microsoft.com/api/stac/v1/collections/landsat-c2-l2/items/LC09_L2SP_042033_20231015_02_T1" is staged with:
1 2 3 4 5 6 7 8 |
|
sh ${WORKSPACE}/scripts/cwl-cli-stage-in-released.sh
The expected content after this step is:
(base) jovyan@coder-fbrito:~/runs$ tree
.
├── app-water-body.1.0.0.cwl
├── lwft9j0o
│ ├── LC09_L2SP_042033_20231015_02_T1
│ │ ├── LC09_L2SP_042033_20231015_02_T1.json
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ANG.txt
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_MTL.json
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_MTL.txt
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_MTL.xml
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_QA_PIXEL.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_QA_RADSAT.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B1.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B2.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B3.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B4.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B5.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B6.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B7.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_QA_AEROSOL.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_ATRAN.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_B10.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_CDIST.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_DRAD.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_EMIS.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_EMSD.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_QA.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_TRAD.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_URAD.TIF
│ │ ├── preview.png
│ │ └── tilejson.json
│ ├── catalog.json
│ └── stage.py
└── staged.json
2 directories, 30 files
The result is redirected to a file named staged.json
as we use jq
to get the path of the staged product:
cat staged.json | jq -r .staged.path
This returns a path like /workspace/mastering-app-package/runs/921x91vw
Step 4 - Execute the Application Package
Use cwltool
to run the application package using the staged Landsat-9 acquisition:
1 2 3 4 5 6 7 8 9 10 11 |
|
sh ${WORKSPACE}/scripts/exec-app-water-body.sh
Step 5 - Stage-out to S3
This step uploads the STAC Catalog to S3.
cwltool \
--podman \
${WORKSPACE}/cwl-cli/stage-out-released.cwl \
--aws_access_key_id $( cat ~/.aws/credentials | grep aws_access_key_id | cut -d "=" -f 2 ) \
--aws_secret_access_key $( cat ~/.aws/credentials | grep aws_secret_access_key | cut -d "=" -f 2 ) \
--endpoint_url $( cat ~/.aws/config | grep endpoint_url | head -n 1 | cut -d "=" -f 2 ) \
--region_name $( cat ~/.aws/config | grep region | cut -d "=" -f 2 ) \
--s3_bucket processing-results \
--sub_path processing-results/$( cat /proc/sys/kernel/random/uuid ) \
--stac_catalog /workspace/mastering-app-package/runs
sh ${WORKSPACE}/scripts/cwl-cli-stage-out-released.sh
Check the staged results on S3:
aws s3 ls $( cat staged-s3.json | jq -r .s3_catalog_output | xargs dirname )/
Expected outcome
The folder /workspace/mastering-app-package/runs
contains:
(base) jovyan@coder-mrossi:~/runs$ tree .
.
├── app-water-body.1.0.0.cwl
├── cg8n2dnu
│ ├── LC09_L2SP_042033_20231015_02_T1
│ │ ├── LC09_L2SP_042033_20231015_02_T1.json
│ │ └── otsu.tif
│ └── catalog.json
├── lwft9j0o
│ ├── LC09_L2SP_042033_20231015_02_T1
│ │ ├── LC09_L2SP_042033_20231015_02_T1.json
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ANG.txt
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_MTL.json
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_MTL.txt
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_MTL.xml
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_QA_PIXEL.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_QA_RADSAT.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B1.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B2.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B3.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B4.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B5.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B6.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_B7.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_SR_QA_AEROSOL.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_ATRAN.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_B10.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_CDIST.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_DRAD.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_EMIS.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_EMSD.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_QA.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_TRAD.TIF
│ │ ├── LC09_L2SP_042033_20231015_20231016_02_T1_ST_URAD.TIF
│ │ ├── preview.png
│ │ └── tilejson.json
│ ├── catalog.json
│ └── stage.py
└── staged.json
4 directories, 33 files
and
(base) jovyan@coder-mrossi:~/runs$ aws s3 ls $( cat staged-s3.json | jq -r .s3_catalog_output | xargs dirname )/
PRE LC09_L2SP_042033_20231015_02_T1/
2023-11-02 08:46:04 549 catalog.json