forked from wrenn/wrenn
Implement three new recipe commands for the admin template builder: - USER <name>: creates the user (adduser + passwordless sudo), switches execution context so subsequent RUN/START commands run as that user via su wrapping. Last USER becomes the template's default_user. - COPY <src> <dst>: copies files from an uploaded build archive (tar/tar.gz/zip) into the sandbox. Source paths validated against traversal. Ownership set to the current USER. - ENV persistence: accumulated env vars stored in templates.default_env (JSONB) and injected via PostInit when sandboxes are created from the template, mirroring Docker's image metadata approach. Supporting changes: - Pre-build creates wrenn-user as default (via USER command) - WORKDIR now creates the directory if it doesn't exist (mkdir -p) - Per-step progress updates (ProgressFunc callback) for live UI - Multipart form support on POST /v1/admin/builds for archive upload - Proto: default_user/default_env fields on Create/ResumeSandboxRequest - Host agent: SetDefaults calls PostInitWithDefaults on envd - Control plane: reads template defaults, passes on sandbox create/resume - Frontend: file upload widget, recipe copy button, keyword colors for USER/COPY, fixed Svelte whitespace stripping in step display - Admin panel defaults to /admin/templates instead of /admin/hosts - Migration adds default_user and default_env to templates and template_builds tables
39 lines
1.2 KiB
SQL
39 lines
1.2 KiB
SQL
-- name: InsertTemplateBuild :one
|
|
INSERT INTO template_builds (id, name, base_template, recipe, healthcheck, vcpus, memory_mb, status, total_steps, template_id, team_id, skip_pre_post)
|
|
VALUES ($1, $2, $3, $4, $5, $6, $7, 'pending', $8, $9, $10, $11)
|
|
RETURNING *;
|
|
|
|
-- name: GetTemplateBuild :one
|
|
SELECT * FROM template_builds WHERE id = $1;
|
|
|
|
-- name: ListTemplateBuilds :many
|
|
SELECT * FROM template_builds ORDER BY created_at DESC;
|
|
|
|
-- name: UpdateBuildStatus :one
|
|
UPDATE template_builds
|
|
SET status = $2,
|
|
started_at = CASE WHEN $2 = 'running' AND started_at IS NULL THEN NOW() ELSE started_at END,
|
|
completed_at = CASE WHEN $2 IN ('success', 'failed', 'cancelled') THEN NOW() ELSE completed_at END
|
|
WHERE id = $1
|
|
RETURNING *;
|
|
|
|
-- name: UpdateBuildProgress :exec
|
|
UPDATE template_builds
|
|
SET current_step = $2, logs = $3
|
|
WHERE id = $1;
|
|
|
|
-- name: UpdateBuildSandbox :exec
|
|
UPDATE template_builds
|
|
SET sandbox_id = $2, host_id = $3
|
|
WHERE id = $1;
|
|
|
|
-- name: UpdateBuildError :exec
|
|
UPDATE template_builds
|
|
SET error = $2, status = 'failed', completed_at = NOW()
|
|
WHERE id = $1;
|
|
|
|
-- name: UpdateBuildDefaults :exec
|
|
UPDATE template_builds
|
|
SET default_user = $2, default_env = $3
|
|
WHERE id = $1;
|