@treeseed/api runs the Treeseed backend control plane: HTTP API, PostgreSQL-backed state, backend auth, operation lifecycle, migrations, seed application, route descriptors, operations runner, and public TreeDX federation hosting.
Use this package when you operate or develop the Treeseed backend. Ordinary admin users interact with it through the web/admin UI or CLI, not by importing this package.
- operators deploying Treeseed API and operations-runner services
- maintainers changing backend routes, storage, auth, migrations, or operation execution
- acceptance-test runners validating hosted API behavior
- platform engineers wiring TreeDX federation into the Treeseed backend
The root market/admin web app reaches this package through HTTP/proxy/client surfaces only.
Railway builds backend services from this package root:
api
rootDir: packages/api
buildCommand: npm run build
startCommand: npm run start:api
healthcheckPath: /healthz
runtimeMode: serverless
operationsRunner
rootDir: packages/api
buildCommand: npm run build
startCommand: npm run start:runner
healthcheckPath: /healthz
runtimeMode: service
volumeMountPath: /data
Treeseed PostgreSQL targets both services with TREESEED_DATABASE_URL.
npm install
npm run build
npm run test:unit
npm run verify:localRuntime scripts:
npm run dev:api
npm run dev:runner -- --market local --watch --operation project:web_deployment --mock-external
npm run dev:compose
npm run start:api
npm run start:runner
npm run db:migrateLocal Docker Compose runs the API, operations runner, and PostgreSQL with the same Railway-owned service shape used by hosting reconciliation. The Compose file does not use env_file or plaintext .env secrets; run it from a trsd-unlocked environment so required variables are injected into the process environment.
npm run dev:compose
npm run dev:compose:logs
npm run dev:compose:downHosted acceptance:
TREESEED_API_BASE_URL=<api-base-url> \
TREESEED_ACCEPTANCE_SERVICE_ID=<service-id> \
TREESEED_ACCEPTANCE_SERVICE_SECRET=<service-secret> \
npm run test:acceptance -- --base-url "$TREESEED_API_BASE_URL"Reconciliation must flow through trsd; direct provider mutation is diagnostic only.
npx trsd ready staging --json
npx trsd hosting plan --environment staging --app api --json
npx trsd hosting apply --environment staging --app api --execute --json
npx trsd hosting verify --environment staging --app api --live --json
npx trsd operations smoke --environment staging --service operationsRunner --jsonThe package deploy workflow verifies the package, reconciles the API app, verifies live Railway/API/runner/PostgreSQL/TreeDX state, runs operations-runner smoke checks, and runs hosted API acceptance before going green.
API and runner:
TREESEED_DATABASE_URLTREESEED_PLATFORM_RUNNER_SECRETTREESEED_CREDENTIAL_SESSION_SECRET- API auth/service trust secrets configured by the environment
Runner:
TREESEED_PLATFORM_RUNNER_IDTREESEED_PLATFORM_RUNNER_DATA_DIRTREESEED_PLATFORM_RUNNER_ENVIRONMENTTREESEED_MANAGER_ID
Web/API trust:
TREESEED_WEB_SERVICE_IDTREESEED_WEB_SERVICE_SECRETTREESEED_WEB_ASSERTION_SECRETTREESEED_API_BASE_URL
Provider credentials are required only for enabled operation types. Manage them through Treeseed config and provider secret stores, not plaintext env files.
@treeseed/api
@treeseed/api/api/app
@treeseed/api/api/server
@treeseed/api/api/store
@treeseed/api/api/market-postgres
@treeseed/api/operations-runner
@treeseed/api/route-descriptors
Published binaries:
treeseed-api
treeseed-api-operations-runner
treeseed-api-db-migrate
@treeseed/adminrenders admin UI and talks to API through HTTP/proxy/client facades.@treeseed/uiowns reusable visual components used by admin/market.- root
@treeseed/markethosts the web tenant and future ecommerce overlays. @treeseed/sdkowns shared contracts, reconciliation, config, and workflow primitives used by API.@treeseed/cliexposes operator commands that call SDK/API surfaces.@treeseed/agentowns capacity-provider runtime; API owns backend control-plane routes and operation state for that runtime.packages/treedxowns the generic repository service image consumed by API hosting.
- web/admin routes or Astro pages
- reusable UI primitives
- root market content, public messaging, or ecommerce
- CLI command UX
- capacity provider manager/runner/worker implementation
- TreeDX internals
@treeseed/api is deploy-only/private for now. It keeps standard Treeseed package scripts so package verification, tags, and workflow orchestration stay consistent.
npm run release:verify
npm run release:publishrelease:publish should no-op or refuse clearly while the package remains private.
See the root Package Ownership guide for cross-package boundaries.