// Code generated by sqlc. DO NOT EDIT. // versions: // sqlc v1.30.0 // source: template_builds.sql package db import ( "context" "github.com/jackc/pgx/v5/pgtype" ) const getTemplateBuild = `-- name: GetTemplateBuild :one SELECT id, name, base_template, recipe, healthcheck, vcpus, memory_mb, status, current_step, total_steps, logs, error, sandbox_id, host_id, created_at, started_at, completed_at, template_id, team_id FROM template_builds WHERE id = $1 ` func (q *Queries) GetTemplateBuild(ctx context.Context, id pgtype.UUID) (TemplateBuild, error) { row := q.db.QueryRow(ctx, getTemplateBuild, id) var i TemplateBuild err := row.Scan( &i.ID, &i.Name, &i.BaseTemplate, &i.Recipe, &i.Healthcheck, &i.Vcpus, &i.MemoryMb, &i.Status, &i.CurrentStep, &i.TotalSteps, &i.Logs, &i.Error, &i.SandboxID, &i.HostID, &i.CreatedAt, &i.StartedAt, &i.CompletedAt, &i.TemplateID, &i.TeamID, ) return i, err } const insertTemplateBuild = `-- name: InsertTemplateBuild :one INSERT INTO template_builds (id, name, base_template, recipe, healthcheck, vcpus, memory_mb, status, total_steps, template_id, team_id) VALUES ($1, $2, $3, $4, $5, $6, $7, 'pending', $8, $9, $10) RETURNING id, name, base_template, recipe, healthcheck, vcpus, memory_mb, status, current_step, total_steps, logs, error, sandbox_id, host_id, created_at, started_at, completed_at, template_id, team_id ` type InsertTemplateBuildParams struct { ID pgtype.UUID `json:"id"` Name string `json:"name"` BaseTemplate string `json:"base_template"` Recipe []byte `json:"recipe"` Healthcheck string `json:"healthcheck"` Vcpus int32 `json:"vcpus"` MemoryMb int32 `json:"memory_mb"` TotalSteps int32 `json:"total_steps"` TemplateID pgtype.UUID `json:"template_id"` TeamID pgtype.UUID `json:"team_id"` } func (q *Queries) InsertTemplateBuild(ctx context.Context, arg InsertTemplateBuildParams) (TemplateBuild, error) { row := q.db.QueryRow(ctx, insertTemplateBuild, arg.ID, arg.Name, arg.BaseTemplate, arg.Recipe, arg.Healthcheck, arg.Vcpus, arg.MemoryMb, arg.TotalSteps, arg.TemplateID, arg.TeamID, ) var i TemplateBuild err := row.Scan( &i.ID, &i.Name, &i.BaseTemplate, &i.Recipe, &i.Healthcheck, &i.Vcpus, &i.MemoryMb, &i.Status, &i.CurrentStep, &i.TotalSteps, &i.Logs, &i.Error, &i.SandboxID, &i.HostID, &i.CreatedAt, &i.StartedAt, &i.CompletedAt, &i.TemplateID, &i.TeamID, ) return i, err } const listTemplateBuilds = `-- name: ListTemplateBuilds :many SELECT id, name, base_template, recipe, healthcheck, vcpus, memory_mb, status, current_step, total_steps, logs, error, sandbox_id, host_id, created_at, started_at, completed_at, template_id, team_id FROM template_builds ORDER BY created_at DESC ` func (q *Queries) ListTemplateBuilds(ctx context.Context) ([]TemplateBuild, error) { rows, err := q.db.Query(ctx, listTemplateBuilds) if err != nil { return nil, err } defer rows.Close() var items []TemplateBuild for rows.Next() { var i TemplateBuild if err := rows.Scan( &i.ID, &i.Name, &i.BaseTemplate, &i.Recipe, &i.Healthcheck, &i.Vcpus, &i.MemoryMb, &i.Status, &i.CurrentStep, &i.TotalSteps, &i.Logs, &i.Error, &i.SandboxID, &i.HostID, &i.CreatedAt, &i.StartedAt, &i.CompletedAt, &i.TemplateID, &i.TeamID, ); err != nil { return nil, err } items = append(items, i) } if err := rows.Err(); err != nil { return nil, err } return items, nil } const updateBuildError = `-- name: UpdateBuildError :exec UPDATE template_builds SET error = $2, status = 'failed', completed_at = NOW() WHERE id = $1 ` type UpdateBuildErrorParams struct { ID pgtype.UUID `json:"id"` Error string `json:"error"` } func (q *Queries) UpdateBuildError(ctx context.Context, arg UpdateBuildErrorParams) error { _, err := q.db.Exec(ctx, updateBuildError, arg.ID, arg.Error) return err } const updateBuildProgress = `-- name: UpdateBuildProgress :exec UPDATE template_builds SET current_step = $2, logs = $3 WHERE id = $1 ` type UpdateBuildProgressParams struct { ID pgtype.UUID `json:"id"` CurrentStep int32 `json:"current_step"` Logs []byte `json:"logs"` } func (q *Queries) UpdateBuildProgress(ctx context.Context, arg UpdateBuildProgressParams) error { _, err := q.db.Exec(ctx, updateBuildProgress, arg.ID, arg.CurrentStep, arg.Logs) return err } const updateBuildSandbox = `-- name: UpdateBuildSandbox :exec UPDATE template_builds SET sandbox_id = $2, host_id = $3 WHERE id = $1 ` type UpdateBuildSandboxParams struct { ID pgtype.UUID `json:"id"` SandboxID pgtype.UUID `json:"sandbox_id"` HostID pgtype.UUID `json:"host_id"` } func (q *Queries) UpdateBuildSandbox(ctx context.Context, arg UpdateBuildSandboxParams) error { _, err := q.db.Exec(ctx, updateBuildSandbox, arg.ID, arg.SandboxID, arg.HostID) return err } const updateBuildStatus = `-- 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') THEN NOW() ELSE completed_at END WHERE id = $1 RETURNING id, name, base_template, recipe, healthcheck, vcpus, memory_mb, status, current_step, total_steps, logs, error, sandbox_id, host_id, created_at, started_at, completed_at, template_id, team_id ` type UpdateBuildStatusParams struct { ID pgtype.UUID `json:"id"` Status string `json:"status"` } func (q *Queries) UpdateBuildStatus(ctx context.Context, arg UpdateBuildStatusParams) (TemplateBuild, error) { row := q.db.QueryRow(ctx, updateBuildStatus, arg.ID, arg.Status) var i TemplateBuild err := row.Scan( &i.ID, &i.Name, &i.BaseTemplate, &i.Recipe, &i.Healthcheck, &i.Vcpus, &i.MemoryMb, &i.Status, &i.CurrentStep, &i.TotalSteps, &i.Logs, &i.Error, &i.SandboxID, &i.HostID, &i.CreatedAt, &i.StartedAt, &i.CompletedAt, &i.TemplateID, &i.TeamID, ) return i, err }