{"openapi":"3.1.0","info":{"title":"PUT /api/v1/ap-approval/approvers/{tier}","version":"1.0.0","description":"Update approvers for a tier"},"servers":[{"url":"https://api.ondayzero.com","description":"Production"}],"paths":{"/api/v1/ap-approval/approvers/{tier}":{"put":{"tags":["ap-approval"],"summary":"Update approvers for a tier","description":"Replace the approver list for a tier in the workflow graph.","operationId":"update_approvers_api_v1_ap_approval_approvers__tier__put","parameters":[{"name":"tier","in":"path","required":true,"schema":{"type":"string","title":"Tier"}},{"name":"authorization","in":"header","required":false,"schema":{"anyOf":[{"type":"string"},{"type":"null"}],"title":"Authorization"}},{"name":"x-business-id","in":"header","required":false,"schema":{"anyOf":[{"type":"string"},{"type":"null"}],"title":"X-Business-Id"}}],"requestBody":{"required":true,"content":{"application/json":{"schema":{"$ref":"#/components/schemas/SetApproversRequest"}}}},"responses":{"200":{"description":"Successful Response","content":{"application/json":{"schema":{"$ref":"#/components/schemas/ApproversResponse"}}}},"401":{"description":"Unauthorized - Authentication required","content":{"application/json":{"example":{"detail":"Not authenticated"}}}},"403":{"description":"Forbidden - Insufficient permissions","content":{"application/json":{"example":{"detail":"Not enough permissions"}}}},"404":{"description":"Not Found - Resource does not exist","content":{"application/json":{"example":{"detail":"Resource not found"}}}},"422":{"description":"Validation Error","content":{"application/json":{"schema":{"$ref":"#/components/schemas/HTTPValidationError"}}}}}}}},"components":{"schemas":{"ApproversResponse":{"properties":{"approvers":{"additionalProperties":{"items":{"type":"string"},"type":"array"},"type":"object","title":"Approvers","description":"Approver user IDs grouped by tier ('ops', 'advisor', 'owner')."}},"type":"object","title":"ApproversResponse","description":"Response for ``GET /ap-approval/approvers`` and the PUT counterpart.\n\n``approvers`` is a map from tier name → list of user UUID strings. Tiers\nwith no approvers configured are absent (or empty), and the run-time\nenforcement falls back to \"anyone on the business\" for those tiers."},"HTTPValidationError":{"properties":{"detail":{"items":{"$ref":"#/components/schemas/ValidationError"},"type":"array","title":"Detail"}},"type":"object","title":"HTTPValidationError"},"SetApproversRequest":{"properties":{"user_ids":{"items":{"type":"string"},"type":"array","title":"User Ids","description":"List of user UUIDs to set as approvers for the tier."}},"type":"object","title":"SetApproversRequest","description":"Body for ``PUT /ap-approval/approvers/{tier}``."},"ValidationError":{"properties":{"loc":{"items":{"anyOf":[{"type":"string"},{"type":"integer"}]},"type":"array","title":"Location"},"msg":{"type":"string","title":"Message"},"type":{"type":"string","title":"Error Type"},"input":{"title":"Input"},"ctx":{"type":"object","title":"Context"}},"type":"object","required":["loc","msg","type"],"title":"ValidationError"}},"securitySchemes":{"BearerAuth":{"type":"http","scheme":"bearer","bearerFormat":"API Token","description":"API token authentication. Format: `Bearer dz_...`"}}},"security":[{"BearerAuth":[]}]}