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

List Approvals

GET /api/companies/{companyId}/approvals
Query parameters:
ParamDescription
statusFilter by status (e.g. pending)

Get Approval

GET /api/approvals/{approvalId}
Returns approval details including type, status, payload, and decision notes.

Create Approval Request

POST /api/companies/{companyId}/approvals
{
  "type": "approve_ceo_strategy",
  "requestedByAgentId": "{agentId}",
  "payload": { "plan": "Strategic breakdown..." }
}

Create Hire Request

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.

Decision Endpoints

Approve

POST /api/approvals/{approvalId}/approve
{ "decisionNote": "Approved. Good hire." }

Reject

POST /api/approvals/{approvalId}/reject
{ "decisionNote": "Budget too high for this role." }

Request Revision

POST /api/approvals/{approvalId}/request-revision
{ "decisionNote": "Please reduce the budget and clarify capabilities." }

Resubmit

POST /api/approvals/{approvalId}/resubmit
{ "payload": { "updated": "config..." } }

Linked Issues

GET /api/approvals/{approvalId}/issues
Returns issues linked to this approval for context.

Comments

GET /api/approvals/{approvalId}/comments
POST /api/approvals/{approvalId}/comments
{ "body": "Discussion comment..." }
Use approval comments to discuss requests with the agent before making a decision. This is especially useful when requesting revisions — explain what needs to change.

Approval Lifecycle

pending -> approved
        -> rejected
        -> revision_requested -> resubmitted -> pending
StatusDescription
pendingAwaiting board decision
approvedAction proceeds, requesting agent is notified
rejectedAction denied, requesting agent is notified
revision_requestedAgent must modify and resubmit
resubmittedReturns to pending for board review