Disclaimer: work in progress.
The Transcriptomics Data Service (TDS) is intended to ingest, organize and query data from transcriptomics experiments through an API.
Start the TDS server with a local PostgreSQL database for testing by running the following command.
# start
docker compose up --build -d
# stop
docker compose down
The --build
argument forces the image to be rebuilt. Be sure to use it if you want code changes to be present.
You can now interact with the API by querying localhost:5000/{endpoint}
For the OpenAPI browser interface, go to localhost:5000/docs
.
For local development, you can use the docker-compose.dev.yaml file to start a TDS
development container that mounts the local directory.
The server starts in reload mode to quickly reflect local changes, and debugpy is listening on the container's internal port 9511
.
# Set UID for directory permissions in the container
export UID=$(id -u)
# start
docker compose -f ./docker-compose.dev.yaml up --build -d
# stop
docker compose -f ./docker-compose.dev.yaml down
You can then attach VS Code to the tds
container, and use the preconfigured Python Debugger (TDS)
for interactive debugging.
The TDS Config
object has its values populated from environment variables and secrets at startup.
The Config.db_password
value is populated by either:
DB_PASSWORD=<a secure password>
if using an environment variable- As seen in docker-compose.dev.yaml
DB_PASSWORD_FILE=/run/secrets/db_password
if using a Docker secret (recommended)- As seen in docker-compose.secrets.dev.yaml
Using a Docker secret is recommended for security, as environment variables are more prone to be leaked.
DB_PASSWORD
should only be considered for local development, or if the database is secured and isolated from public access in a private network.
The Transcriptomics Data Service is meant to be a reusable microservice that can be integrated in existing stacks. Since authorization schemes vary across projects, TDS allows adopters to code their own authorization plugin, enabling adopters to leverage their existing access control code, tools and policies.
See the authorization docs for more information on how to create and use the authz plugin with TDS.
TODO: replace this with Swagger UI docs generated from CI workflows.
/service-info
- GA4GH service info
/ingest
/normalize
/expressions
/experiment
/search
(WIP)
The Transcriptomics Data Service is packaged and released as a Docker image using GitHub Actions.
Images are published in GitHub's container registry, here.
Images are built and published using the following tags:
<version>
: Build for a tagged releaselatest
: Build for the latest tagged releaseedge
: The top of themain
branchpr-<number>
: Build for a pull request that targetsmain
Note: Images with the -dev
suffix (e.g. edge-dev
) are for local development.
To pull an image, or reference it in a compose file, use this pattern:
docker pull ghcr.io/bento-platform/transcriptomics_data_service:<TAG>