Database for OpenCloning, a web application to generate molecular cloning strategies in json format, and share them with others.
Project description
opencloning-db
opencloning-db is the database/API companion package for the OpenCloning backend. It provides the app and local data workflows used for OpenCloning database features.
Run locally
From the repository root:
# Install or update workspace dependencies
uv sync
# If you are using mac, you may have to stop any local Postgres instances running on port 5432
brew services stop postgresql
# Start local Postgres with dev/test/e2e databases plus Garage for object storage
docker compose \
-f docker/docker-compose.postgres.yml \
-f docker/docker-compose.garage.yml \
up -d postgres garage
# Load required local runtime config
source .env.dev
# Create the schema safely
uv run opencloning-cli db init
# Optional: load the deterministic demo/test baseline
OPENCLONING_TESTING=1 uv run opencloning-cli db seed
# Run both the cloning and the database API - this what the OpenCloningDB frontend expects
uv run uvicorn opencloning_db.combined:app --reload --reload-exclude='.venv'
# Run the opencloning-db API (only database, not cloning. This is not used when running with the frontend)
uv run uvicorn opencloning_db.api:app --reload --reload-exclude='.venv'
That will serve the cloning API at http://127.0.0.1:8000/cloning and the database API at http://127.0.0.1:8001/db. That's what the OpenCloningDB frontend expects.
When the cloning app is served through opencloning_db.combined, the entire /cloning mount is protected by the same bearer-token authentication used by the db API.
Running tests locally
From the repository root:
# Install or update workspace dependencies
uv sync
# Run the tests
uv run pytest packages/opencloning-db/tests -v -ks
Frontend testing
Frontend testing using the database requires reseeding after tests that modify the database. You can do this by calling the /__test/reset-db endpoint with the X-Test-Reset-Token header set to RESET-TOKEN. That endpoint is only available if the OPENCLONING_TESTING environment variable is set to 1, and it delegates to the guarded opencloning-cli db seed command.
Building and running the Docker image
The Dockerfile is shared with the cloning app, and the build arg APP_TARGET determines which app to build. So you can build the image by running:
docker build -f docker/opencloning.Dockerfile --build-arg APP_TARGET=db -t manulera/opencloning-db-backend .
Then run it for development:
# Run the containers (Postgres + Garage + db API)
docker compose \
-f docker/docker-compose.postgres.yml \
-f docker/docker-compose.garage.yml \
-f docker/docker-compose.opencloning-db.yml \
up -d
That stack exposes Garage's S3-compatible API at http://127.0.0.1:9000. Garage does not provide a MinIO-style browser console in this setup, so use an S3 client such as awscli or mc if you need to inspect the local bucket. The local defaults in .env.dev point host-side uv run ... commands at the same Garage bucket used by the containerized db API.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file opencloning_db-1.6.0.tar.gz.
File metadata
- Download URL: opencloning_db-1.6.0.tar.gz
- Upload date:
- Size: 242.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a3515e35440ece91ace71d4fb8f3ae11da73e31e9d1d862b0619d5d8edfa5b8a
|
|
| MD5 |
c429d76c00fa7f7c56a540ebce477609
|
|
| BLAKE2b-256 |
54d857e18ea7104fa0e77db2aced7b6b9377aa3fd530d4122c474539f5221f18
|
Provenance
The following attestation bundles were made for opencloning_db-1.6.0.tar.gz:
Publisher:
release-please.yml on OpenCloning/OpenCloning_backend
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
opencloning_db-1.6.0.tar.gz -
Subject digest:
a3515e35440ece91ace71d4fb8f3ae11da73e31e9d1d862b0619d5d8edfa5b8a - Sigstore transparency entry: 1601970519
- Sigstore integration time:
-
Permalink:
OpenCloning/OpenCloning_backend@73d1e42bb73ee25868560827b02423bc4a11f93c -
Branch / Tag:
refs/heads/master - Owner: https://github.com/OpenCloning
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-please.yml@73d1e42bb73ee25868560827b02423bc4a11f93c -
Trigger Event:
push
-
Statement type:
File details
Details for the file opencloning_db-1.6.0-py3-none-any.whl.
File metadata
- Download URL: opencloning_db-1.6.0-py3-none-any.whl
- Upload date:
- Size: 227.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0f77733df66500391e780817ce24f85c7d5523da4869d8c140f6efeb942a42a7
|
|
| MD5 |
1c58c53de6a6f172b2558924b7b98c97
|
|
| BLAKE2b-256 |
79cadee9d95a8c2eae0e613d0b4c7cd208133f02b5f1c79b9f25d191288d3e08
|
Provenance
The following attestation bundles were made for opencloning_db-1.6.0-py3-none-any.whl:
Publisher:
release-please.yml on OpenCloning/OpenCloning_backend
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
opencloning_db-1.6.0-py3-none-any.whl -
Subject digest:
0f77733df66500391e780817ce24f85c7d5523da4869d8c140f6efeb942a42a7 - Sigstore transparency entry: 1601970538
- Sigstore integration time:
-
Permalink:
OpenCloning/OpenCloning_backend@73d1e42bb73ee25868560827b02423bc4a11f93c -
Branch / Tag:
refs/heads/master - Owner: https://github.com/OpenCloning
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-please.yml@73d1e42bb73ee25868560827b02423bc4a11f93c -
Trigger Event:
push
-
Statement type: