Custom logic for slurping external datasets into Broad data repositories.
The project is built using sbt
. Once the tool is installed,
you can compile with:
$ cd ${PROJECT_ROOT}
$ sbt
# Much garbage logging, before dropping into the sbt repl
sbt:gdr-ingest> compile
You can also compile by running sbt compile
from the project root in bash, but that will eat the build tool's
startup cost on every call.
From within the sbt
repl, run:
sbt:gdr-ingest> encode-ingest/run --help
You can also run "help" for specific sub-commands to see their options, i.e.
sbt:gdr-ingest> encode-ingest/run download-metadata --help
There aren't any automated tests (yet). Manual testing has been done by comparing outputs to a test workspace in FireCloud containing a subset of all data.
First, make sure Postgres 9.6 is installed, running, and seeded with data:
$ brew install postgresql@9.6
$ echo 'export PATH="/usr/local/opt/postgresql@9.6/bin:$PATH"' >> ~/.bash_profile
$ source ~/.bash_profile
$ brew services start postgresql@9.6
$ psql postgres < encode/explorer/db/tables.sql
$ gsutil cat gs://broad-gdr-encode-transfer-tmp/snapshot.sql | psql postgres
Then, add configuration for accessing the DB to encode/explorer/src/main/resources/application.conf
. The needed
fields are:
- org.broadinstitute.gdr.encode.explorer.db.username
- org.broadinstitute.gdr.encode.explorer.db.password
Finally, from within the sbt
repl run:
sbt:gdr-ingest> encode-explorer/run
If you see ASCII art, the server is successfully running.
You can then query the API by curl
-ing localhost:
$ curl localhost:8080/api/facets
Run encode/explorer/deploy.sh
to push the API server into App Engine.
Default configuration is listed in encode/explorer/src/main/resources/reference.conf
. To tweak the defaults, you
can either modify reference.conf
or add overrides to application.conf
.