← Back to Skills Marketplace
kiagentkronos-cell

Fill XFA PDF Forms

by kiagentkronos-cell · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ✓ Security Clean
30
Downloads
0
Stars
0
Active Installs
1
Versions
Install in OpenClaw
/install fill-xfa
Description
Fill XFA (Adobe LiveCycle) PDF forms programmatically. Use when working with .pdf files that have Form: XFA (check with pdfinfo). Standard tools like pdftk,...
README (SKILL.md)

Fill XFA PDF Forms

Fill any Adobe LiveCycle XFA form from the CLI. Solves a gap that standard PDF tools cannot address.

Why This Exists

XFA forms (Form: XFA in pdfinfo) embed data as XML inside the PDF, not as standard AcroForm fields. Tools like pdftk, pypdf, and PyPDF2 silently fail or produce empty output. This script modifies the embedded XFA XML directly.

Prerequisites

pip install pikepdf

Quick Start

SCRIPT="\x3Cskill_dir>/scripts/fill_xfa.py"

# 1) Verify the form is XFA:
pdfinfo form.pdf | grep Form  # Should show: Form: XFA

# 2) Discover field names:
python3 "$SCRIPT" fields form.pdf

# 3) Fill from JSON:
python3 "$SCRIPT" fill form.pdf -o filled.pdf -d data.json

Commands

fields — List Data Fields

python3 "$SCRIPT" fields form.pdf

Outputs sorted field names with current values and duplicate counts.

fill — Set Field Values

Three input methods — combine freely:

# Repeatable --set flags:
python3 "$SCRIPT" fill form.pdf -o out.pdf \
  --set "Eigentümer_Name=Müller" \
  --set "Eigentümer_Vorname=Anna" \
  --set "PLZ=84424"

# JSON file:
python3 "$SCRIPT" fill form.pdf -o out.pdf -d fields.json

# Stdin pipe:
printf '{"Name":"Müller","Vorname":"Anna"}' | \
  python3 "$SCRIPT" fill form.pdf -o out.pdf --stdin

JSON Data Format

{
  "Feldname": "Wert",
  "Eigentümer_Name": "Müller",
  "Datum": "2026-05-05"
}

Field names must match the XML element names in the form (discover with fields).

Duplicate Fields

Some forms reuse field names (e.g., multiple Textfeld1). Two modes:

  • Same value everywhere: --set Textfeld1=3 sets all occurrences to "3"
  • Different values per occurrence: Pass an array: {"Textfeld1": ["A", "B", "C"]} distributes values across duplicates (first field gets "A", second gets "B", etc.)

Limitations

  • Only works with XFA forms — verify first: pdfinfo form.pdf | grep Form
  • Form must not be password-protected
  • Namespace restoration preserves only the first xmlns:* declaration (rarely matters)
  • Some forms require manual wet-ink signature after filling

Common Use Cases

  • Government registration forms (German: Behördendrucke, Landkreis forms)
  • Utility company forms (waste collection, water/electricity)
  • School enrollment applications
  • Any Adobe LiveCycle Designer form downloaded from official websites

Example: German Waste Bin Registration

# Discover fields:
python3 "$SCRIPT" fields tonnenanmeldung_blank.pdf

# Fill from JSON (pipe to stdin):
python3 "$SCRIPT" fill tonnenanmeldung_blank.pdf -o tonnenanmeldung_filled.pdf --stdin \x3C\x3C'EOF'
{
  "Neuantrag": "1",
  "Eigentümer_Name": "Müller",
  "Eigentümer_Vorname": "Anna",
  "Eigentümer_Straße": "Hauptstraße",
  "Eigentümer_Straße_Nummer": "5",
  "Eigentümer_PLZ": "84424",
  "Eigentümer_Ort": "Isen",
  "Eigentümer_seit": "2026-01-15",
  "Grundstück_Straße": "Beispielweg",
  "Grundstück_PLZ": "85435",
  "Grundstück_Ort": "Erding",
  "Grundstück_Haus_Nummer": "12",
  "Textfeld1": "3",
  "Restmüll_ab": "07/2026",
  "Zugang_80_l": "1",
  "Bio_Zugang_80_l": "1",
  "Papier_Zugang_240_l": "1",
  "Kontoinhaber_Name": "Müller, Anna",
  "Kontoinhaber_Straße": "Hauptstraße 5",
  "Kontoinhaber_Ort": "84424 Isen",
  "Kontoinhaber_Kreditinstitut": "VR-Bank",
  "Kontoinhaber_IBAN": "DE",
  "Kontoinhaber_IBAN_Nummer": "1234567890",
  "Kontoinhaber_BIC": "GENODEF1XXX",
  "Datum": "2026-05-05"
}
EOF
Usage Guidance
Before installing, review the script, install pikepdf in a trusted virtual environment, and use the tool only with PDFs and form data you are comfortable processing in the current session. Check the output PDF before submitting it, and remember that filled field values may appear in logs or transcripts.
Capability Analysis
Type: OpenClaw Skill Name: fill-xfa Version: 1.0.0 The skill provides a specialized utility for filling Adobe XFA (LiveCycle) PDF forms by directly manipulating the embedded XML data using the pikepdf library. The Python script (scripts/fill_xfa.py) implements field discovery and data injection without any network activity, suspicious file access, or command execution. The instructions in SKILL.md are strictly aligned with the stated purpose and do not contain any prompt-injection attempts or malicious directives.
Capability Assessment
Purpose & Capability
The stated purpose and visible code align: it inspects and fills XFA PDF XML. Because the documented examples include personal and banking form fields, users should treat inputs and command output as sensitive.
Instruction Scope
The instructions are explicit user-invoked CLI workflows for listing fields and filling PDFs; no prompt override, hidden goal redirection, or autonomous background action is shown.
Install Mechanism
The skill asks users to manually install pikepdf with pip, and no automatic install script or remote execution step is shown.
Credentials
Reading local PDFs and JSON/stdin data and writing a specified output PDF is proportionate to the purpose, but the script also prints filled values to stdout.
Persistence & Privilege
The provided artifacts show no credentials, network endpoints, persistence, elevated privileges, or background agents.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install fill-xfa
  3. After installation, invoke the skill by name or use /fill-xfa
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.0
Initial release — generic XFA (Adobe LiveCycle) form filler. Discovers fields, fills via --set/-d/--stdin, handles duplicates with array values. Hyperion-reviewed code + docs.
Metadata
Slug fill-xfa
Version 1.0.0
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 1
Frequently Asked Questions

What is Fill XFA PDF Forms?

Fill XFA (Adobe LiveCycle) PDF forms programmatically. Use when working with .pdf files that have Form: XFA (check with pdfinfo). Standard tools like pdftk,... It is an AI Agent Skill for Claude Code / OpenClaw, with 30 downloads so far.

How do I install Fill XFA PDF Forms?

Run "/install fill-xfa" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is Fill XFA PDF Forms free?

Yes, Fill XFA PDF Forms is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does Fill XFA PDF Forms support?

Fill XFA PDF Forms is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created Fill XFA PDF Forms?

It is built and maintained by kiagentkronos-cell (@kiagentkronos-cell); the current version is v1.0.0.

💬 Comments