Skip to main content

Deploy Rust workers, static frontends, and worker-static services to Tovuk.

Project description

tovuk

Python CLI package for deploying Rust workers, static frontends, and worker-static services to Tovuk. It installs or downloads the same native Tovuk binary used by npm, Homebrew, and Cargo. PyPI requires Python to install and launch the package, but it does not require Node.js, npm, npx, or tsx.

pipx install tovuk
tovuk init hello-service --template worker-static-rust-tanstack
cd hello-service/web && bun install && cd ..
tovuk doctor --json
tovuk preview
tovuk deploy --wait --json

From a worker-static repo root, tovuk deploy reads one root tovuk.toml, builds the worker and frontend roots, and returns one service URL with /api/* routed to the Rust worker.

Rust worker deploys require cargo fmt --all --check, locked release-mode cargo check, locked release-mode tests, and strict all-target, all-feature Clippy with panic/unwrap bans plus resource-sensitive lints.

Static frontend deploys require TypeScript browser source, stable native type-aware TypeScript checks, native linting such as oxlint, biome check, or deno lint, and Fallow dead-code, semantic duplicate-code, and health gates.

The npm package is also available:

npx tovuk deploy

The Python package exposes the same agent command surface as npm:

tovuk capabilities
tovuk me
tovuk usage
tovuk activity --json
tovuk service list
tovuk service show service_1 --json
tovuk deploys --service service_1
tovuk builds
tovuk logs --deploy deploy_1 --limit 100 --json
tovuk env list --service service_1
tovuk env set --service service_1 API_KEY=value
tovuk env delete --service service_1 API_KEY
tovuk domains add --service service_1 api.example.com
tovuk domains verify --service service_1 api.example.com
tovuk storage list --service service_1 --json
tovuk storage upload --service service_1 ./logo.png uploads/logo.png --public --json
tovuk storage download --service service_1 uploads/logo.png ./logo.png --json
tovuk storage delete --service service_1 uploads/logo.png --json
tovuk platform --service service_1 --json
tovuk database create --service service_1 DB --json
tovuk kv create --service service_1 CACHE --json
tovuk kv put --service service_1 CACHE user:1 '{"name":"Ada"}' --json
tovuk kv get --service service_1 CACHE user:1 --json
tovuk queue create --service service_1 jobs --json
tovuk queue send --service service_1 jobs '{"task":"sync"}' --json
tovuk cron create --service service_1 nightly "0 0 * * *" --json
tovuk durable-object create --service service_1 Room --json
tovuk binding create --service service_1 AUTH_SERVICE --target auth-service --json
tovuk limit set worker_requests --period day --value 100000 --json
tovuk billing checkout --json
tovuk billing portal
tovuk support create "Deploy failed" "Agent retried deploy after doctor." --service service_1 --build job_1 --deploy deploy_1 --failing-command "tovuk deploy --wait --json" --first-log-line "cargo check failed in src/main.rs" --json
tovuk support list --json
tovuk support resolve ticket_0123456789abcdef0123 --json

Agent repair loop:

tovuk doctor --json
tovuk deploy --wait --json
tovuk logs --build job_1 --json

Fix the first failed agent_instruction. If a build fails, inspect build logs, fix the first actionable log error, rerun doctor, then redeploy.

On first deploy, the CLI opens browser login, waits for GitHub or Google, stores the Tovuk session in the OS credential store when available, and continues the deploy. Later commands reuse that session.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tovuk-0.1.63.tar.gz (4.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tovuk-0.1.63-py3-none-any.whl (4.7 kB view details)

Uploaded Python 3

File details

Details for the file tovuk-0.1.63.tar.gz.

File metadata

  • Download URL: tovuk-0.1.63.tar.gz
  • Upload date:
  • Size: 4.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tovuk-0.1.63.tar.gz
Algorithm Hash digest
SHA256 f612a59fd59304cf3b605792b11c176c0665afc1f5ae2a35ee04e23a8635f2b2
MD5 4f76f2c20a89db265ade94f56b6a54d1
BLAKE2b-256 9ad0e7745b6b9635b381aa576f348d83d65461f9c4aa82889cc6d2873247741a

See more details on using hashes here.

Provenance

The following attestation bundles were made for tovuk-0.1.63.tar.gz:

Publisher: publish-pypi.yml on tovuk/tovuk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tovuk-0.1.63-py3-none-any.whl.

File metadata

  • Download URL: tovuk-0.1.63-py3-none-any.whl
  • Upload date:
  • Size: 4.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tovuk-0.1.63-py3-none-any.whl
Algorithm Hash digest
SHA256 d3dbd466fc618e4a6e30128d18d01c8bf4af21a1783af43ee075bc93e5bf8d5c
MD5 7f3c9a014c1ffe1ff38e848e27557a65
BLAKE2b-256 92492978e96ca443fd4094d469303570d54c9949a8113e4e2b9336790b3e28e5

See more details on using hashes here.

Provenance

The following attestation bundles were made for tovuk-0.1.63-py3-none-any.whl:

Publisher: publish-pypi.yml on tovuk/tovuk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page