Save Document
POST
/api/canvas/{deal_id}/save
const url = 'https://example.com/api/canvas/example/save';const options = { method: 'POST', headers: {Authorization: 'Bearer <token>', 'Content-Type': 'application/json'}, body: '{"content":"example"}'};
try { const response = await fetch(url, options); const data = await response.json(); console.log(data);} catch (error) { console.error(error);}curl --request POST \ --url https://example.com/api/canvas/example/save \ --header 'Authorization: Bearer <token>' \ --header 'Content-Type: application/json' \ --data '{ "content": "example" }'Save full document content.
Auto-promotes DRAFT -> EDITING on first save. Content is persisted to both Redis (fast) and Store (durable, decomposed by section). Broadcasts document_saved event via WebSocket.
Phase 4: RequireEditor — viewers and commenters cannot save.
Authorizations
Section titled “Authorizations ”Parameters
Section titled “ Parameters ”Path Parameters
Section titled “Path Parameters ” deal_id
required
Deal Id
string
Request Body required
Section titled “Request Body required ” Media type application/json
SaveDocumentRequest
Request body for saving document content.
object
content
required
Content
string
Example generated
{ "content": "example"}Responses
Section titled “ Responses ”Successful Response
Media type application/json
DocumentStateResponse
Response for document state transitions.
object
Example generated
{ "success": true, "from_state": "example", "to_state": "example", "error": "example", "details": {}}Validation Error
Media type application/json
HTTPValidationError
object
detail
Detail
Array<object>
ValidationErrorobject
loc
required
Location
Array
msg
required
Message
string
type
required
Error Type
string
input
Input
ctx
Context
object
Example generated
{ "detail": [ { "loc": [ "example" ], "msg": "example", "type": "example", "input": "example", "ctx": {} } ]}