# AILANG Parse MCP server

Deterministic DOCX/PPTX/XLSX/PDF parser: track changes, comments, headers, footers, merged cells.

## Links
- Registry page: https://www.getdrio.com/mcp/io-github-sunholo-data-parse
- Repository: https://github.com/sunholo-data/ailang-parse
- Website: https://www.sunholo.com/ailang-parse/

## Install
- Command: `npx -y @ailang/parse`
- Endpoint: https://docparse.ailang.sunholo.com/mcp/
- Auth: Not captured

## Setup notes
- Package: Npm @ailang/parse v0.7.1
- Environment variable: DOCPARSE_API_KEY (secret)
- Environment variable: AILANG_PARSE_MCP_URL
- Package: Pypi ailang-parse v0.7.1
- Environment variable: DOCPARSE_API_KEY (secret)
- Environment variable: AILANG_PARSE_MCP_URL
- Remote endpoint: https://docparse.ailang.sunholo.com/mcp/

## Tools
- agentCard - A2A Agent Card for agent-to-agent discovery.
Returns a hand-crafted Agent Card with AILANG Parse-specific skills,
supported formats, and capability descriptions.
@raw: return raw JSON (no {result:..., elapsed_ms:N} envelope) for A2A compliance.
Switch to @nowrap once available (lighter than @raw). If using --a2a flag, the
built-in route takes precedence (collision guard skips this). Endpoint: https://docparse.ailang.sunholo.com/mcp/
- apiSamples - Sample files inventory — delegates to the upstream package.
Package @route annotations don't auto-register with serve-api, so we provide
a local wrapper here. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- apiTools - Tool definitions for Claude, OpenAI, MCP, and A2A agent frameworks.
Delegates to the upstream package. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- capabilities - capabilities(∀α2812. () -> α2812 ! {Env}) [pure] Endpoint: https://docparse.ailang.sunholo.com/mcp/
- deviceAuthApprove - Approve a device authorization request.
Called by the browser approval page after user signs in and confirms.
Verifies Firebase ID token from Authorization header to ensure the
caller is a real authenticated user. Extracts uid from the verified token.
Dev mode: ALLOW_SELF_APPROVE=true skips Firebase verification (for testing). Endpoint: https://docparse.ailang.sunholo.com/mcp/
- deviceAuthInspect - Look up a pending device code by user_code and return its provenance.
No authentication required — possession of the user_code is the proof.
The dashboard /approve.html page calls this BEFORE showing the approve UI
so the user can see where the request came from (IP, User-Agent, Referer,
age) and decide whether to trust it.

Returns 404 if the user_code does not match any pending device_codes doc.
Already-approved or expired codes return as INPUT_NOT_FOUND too — there is
nothing to inspect after the fact. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- deviceAuthPoll - Poll for device authorization approval.
Returns AUTHORIZATION_PENDING if user hasn't approved yet.
Returns DEVICE_CODE_EXPIRED if the code has timed out.
Returns approved status with API key on success. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- deviceAuthRequest - Request a device authorization code.
Returns device_code, user_code, and verification URL.
The agent should display the verification_url to the user. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- editDocument - Parse a document, apply JSON edit deltas, and return the modified blocks
as JSON (same format as POST /api/v1/parse with outputFormat=blocks).

filepath: uploaded file path (multipart upload).
deltas:   JSON array of edit operations — see edit_apply.ail for format.
          Empty array or "" → round-trip (parse + return unchanged blocks).
apiKey:   dp_ API key.

Response: modified blocks JSON. Use the AILANG SDK or CLI to generate a
file from the returned blocks (e.g. ailang run ... --convert output.docx).

Only deterministic office formats are supported (docx, pptx, xlsx, odt, odp, ods).
AI-required formats (pdf, image, audio, video) are rejected. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- estimate - estimate(∀α31. (string, string) -> α31 ! {Clock, FS}) [pure] Endpoint: https://docparse.ailang.sunholo.com/mcp/
- formats - List all supported document formats for parsing and generation.
Returns: parse formats (13), generate formats (9), output formats (blocks/markdown/html/a2ui),
and which formats require AI (PDF, images). Endpoint: https://docparse.ailang.sunholo.com/mcp/
- getKeyUsage - Get usage stats for a user's API key. Accepts Firebase JWT or apiKey.
Verifies that the requested keyId belongs to the authenticated user. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- getUploadUrl - Request a pre-authenticated GCS upload URL for direct file upload.
Business tier only. The returned URL allows the client to PUT file content
directly to GCS, bypassing the 32MB Cloud Run request limit.
After upload, pass the gcs_ref to POST /api/v1/parse. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- health - Health check for the AILANG Parse API.
Returns service status, version, AILANG commit hash, supported format counts,
and billing catalog status. `billing_catalog_loaded` is FALSE when the
BILLING_PLAN_CATALOG env var is unset or parses to an empty list — in that
mode every authenticated request silently falls back to the safety-net
"fallback" plan (limit=1) and is rejected as over-quota. release.sh asserts
`billing_catalog_loaded == true` after every promotion to catch this regressing. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- listApiKeys - List API keys for a user. Accepts either:
  - Authorization: Bearer <firebase_id_token>  (dashboard path)
  - {apiKey: "..."} or {args: ["dp_..."]} in body  (CLI/SDK path)
The resolved userId filters the Firestore query server-side. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- mcpAccount - View account info, pricing, entitlements, or list keys.
Actions:
  "status"  (default) → tier, quota, usage from /me/entitlements
  "pricing"           → public pricing tiers (no auth required)
  "keys"              → list user's API keys with per-key usage
  "usage"             → alias for "keys" (per-key usage is shown there) Endpoint: https://docparse.ailang.sunholo.com/mcp/
