Skip to main content
POST
/
api
/
v0
/
narrate
Narrative Agent
curl --request POST \
  --url https://agents.graphy.dev/api/v0/narrate \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '
{
  "config": {
    "type": "line",
    "data": {
      "columns": [
        {
          "key": "month",
          "label": "Month"
        },
        {
          "key": "users",
          "label": "Active Users"
        }
      ],
      "rows": [
        {
          "month": "Jan",
          "users": 1200
        },
        {
          "month": "Feb",
          "users": 1800
        },
        {
          "month": "Mar",
          "users": 3100
        }
      ]
    }
  },
  "userPrompt": "Write a punchy title and a one-line caption",
  "metadata": {
    "callId": "req-narrate-1",
    "locale": "EN_US"
  }
}
'
{
  "message": "<string>"
}
Generate a chart’s title, subtitle, and caption with natural language. Send a GraphConfig and a prompt, receive an updated GraphConfig via Server-Sent Events. Narrative is written into config.content as TipTap JSON.

Request body

userPrompt is required — the narrative agent needs an instruction to write against. Which fields are produced (title only, title + caption, or all three) depends on the storytelling level derived from metadata.effort.

Response

The response is a Server-Sent Events stream. See SSE Format for parsing details.
event: progress
data: {"message":"Generating narrative..."}

event: complete
data: {"config":{...},"response":{"message":"Wrote a title and caption"}}
Final response data:
interface NarrateResponse {
  config: GraphConfig;
  response: {
    message: string;
  };
}

HTTP Status Codes

StatusDescription
200Success (stream begins)
400Invalid request body
401Invalid or missing API key
429Rate limit exceeded
500Internal server error
Errors may also arrive as SSE events within a 200 response. See Error Codes.

Authorizations

Authorization
string
header
required

Your Graphy API key

Body

application/json
config
object
required

The graph configuration object used to render charts. See Graph Config Schema for the complete reference.

userPrompt
string
required

Natural language instruction describing the desired changes

Maximum string length: 10000
metadata
object

Optional tracking information for requests

Response

SSE stream with progress and completion events

SSE event name is "progress"

message
string