The steps to set up TT and RS locally are in setup locally section in the main README.md . Follow the instructions below to load the environments variables required for these scripts. ReportStream and Trusted Intermediary must be running locally before running any scripts.
- Copy
.env.template
to.env
cp .env.template .env
- Edit
.env
and make sure to update at least:CDCTI_HOME
: local path to thetrusted-intermediary
codebaseRS_HOME
: local path to theprime-reportstream
codebase- Note: if you don't set
CDCTI_HOME
, none of these scripts will work. Also, please use$HOME
or the full path to your home directory instead of~
- Export the environment variables in
.env
by runningNote: you may also want to add it to your shell's startup file so you don't need to run it for every terminal session.set -a; source .env; set +a
- Run your script
Sends a HL7 message to RS and tracks its status throughout the flow until final delivery. When running locally, it grabs the snapshots of the file in azurite after converting to FHIR, after applying transformations in TI, and after converting back to HL7; and it copies those files to the same folder where the submitted file is. If running in a deployed environment we currently don't have a way to download the files from Azure, but the script will print the relative path for the files in the blob storage container.
- hurl
- jq
- azure-cli
Usage: ./submit.sh -f <message_file.hl7> [-e <environment>]
Options:
-f <FILE> Message file path (Required)
-e <ENVIRONMENT> Environment: local|staging|production (Default: local)
-x <RS_SENDER_PRIVATE_KEY> Path to the sender private key for authentication with RS API (Required for non-local environments)
-z <TI_SENDER_PRIVATE_KEY> Path to the sender private key for authentication with TI API (Optional for all environments)
-h Display this help and exit
Submit requests to RS API endpoints
- hurl
- jwt-cli
Usage: ./rs.sh <ENDPOINT_NAME> [OPTIONS]
ENDPOINT_NAME:
The name of the endpoint to call (required)
Options:
-e <ENVIRONMENT> Environment: local|staging (Default: local)
-f <REL_PATH> Path to the message file to submit (Required for submission endpoints)
-r <ROOT_PATH> Root path to the message files (Default: /Users/bbogado/Code/Flexion/CDC-TI/trusted-intermediary/examples/)
-t <CONTENT_TYPE> Content type for the message file (Default: application/hl7-v2)
-k <KEY_PATH> Path to the sender private key (Required for non-local environments)
-s <SENDER> Sender ID used for authentication (Default: flexion.simulated-sender)
-u <URL> URL root for the API endpoint (Default: auto-detected)
-i <SUBMISSION_ID> Submission ID (Required for query endpoints)
-v Verbose mode
-h Display this help and exit
Sending an order to local environment
./rs.sh waters -f Test/Orders/003_AL_ORM_O01_NBS_Fully_Populated_0_initial_message.hl7
Sending a result to local environment
./rs.sh waters -f Test/Results/002_AL_ORU_R01_NBS_Fully_Populated_0_initial_message.hl7
Sending an order to staging
./rs.sh waters -f Test/Orders/003_AL_ORM_O01_NBS_Fully_Populated_0_initial_message.hl7 -e staging -k /path/to/sender/staging/private/key
Checking the history in local environment for a submission id
./rs.sh history -i 100
Checking the history in staging for a submission id
./rs.sh history -i 100 -e staging -k /path/to/sender/staging/private/key
Submit requests to TI API endpoints
- hurl
- jwt-cli
Usage: ./ti.sh <ENDPOINT_NAME> [OPTIONS]
ENDPOINT_NAME:
The name of the endpoint to call (required)
Options:
-e <ENVIRONMENT> Environment: local|staging (Default: local)
-f <REL_PATH> Path to the message file to submit (Required for submission endpoints)
-r <ROOT_PATH> Root path to the message files (Default: /Users/bbogado/Code/Flexion/CDC-TI/trusted-intermediary/examples/)
-t <CONTENT_TYPE> Content type for the message file (Default: application/fhir+ndjson)
-k <KEY_PATH> Path to the sender private key (Required for non-local environments)
-s <SENDER> Sender ID used for authentication (Default: report-stream)
-u <URL> URL root for the API endpoint (Default: auto-detected)
-i <SUBMISSION_ID> Submission ID (Required for query endpoints)
-v Verbose mode
-h Display this help and exit
Submit an order to local environment:
./ti.sh orders -f Test/Orders/003_AL_ORM_O01_NBS_Fully_Populated_1_hl7_translation.fhir -i 100
Submit an order to staging:
./ti.sh orders -f Test/Orders/003_AL_ORM_O01_NBS_Fully_Populated_0_initial_message.hl7 -e staging -k /path/to/sender/staging/private/key
Submit a result to local environment:
./ti.sh results -f Test/Results/002_AL_ORU_R01_NBS_Fully_Populated_1_hl7_translation.fhir -i 100
Get metadata from local environment:
./ti.sh metadata -i 100
Authenticate to local environment:
./ti.sh auth
Get OpenAPI docs from local environment:
./ti.sh openapi
Get Health info from local environment:
./ti.sh health
Submit requests to UCSD API endpoints
- hurl
- Add the
sender
id toucsd.sh
- Update the
secret
variable path
./ucsd.sh results -k /path/to/ucsd-ucsd-private-key.pem -s sender_name
Sends all the HL7 files with _0_initial_message.hl7
suffix in the /examples
folder to a locally running RS instance. As the submit.sh
script, it downloads the snapshots at each stage. This script is helpful to keep all the message snapshots in the examples folder up to date
- hurl
- jq
- azure-cli
./update-examples-snapshots.sh
Setup script for ReportStream.
- yq
./setup-reportstream.sh
Utility functions shared by scripts
Functions to submit requests to RS, check the submission status throughout the whole flow, and downloading snapshots from azurite