- mcpAuth - Start device authorization to get an API key.
Returns device_code, user_code, and verification URL.
The agent should display the verification URL to the user, who signs in
and approves the code. Then call mcpAuthPoll with the device_code.
MCP wrappers don't have HTTP request headers, so provenance is empty here. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- mcpAuthPoll - Poll for device authorization completion.
Returns "pending" (keep polling every 5s), "approved" (with api_key and tier),
or "expired" (start over with mcpAuth). Endpoint: https://docparse.ailang.sunholo.com/mcp/
- mcpConvert - Convert is not supported on the hosted server (no persistent local filesystem
to write the output file to). Use the local stdio SDK (@ailang/parse) for
local conversions, where the user has filesystem access. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- mcpEstimate - Estimate cost and latency for parsing a document.
Accepts a file path or sample_id. No auth required. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- mcpFormats - List supported formats, samples, and service capabilities.
Pure JSON, no auth required. Delegates to package implementation.
Single source of truth lives in pkg/sunholo/ailang_parse/services/mcp/tools. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- mcpParse - Parse a document. Accepts a file path or sample_id (e.g. "sample_docx_formatting").
The hosted server requires a valid dp_ API key — get one via mcpAuth.
Output formats: blocks (default), markdown, html, a2ui.
requestId is reserved for future replay support. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- myEntitlements - Get the authenticated user's billing entitlements, usage, and plan details.
Returns: plan name, monthly request limit, requests used, remaining requests, upgrade/manage URLs.
Requires a valid AILANG Parse API key (dp_ prefix). Endpoint: https://docparse.ailang.sunholo.com/mcp/
- parseFileSecure - Parse a document. Requires a valid API key.
Validates the key, checks entitlement quotas, logs for replay.
filepath: file path OR sample_id (e.g. "sample_docx_formatting" → resolved via /api/v1/samples).
outputFormat: "blocks", "markdown", "html", or "a2ui".
editable: "true" to emit editable A2UI component variants with block_index props; only meaningful when outputFormat="a2ui".
gcsRef: optional gs:// URI for Business tier large file uploads (>32MB).
  When provided, the file is downloaded from GCS via our service account.
  Business tier only — Free/Pro users get TIER_UPGRADE_REQUIRED error.
sourceUrl: optional https:// URL (e.g., a signed GCS URL or any public file).
  When provided, the file is fetched over HTTPS by docparse and parsed.
  Available on all tiers; tier dictates the max fetched-file size.
  Cannot be combined with gcsRef or filepath — sourceUrl wins.
@nowrap: raw JSON (no envelope), _headers extracted as HTTP response headers. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- partitionGeneral - Unstructured API-compatible endpoint (drop-in replacement for Unstructured.io).
Returns elements in Unstructured JSON format (Title, NarrativeText, Table, ListItem, etc.).
Accepts file upload (multipart/form-data) or JSON body with filepath/sample_id.
API key: via unstructured-api-key header (Unstructured convention) or apiKey form field.
strategy parameter: "auto" (default), "hi_res", "fast", "ocr_only".
Uses _headers for header access while keeping @route multipart support. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- pricing - pricing(∀α370. () -> α370 ! {...ε19}) [pure] Endpoint: https://docparse.ailang.sunholo.com/mcp/
- requestHistory - List recent parse requests for a user. Returns up to 50 entries.
Accepts Firebase ID token (dashboard) OR dp_ API key (programmatic).
Dashboard sends Authorization: Bearer <firebase_token> with {args: [uid]}.
API clients send {args: [apiKey]}.
Uses Firestore structured query to filter by user_id server-side
and order by timestamp descending. Only reads matching docs (not full scan). Endpoint: https://docparse.ailang.sunholo.com/mcp/
- requestReplay - Retrieve a stored request/response pair for replay.
Requires authentication: Firebase JWT or dp_ API key.
The request must belong to the authenticated user (user_id match).
Accepts optional outputFormat (blocks/markdown/html/a2ui) to re-render
the stored blocks server-side using the ailang_parse pipeline. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- revokeApiKey - Revoke an API key by keyId. Authenticates via either Firebase JWT or apiKey. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- rotateApiKey - Rotate an API key: generate new key, revoke old one, preserve tier + usage. Endpoint: https://docparse.ailang.sunholo.com/mcp/
- submit_feedback - Anonymous bug report / feature request / docs gap, queued for human review. Default routing: `public-feedback` inbox (general AILANG). Pass `package="vendor/name"` (e.g. "sunholo/auth") to route to that package's `pkg:vendor/name` inbox where its autonomous agent watches. Categories: bug, feature, docs, limitation. Body limit 10KB, snippet limit 4KB. Optional contact field for follow-up; opaque to the server. Set `auto_dispatch=true` to authorize the package agent to act on your submission immediately (default false — files for human triage; pkg-feedback agent template lands in a separate sprint). Endpoint: https://docparse.ailang.sunholo.com/mcp/

## Resources
- ailang://meta/modules - List of all loaded AILANG modules and their exports MIME type: application/json

## Prompts
Not captured

## Metadata
- Owner: io.github.sunholo-data
- Version: 0.7.1
- Runtime: Npm, Pypi
- Transports: STDIO, HTTP
- License: Not captured
- Language: Not captured
- Stars: Not captured
- Updated: May 16, 2026
- Source: https://registry.modelcontextprotocol.io
