PDF Tools
Fill standard PDF forms programmatically (text, checkbox, radio, dropdown/list) using JSON data injection
Call this tool from your code in three languages.
# 1) Upload each file first → returns { filePath }
curl -X POST 'https://api.elysiatools.com/upload/pdf-acroform-filler' \
-F 'file=@/path/to/pdfFile.ext'
# 2) Call the tool with the returned filePath values
curl -X POST 'https://api.elysiatools.com/en/api/tools/pdf-acroform-filler' \
-F 'pdfFile=/public/samples/pdf/form-sample-acroform.pdf' \
-F 'fieldDataJson={"full_name":"Alex Doe","agree_terms":true,"tier":"pro","country":"US","hobbies":["Reading","Music"]}' \
-F 'removeXfaBeforeFill=true' \
-F 'flatten=true' \
-F 'strictMode=false'Send a POST request with your inputs as JSON. File parameters require a separate upload first.
POST https://api.elysiatools.com/en/api/tools/pdf-acroform-filler| Name | Type | Required | Description |
|---|---|---|---|
| pdfFile | fileupload required | Yes | — |
| fieldDataJson | textarea | Yes | JSON object where key = field name, value = field value |
| removeXfaBeforeFill | checkbox | No | For hybrid PDFs, remove XFA packet and fill AcroForm fallback |
| flatten | checkbox | No | Flatten fields to make result non-editable |
| strictMode | checkbox | No | Fail immediately when any field cannot be mapped/written |
File result
{
"filePath": "/public/processing/randomid.ext",
"fileName": "output.ext",
"contentType": "application/octet-stream",
"size": 1024,
"metadata": {
"key": "value"
},
"error": "Error message (optional)",
"message": "Notification message (optional)"
}Add this tool to your Model Context Protocol server so AI agents can list and call it.
Add this block to your MCP client configuration:
{
"mcpServers": {
"elysiatools-pdf-acroform-filler": {
"name": "pdf-acroform-filler",
"description": "Fill standard PDF forms programmatically (text, checkbox, radio, dropdown/list) using JSON data injection",
"baseUrl": "https://api.elysiatools.com/mcp/sse?toolId=pdf-acroform-filler",
"command": "",
"args": [],
"env": {},
"isActive": true,
"type": "sse"
}
}
}After connecting to the SSE endpoint, list the exposed tools:
{
"jsonrpc": "2.0",
"id": 1,
"method": "tools/list"
}Invoke the tool by its id, passing arguments built from its parameters:
{
"jsonrpc": "2.0",
"id": 2,
"method": "tools/call",
"params": {
"name": "pdf-acroform-filler",
"arguments": {
"pdfFile": "/public/samples/pdf/form-sample-acroform.pdf",
"fieldDataJson": "{\"full_name\":\"Alex Doe\",\"agree_terms\":true,\"tier\":\"pro\",\"country\":\"US\",\"hobbies\":[\"Reading\",\"Music\"]}",
"removeXfaBeforeFill": true,
"flatten": true,
"strictMode": false
}
}
}Questions or issues? Contact [email protected]