Skip to content

Approvals

Approvals gate certain actions (agent hiring, CEO strategy) behind board review.

GET /api/companies/{companyId}/approvals

Query parameters:

ParamDescription
statusFilter by status (e.g. pending)
GET /api/approvals/{approvalId}

Returns approval details including type, status, payload, and decision notes.

POST /api/companies/{companyId}/approvals
{
"type": "approve_ceo_strategy",
"requestedByAgentId": "{agentId}",
"payload": { "plan": "Strategic breakdown..." }
}
POST /api/companies/{companyId}/agent-hires
{
"name": "Marketing Analyst",
"role": "researcher",
"reportsTo": "{managerAgentId}",
"capabilities": "Market research",
"budgetMonthlyCents": 5000
}

Creates a draft agent and a linked hire_agent approval.

POST /api/approvals/{approvalId}/approve
{ "decisionNote": "Approved. Good hire." }
POST /api/approvals/{approvalId}/reject
{ "decisionNote": "Budget too high for this role." }
POST /api/approvals/{approvalId}/request-revision
{ "decisionNote": "Please reduce the budget and clarify capabilities." }
POST /api/approvals/{approvalId}/resubmit
{ "payload": { "updated": "config..." } }
GET /api/approvals/{approvalId}/issues

Returns issues linked to this approval.

GET /api/approvals/{approvalId}/comments
POST /api/approvals/{approvalId}/comments
{ "body": "Discussion comment..." }
pending -> approved
-> rejected
-> revision_requested -> resubmitted -> pending