loading…
Search for a command to run...
loading…
Tag, rename, and enrich any PDF or image. One MCP call. Free tier: 1,500 tags/month, no credit card.
Tag, rename, and enrich any PDF or image. One MCP call. Free tier: 1,500 tags/month, no credit card.
Tag, rename, and enrich any PDF or image. One MCP call. Free tier: 1,500 tags/month, no credit card.
License: MIT Free tier MCP Last commit
Install • Examples • Product page • Full docs
This repository is the discovery, install, and examples surface for Gemina FileTag's MCP server. The server itself is hosted at https://api.gemina.co/api/v1/mcp/ — there is no daemon to run locally. Point your MCP-compatible client at the endpoint, paste an API key, and tag your first document in under a minute.
The server itself is closed-source (operated by Gemina). Everything in this repo — install snippets, examples, integration code — is MIT-licensed and contributions are welcome.
Send a PDF or image. Get back structured metadata, six suggested filenames, and a downloadable copy with metadata already embedded in the file itself.
Input: any PDF or image up to 50 MB (PDF, PNG, JPEG, GIF, WebP).
Output:
{
"document_id": "abc-123",
"suggested_filename": "2026-02-15_Acme-Corp_Invoice_12345.pdf",
"metadata": {
"document_type": "invoice",
"vendor": "Acme Corp",
"date": "2026-02-15",
"amount": 7200,
"currency": "ILS",
"document_number": "12345",
"title": "Invoice",
"tags": ["vendor", "invoice"]
},
"filename_patterns": {
"date_first": "2026-02-15_Invoice_12345.pdf",
"type_first": "Invoice_12345_2026-02-15.pdf",
"vendor_first": "Acme-Corp_Invoice_2026-02-15.pdf",
"date_vendor": "2026-02-15_Acme-Corp.pdf",
"vendor_date": "Acme-Corp_2026-02-15.pdf",
"compact": "Acme-Corp_Invoice.pdf"
},
"enriched_file_url": "https://api.gemina.co/files/tmp_abc123.pdf",
"enriched_file_expires_at": "2026-02-15T12:15:00Z"
}
Three uses out of one response — pick the one your code needs, ignore the rest.
You need an API key. Get one free (no credit card) at https://console.gemina.co/registration/create-account, then drop the snippet below into your MCP client's config and restart it.
Endpoint: https://api.gemina.co/api/v1/mcp/ · Transport: Streamable HTTP · Auth: X-API-Key header
Claude Desktop's Custom Connectors UI (Customize → Connectors) only supports OAuth and doesn't accept custom headers — it can't authenticate against Gemina's X-API-Key. Use the mcp-remote stdio bridge instead.
Prerequisites
Node.js 18+ — install from nodejs.org (Windows: ensure "Add to PATH" stays checked; macOS/Linux: standard installer).
Claude Desktop capabilities — open Settings → Capabilities and turn on:
storage.googleapis.com to the narrow allowlist — that's where signed enriched-file URLs are hosted).Without network egress, tag_file/tag_url return JSON correctly but Claude can't fetch the enriched-file URL from storage and you'll see "Host not in allowlist". Settings only apply to new chats — start a fresh conversation after toggling.
Config
In Claude Desktop, Settings → Developer → Edit Config opens claude_desktop_config.json at:
~/Library/Application Support/Claude/claude_desktop_config.json%APPDATA%\Claude\claude_desktop_config.jsonMerge the mcpServers block alongside any existing config:
{
"mcpServers": {
"gemina": {
"command": "npx",
"args": [
"-y",
"mcp-remote",
"https://api.gemina.co/api/v1/mcp/",
"--header",
"X-API-Key:${GEMINA_API_KEY}"
],
"env": {
"GEMINA_API_KEY": "<paste-your-key-here>"
}
}
}
}
Save → fully quit Claude Desktop (Cmd+Q / right-click tray → Quit) → relaunch. First launch may take 10–30s while npx downloads mcp-remote.
Notes
X-API-Key: in the --header arg — it's the documented workaround for npx's shell-split parsing.${GEMINA_API_KEY}) keeps the literal key out of args, where it could leak via process listings.spawn npx ENOENT: Claude Desktop doesn't inherit your shell's PATH. Replace "command": "npx" with the absolute path from where npx in PowerShell (forward slashes work in JSON), e.g. "C:/Program Files/nodejs/npx.cmd".File: ~/.cursor/mcp.json.
{
"mcpServers": {
"gemina": {
"url": "https://api.gemina.co/api/v1/mcp/",
"headers": {
"X-API-Key": "<paste-your-key-here>"
}
}
}
}
claude mcp add --transport http gemina https://api.gemina.co/api/v1/mcp/ \
--header "X-API-Key: <paste-your-key-here>"
File: .vscode/mcp.json (per workspace).
{
"servers": {
"gemina": {
"type": "http",
"url": "https://api.gemina.co/api/v1/mcp/",
"headers": {
"X-API-Key": "<paste-your-key-here>"
}
}
}
}
In Cline's MCP settings (gear icon → MCP Servers → Edit Config), add:
{
"mcpServers": {
"gemina": {
"type": "streamableHttp",
"url": "https://api.gemina.co/api/v1/mcp/",
"headers": {
"X-API-Key": "<paste-your-key-here>"
}
}
}
}
File: ~/.codeium/windsurf/mcp_config.json. Note: the field is serverUrl, not url.
{
"mcpServers": {
"gemina": {
"serverUrl": "https://api.gemina.co/api/v1/mcp/",
"headers": {
"X-API-Key": "<paste-your-key-here>"
}
}
}
}
Append to ~/.codex/config.toml:
[mcp_servers.gemina]
url = "https://api.gemina.co/api/v1/mcp/"
http_headers = { "X-API-Key" = "<paste-your-key-here>" }
openclaw mcp set gemina '{"url":"https://api.gemina.co/api/v1/mcp/","transport":"streamable-http","headers":{"X-API-Key":"<paste-your-key-here>"}}'
Append under mcp_servers in ~/.hermes/config.yaml:
mcp_servers:
gemina:
url: "https://api.gemina.co/api/v1/mcp/"
headers:
X-API-Key: "<paste-your-key-here>"
For the full machine-readable install guide (used by agents), see llms-install.md.
1,500 tags per month. No credit card required. Sign up at gemina.co/filetag, grab an API key, paste it into your config. The same key works for both MCP and the REST API.
Need more? Paid plans add larger monthly allowances, configurable data residency, and longer retention. See pricing.
The same MCP call (tag_file or tag_url) powers all of these. Each example has a dedicated walkthrough in examples/.
| Use case | What it does | Example |
|---|---|---|
| 📥 Email attachment triage | Tag inbound attachments, route to folders by vendor/type | examples/gmail-attachment-triage |
| 🔍 RAG ingestion | Attach structured metadata to vector store entries so retrieval can filter by vendor, date, or document type | examples/llamaindex-reader · examples/langchain-loader |
| 🧾 Invoice automation | Extract vendor, totals, line items; route to AP; export to accounting | examples/bulk-tag-folder |
| 📁 Bulk document filing | Walk a directory, rename every file to a consistent pattern | examples/bulk-tag-folder |
| ⚡ Quickstart (curl) | First tag in three minutes, no MCP client needed | examples/curl-quickstart |
| 🖥️ Claude Desktop walkthrough | Step-by-step setup with screenshots | examples/claude-desktop |
A naive "ask GPT to tag this PDF" pipeline breaks in production: hallucinated vendor names, inconsistent date formats, no structured output, no PDF metadata embedding, no enriched-file roundtrip. FileTag is the harness around that call — specialized agents that reason, cross-check, and refuse to guess — wrapped in a single endpoint with a stable JSON contract.
| Raw LLM | Gemina FileTag | |
|---|---|---|
| Structured output | Free text, requires parsing | Stable JSON schema |
| Filename suggestions | None | Six patterns, ready to use |
| PDF metadata embedding | DIY | Returned as downloadable enriched copy |
| Hallucinations | Frequent | Cross-checked, refuses when unsure |
| Per-document cost | $$ per call | Free for first 1,500/month |
Full details on the Gemina Trust Center.
The Dockerfile at the repo root is not for end users. It exists so directory operators (e.g. Glama's /mcp/servers/ tier) can build a container that introspects the public tool surface without provisioning credentials. The container runs mcp-remote against https://api.gemina.co/api/v1/mcp/public/ — a read-only discovery endpoint that serves initialize / tools/list / prompts/list to anonymous callers but refuses tools/call. End users should follow the Quick install section above and connect to the authenticated endpoint with their personal API key.
Examples PRs welcome — see CONTRIBUTING.md. The server itself is closed-source, so PRs that touch the actual MCP server logic will be declined, but bug reports against the live server are very welcome.
The contents of this repository — install snippets, example code, documentation, configuration files, and sample assets — are released under the MIT License.
The Gemina FileTag MCP server itself is a hosted closed-source service operated by Gemina (https://gemina.co) and is not covered by this license. Use of the server is governed by Gemina's Terms of Service and Privacy Policy.
Выполни в терминале:
claude mcp add gemina-filetag -- npx Безопасность
Низкий рискАвтоматическая эвристика по публичным данным — не гарантия безопасности.