REST API endpoints for preparing files and verifying citations.
Upload and process a document for citation verification. Extracts text with line IDs for LLM prompts.
multipart/form-data
| Field | Type | Required | Description |
|---|---|---|---|
file |
File | Yes | PDF or image file (max 10MB) |
filename |
string | No | Override filename |
| Field | Type | Description |
|---|---|---|
attachmentId |
string | System-generated ID for verification calls. Store this to avoid re-uploading. |
deepTextPromptPortion |
string | Formatted text with page markers and line IDs for wrapCitationPrompt() |
status |
"ready" | "error" |
Processing status |
metadata |
object | File metadata (filename, mimeType, pageCount, textByteSize) |
processingTimeMs |
number | Processing time in milliseconds |
error |
string | Error message if status is “error” |
curl -X POST "https://api.deepcitation.com/prepareFile" \
-H "Authorization: Bearer dc_live_your_api_key" \
-F "file=@document.pdf"
{
"attachmentId": "abc123-def456-ghi789",
"deepTextPromptPortion": "[Page 1]\n[L1] Revenue increased by 25% in Q4...\n[L2] Net profit margin improved...",
"metadata": {
"filename": "document.pdf",
"mimeType": "application/pdf",
"pageCount": 2,
"textByteSize": 4096
},
"status": "ready",
"processingTimeMs": 1234
}
Verify citations from LLM output against the source document. Returns verification status and visual proof.
application/json
| Field | Type | Required | Description |
|---|---|---|---|
data.attachmentId |
string | Yes | From prepareFile response. The SDK handles this automatically with dc.verify(). |
data.citations |
Record<string, Citation> |
Yes | Map of citation keys to Citation objects |
data.outputImageFormat |
"jpeg" | "png" | "avif" |
No | Image format for proofs (default: “avif”) |
| Field | Type | Description |
|---|---|---|
verifications |
Record<string, Verification> |
Map of citation keys to verification results |
curl -X POST "https://api.deepcitation.com/verifyCitations" \
-H "Authorization: Bearer dc_live_your_api_key" \
-H "Content-Type: application/json" \
-d '{
"data": {
"attachmentId": "abc123-def456-ghi789",
"citations": {
"citation-1": {
"fullPhrase": "Revenue increased by 25% in Q4",
"pageNumber": 1
},
"citation-2": {
"fullPhrase": "Net profit margin improved",
"value": "profit margin"
}
},
"outputImageFormat": "avif"
}
}'
{
"verifications": {
"citation-1": {
"pageNumber": 1,
"lowerCaseSearchTerm": "revenue increased by 25% in q4",
"matchSnippet": "...the company reported that Revenue increased by 25% in Q4 compared to...",
"verificationImageBase64": "...",
"searchState": {
"status": "found"
},
"verifiedAt": "2024-01-15T10:30:00.000Z"
},
"citation-2": {
"pageNumber": 1,
"lowerCaseSearchTerm": "net profit margin improved",
"matchSnippet": "...operating costs. Net profit margin improved by 3.2 percentage points...",
"verificationImageBase64": "...",
"searchState": {
"status": "found"
},
"verifiedAt": "2024-01-15T10:30:00.000Z"
}
}
}
| Status | Code | Description |
|---|---|---|
| 400 | invalid-argument |
Missing required parameters or invalid file format |
| 401 | unauthenticated |
Invalid or expired API key |
| 404 | not-found |
Attachment not found (may have expired after 30 days) |
| 405 | method-not-allowed |
Only POST requests are allowed |
| 429 | resource-exhausted |
Free tier limit exceeded - add a payment method |
| 503 | service-unavailable |
Temporary service issue - retry with exponential backoff |
See full pricing for details.