loading…
Search for a command to run...
loading…
MCP server for AI-powered translation management in i18n projects, enabling automated locale detection, translation status checks, and sync via LangAPI.
MCP server for AI-powered translation management in i18n projects, enabling automated locale detection, translation status checks, and sync via LangAPI.
MCP (Model Context Protocol) server for LangAPI - AI-powered translation management for i18n projects.
This package enables AI assistants like Claude, Cursor, and VS Code extensions to manage translations in your project programmatically.
# 1. Get your API key at https://langapi.io (1,000 free credits)
# 2. Add to your AI tool (example for Claude Desktop on macOS):
# Edit ~/Library/Application Support/Claude/claude_desktop_config.json
# 3. Start chatting:
# "Scan my project for translations"
# "What keys are missing in German?"
# "Sync all translations"
.strings, .xcstrings, and .stringsdict filesnpm install @langapi/mcp-server
Or use directly with npx (recommended):
npx @langapi/mcp-server
Config file locations:
~/Library/Application Support/Claude/claude_desktop_config.json%APPDATA%\Claude\claude_desktop_config.json~/.config/Claude/claude_desktop_config.jsonConfiguration:
{
"mcpServers": {
"langapi": {
"command": "npx",
"args": ["@langapi/mcp-server"],
"env": {
"LANGAPI_API_KEY": "your-api-key-here"
}
}
}
}
After editing, restart Claude Desktop for changes to take effect.
Option 1: CLI command (quickest)
# Add to current project (stored in .mcp.json)
claude mcp add langapi \
--env LANGAPI_API_KEY=your-api-key-here \
-- npx -y @langapi/mcp-server
Option 2: Project-level config (recommended for teams)
Create .mcp.json in your project root:
{
"mcpServers": {
"langapi": {
"command": "npx",
"args": ["@langapi/mcp-server"],
"env": {
"LANGAPI_API_KEY": "your-api-key-here"
}
}
}
}
Option 3: User-level config
Add to ~/.claude.json:
{
"mcpServers": {
"langapi": {
"command": "npx",
"args": ["@langapi/mcp-server"],
"env": {
"LANGAPI_API_KEY": "your-api-key-here"
}
}
}
}
Option 4: Environment variable
export LANGAPI_API_KEY="your-api-key-here"
Then the MCP server will pick it up automatically.
Verify connection:
# List configured servers
claude mcp list
# Check server status inside Claude Code
/mcp
Remove server:
claude mcp remove langapi
Config file locations:
.cursor/mcp.json in your project root~/.cursor/mcp.jsonConfiguration:
{
"mcpServers": {
"langapi": {
"command": "npx",
"args": ["@langapi/mcp-server"],
"env": {
"LANGAPI_API_KEY": "your-api-key-here"
}
}
}
}
Alternative: Via UI
.vscode/cline_mcp_settings.json in your project:{
"mcpServers": {
"langapi": {
"command": "npx",
"args": ["@langapi/mcp-server"],
"env": {
"LANGAPI_API_KEY": "your-api-key-here"
}
}
}
}
.vscode/mcp.json in your project:{
"mcpServers": {
"langapi": {
"command": "npx",
"args": ["@langapi/mcp-server"],
"env": {
"LANGAPI_API_KEY": "your-api-key-here"
}
}
}
}
Config file: ~/.codeium/windsurf/mcp_config.json
{
"mcpServers": {
"langapi": {
"command": "npx",
"args": ["@langapi/mcp-server"],
"env": {
"LANGAPI_API_KEY": "your-api-key-here"
}
}
}
}
Restart Windsurf after editing.
| Variable | Required | Description |
|---|---|---|
LANGAPI_API_KEY |
Yes | Your LangAPI API key (get one at langapi.io) |
LANGAPI_API_URL |
No | Custom API URL (default: https://api.langapi.io) |
list_local_localesScan your project for locale JSON files and detect the i18n framework.
Input:
{
"project_path": "/path/to/project", // optional, defaults to cwd
"include_key_count": true // optional, default: true
}
Output:
{
"framework": "next-intl",
"confidence": "high",
"source_lang": "en",
"locales_path": "messages",
"locales": [
{
"lang": "en",
"files": [{ "path": "messages/en.json", "namespace": null, "key_count": 150 }],
"total_keys": 150
},
{
"lang": "de",
"files": [{ "path": "messages/de.json", "namespace": null, "key_count": 120 }],
"total_keys": 120
}
],
"config_file": "i18n.ts"
}
get_translation_statusCompare source locale against targets to identify missing keys and estimate costs.
Input:
{
"source_lang": "en",
"target_langs": ["de", "fr"], // optional, all non-source by default
"project_path": "/path/to/project" // optional
}
Output:
{
"source_lang": "en",
"source_keys": 150,
"targets": [
{
"lang": "de",
"status": "outdated",
"keys": { "total": 120, "missing": ["new.key1", "new.key2"], "extra": [] }
}
],
"cost_estimate": {
"words_to_translate": 45,
"credits_required": 90,
"current_balance": 1000,
"balance_after_sync": 910
}
}
sync_translationsSync translations via the LangAPI API. Default is dry_run=true for safety.
Input:
{
"source_lang": "en",
"target_langs": ["de", "fr"],
"dry_run": true, // default: true (preview mode)
"project_path": "/path/to/project", // optional
"write_to_files": true, // optional, default: true
"skip_keys": ["key.to.skip"] // optional, keys to exclude
}
Output (dry_run=true):
{
"success": true,
"dry_run": true,
"delta": {
"new_keys": ["new.key1", "new.key2"],
"changed_keys": [],
"total_keys_to_sync": 2
},
"cost": {
"words_to_translate": 45,
"credits_required": 90,
"current_balance": 1000,
"balance_after_sync": 910
},
"message": "Preview: 2 keys to sync, 90 credits required. Run with dry_run=false to execute."
}
Output (dry_run=false):
{
"success": true,
"dry_run": false,
"results": [
{ "language": "de", "translated_count": 2, "file_written": "messages/de.json" },
{ "language": "fr", "translated_count": 2, "file_written": "messages/fr.json" }
],
"cost": {
"credits_used": 90,
"balance_after_sync": 1910
},
"message": "Sync complete. 4 keys translated across 2 languages. 90 credits used."
}
"Scan my project for translations"
"What i18n framework am I using?"
"List all my locale files"
"How many translation keys do I have?"
"What languages are configured in my project?"
"What translations are missing?"
"Compare English to all other languages"
"How many keys need to be translated for French?"
"Which languages are out of sync?"
"Show me the missing keys for German"
"How much will it cost to sync all languages?"
"Preview what would happen if I sync all languages"
"Do a dry run for French translations"
"Show me what keys will be translated"
"What's the cost estimate for syncing German?"
"Preview the sync without making changes"
"Sync all missing translations"
"Translate to German and French"
"Update all locale files with missing keys"
"Sync translations and write to files"
"Execute the translation sync"
"Are there any extra keys in German that aren't in English?"
"Skip the settings.* keys when syncing"
"Only sync the home.* and nav.* keys"
"Sync to Japanese but skip experimental features"
You: List the translations in my project
Claude: [Calls list_local_locales]
I found a next-intl project with English (150 keys) and German (120 keys) translations.
You: What translations are missing for German?
Claude: [Calls get_translation_status]
German is missing 30 keys. The sync would cost 85 credits (you have 1000 credits).
You: Sync the German translations
Claude: [Calls sync_translations with dry_run=true]
Preview: 30 keys will be translated, costing 85 credits. Should I proceed?
You: Yes, go ahead
Claude: [Calls sync_translations with dry_run=false]
Done! 30 keys translated. German file updated at messages/de.json.
The server automatically detects these i18n frameworks:
| Framework | Locale Patterns | Config Files |
|---|---|---|
| next-intl | messages/*.json, locales/*.json |
i18n.ts, next.config.js |
| i18next | public/locales/*/*.json, locales/*/*.json |
i18next.config.js, i18n.js |
| react-intl | src/lang/*.json, lang/*.json |
src/i18n.ts |
| iOS/macOS | .strings, .xcstrings, .stringsdict |
Info.plist |
| generic | Various common patterns | - |
npx is in your PATHnpx @langapi/mcp-server manually to testenv section, not argsproject_path explicitlyUse project-level config files (.mcp.json, .cursor/mcp.json) with different API keys per project.
For self-hosted or enterprise deployments:
{
"mcpServers": {
"langapi": {
"command": "npx",
"args": ["@langapi/mcp-server"],
"env": {
"LANGAPI_API_KEY": "your-api-key",
"LANGAPI_API_URL": "https://your-api-server.com"
}
}
}
}
LangAPI uses a credit-based billing system:
Get your API key at langapi.io.
MIT
Run in your terminal:
claude mcp add langapi-mcp-server -- npx Security
Low riskAutomated heuristic from public metadata — not a security guarantee.