Lara Translate logo

Lara Translate

official
other

MCP Server for Lara Translate API, enabling powerful translation capabilities with support for language detection and context-aware translations.

Lara Translate MCP Server

A Model Context Protocol (MCP) Server for Lara Translate API, enabling powerful translation capabilities with support for language detection, context-aware translations and translation memories.
License Docker Pulls npm downloads

πŸ“š Table of Contents

πŸ“– Introduction

<details> <summary><strong>What is MCP?</strong></summary>
Model Context Protocol (MCP) is an open standardized communication protocol that enables AI applications to connect with external tools, data sources, and services. Think of MCP like a USB-C port for AI applications - just as USB-C provides a standardized way to connect devices to various peripherals, MCP provides a standardized way to connect AI models to different data sources and tools.
Lara Translate MCP Server enables AI applications to access Lara Translate's powerful translation capabilities through this standardized protocol.
More info about Model Context Protocol on: https://modelcontextprotocol.io/
</details> <details> <summary><strong>How Lara Translate MCP Works</strong></summary>
Lara Translate MCP Server implements the Model Context Protocol to provide seamless translation capabilities to AI applications. The integration follows this flow:
  1. Connection Establishment: When an MCP-compatible AI application starts, it connects to configured MCP servers, including the Lara Translate MCP Server
  2. Tool & Resource Discovery: The AI application discovers available translation tools and resources provided by the Lara Translate MCP Server
  3. Request Processing: When translation needs are identified:
    • The AI application formats a structured request with text to translate, language pairs, and optional context
    • The MCP server validates the request and transforms it into Lara Translate API calls
    • The request is securely sent to Lara Translate's API using your credentials
  4. Translation & Response: Lara Translate processes the translation using advanced AI models
  5. Result Integration: The translation results are returned to the AI application, which can then incorporate them into its response
This integration architecture allows AI applications to access professional-grade translations without implementing the API directly, while maintaining the security of your API credentials and offering flexibility to adjust translation parameters through natural language instructions.
</details> <details> <summary><strong>Why to use Lara inside an LLM</strong></summary>
Integrating Lara with LLMs creates a powerful synergy that significantly enhances translation quality for non-English languages.

Why General LLMs Fall Short in Translation

While large language models possess broad linguistic capabilities, they often lack the specialized expertise and up-to-date terminology required for accurate translations in specific domains and languages.

Lara’s Domain-Specific Advantage

Lara overcomes this limitation by leveraging Translation Language Models (T-LMs) trained on billions of professionally translated segments. These models provide domain-specific machine translation that captures cultural nuances and industry terminology that generic LLMs may miss. The result: translations that are contextually accurate and sound natural to native speakers.

Designed for Non-English Strength

Lara has a strong focus on non-English languages, addressing the performance gap found in models such as GPT-4. The dominance of English in datasets such as Common Crawl and Wikipedia results in lower quality output in other languages. Lara helps close this gap by providing higher quality understanding, generation, and restructuring in a multilingual context.

Faster, Smarter Multilingual Performance

By offloading complex translation tasks to specialized T-LMs, Lara reduces computational overhead and minimizes latencyβ€”a common issue for LLMs handling non-English input. Its architecture processes translations in parallel with the LLM, enabling for real-time, high-quality output without compromising speed or efficiency.

Cost-Efficient Translation at Scale

Lara also lowers the cost of using models like GPT-4 in non-English workflows. Since tokenization (and pricing) is optimized for English, using Lara allows translation to take place before hitting the LLM, meaning that only the translated English content is processed. This improves cost efficiency and supports competitive scalability for global enterprises.
</details>

πŸ›  Available Tools

Translation Tools

<details> <summary><strong>translate</strong> - Translate text between languages</summary>
Inputs:
  • text
    (array): An array of text blocks to translate, each with:
    • text
      (string): The text content
    • translatable
      (boolean): Whether this block should be translated
  • source
    (optional string): Source language code (e.g., 'en-EN')
  • target
    (string): Target language code (e.g., 'it-IT')
  • context
    (optional string): Additional context to improve translation quality
  • instructions
    (optional string[]): Instructions to adjust translation behavior
  • source_hint
    (optional string): Guidance for language detection
Returns: Translated text blocks maintaining the original structure
</details>

Translation Memories Tools

<details> <summary><strong>list_memories</strong> - List saved translation memories</summary>
Returns: Array of memories and their details
</details> <details> <summary><strong>create_memory</strong> - Create a new translation memory</summary>
Inputs:
  • name
    (string): Name of the new memory
  • external_id
    (optional string): ID of the memory to import from MyMemory (e.g., 'ext_my_[MyMemory ID]')
Returns: Created memory data
</details> <details> <summary><strong>update_memory</strong> - Update translation memory name</summary>
Inputs:
  • id
    (string): ID of the memory to update
  • name
    (string): The new name for the memory
Returns: Updated memory data
</details> <details> <summary><strong>delete_memory</strong> - Delete a translation memory</summary>
Inputs:
  • id
    (string): ID of the memory to delete
Returns: Deleted memory data
</details> <details> <summary><strong>add_translation</strong> - Add a translation unit to memory</summary>
Inputs:
  • id
    (string | string[]): ID or IDs of memories where to add the translation unit
  • source
    (string): Source language code
  • target
    (string): Target language code
  • sentence
    (string): The source sentence
  • translation
    (string): The translated sentence
  • tuid
    (optional string): Translation Unit unique identifier
  • sentence_before
    (optional string): Context sentence before
  • sentence_after
    (optional string): Context sentence after
Returns: Added translation details
</details> <details> <summary><strong>delete_translation</strong> - Delete a translation unit from memory</summary>
Inputs:
  • id
    (string): ID of the memory
  • source
    (string): Source language code
  • target
    (string): Target language code
  • sentence
    (string): The source sentence
  • translation
    (string): The translated sentence
  • tuid
    (optional string): Translation Unit unique identifier
  • sentence_before
    (optional string): Context sentence before
  • sentence_after
    (optional string): Context sentence after
Returns: Removed translation details
</details> <details> <summary><strong>import_tmx</strong> - Import a TMX file into a memory</summary>
Inputs:
  • id
    (string): ID of the memory to update
  • tmx
    (file path): The path of the TMX file to upload
  • gzip
    (boolean): Indicates if the file is compressed (.gz)
Returns: Import details
</details> <details> <summary><strong>check_import_status</strong> - Checks the status of a TMX file import</summary>
Inputs:
  • id
    (string): The ID of the import job
Returns: Import details
</details>

πŸš€ Getting Started

πŸ“‹ Requirements

  • Lara Translate API Credentials
  • An LLM client that supports Model Context Protocol (MCP), such as Claude Desktop, Cursors, or GitHub Copilot
  • NPX or Docker (depending on your preferred installation method)

πŸ”Œ Installation

Introduction

The installation process is standardized across all MCP clients. It involves manually adding a configuration object to your client's MCP configuration JSON file.
If you're unsure how to configure an MCP with your client, please refer to your MCP client's official documentation.
Lara Translate MCP supports multiple installation methods, including NPX and Docker.
Below, we'll use NPX as an example.

Installation & Configuration

Step 1: Open your client's MCP configuration JSON file with a text editor, then copy and paste the following snippet:
{
  "mcpServers": {
    "lara-translate": {
      "command": "npx",
      "args": [
        "-y",
        "@translated/lara-mcp@latest"
      ],
      "env": {
        "LARA_ACCESS_KEY_ID": "<YOUR_ACCESS_KEY_ID>",
        "LARA_ACCESS_KEY_SECRET": "<YOUR_ACCESS_KEY_SECRET>"
      }
    }
  }
}
Step 2: Replace
<YOUR_ACCESS_KEY_ID>
and
<YOUR_ACCESS_KEY_SECRET>
with your Lara Translate API credentials (refer to the Official Documentation for details).
Step 3: Restart your MCP client.

Verify Installation

After restarting your MCP client, you should see Lara Translate MCP in the list of available MCPs.
The method for viewing installed MCPs varies by client. Please consult your MCP client's documentation.
To verify that Lara Translate MCP is working correctly, try translating with a simple prompt:
Translate with Lara "Hello world" to Spanish
Your MCP client will begin generating a response. If Lara Translate MCP is properly installed and configured, your client will either request approval for the action or display a notification that Lara Translate is being used.

🧩 Installation Engines

<details> <summary><strong>Option 1: Using NPX</strong></summary>
This option requires Node.js to be installed on your system.
  1. Add the following to your MCP configuration file:
{
  "mcpServers": {
    "lara-translate": {
      "command": "npx",
      "args": ["-y", "@translated/lara-mcp@latest"],
      "env": {
        "LARA_ACCESS_KEY_ID": "<YOUR_ACCESS_KEY_ID>",
        "LARA_ACCESS_KEY_SECRET": "<YOUR_ACCESS_KEY_SECRET>"
      }
    }
  }
}
  1. Replace
    <YOUR_ACCESS_KEY_ID>
    and
    <YOUR_ACCESS_KEY_SECRET>
    with your actual Lara API credentials.
</details> <details> <summary><strong>Option 2: Using Docker</strong></summary>
This option requires Docker to be installed on your system.
  1. Add the following to your MCP configuration file:
{
  "mcpServers": {
    "lara-translate": {
      "command": "docker",
      "args": [
        "run",
        "-i",
        "--rm",
        "-e",
        "LARA_ACCESS_KEY_ID",
        "-e",
        "LARA_ACCESS_KEY_SECRET",
        "translatednet/lara-mcp:latest"
      ],
      "env": {
        "LARA_ACCESS_KEY_ID": "<YOUR_ACCESS_KEY_ID>",
        "LARA_ACCESS_KEY_SECRET": "<YOUR_ACCESS_KEY_SECRET>"
      }
    }
  }
}
  1. Replace
    <YOUR_ACCESS_KEY_ID>
    and
    <YOUR_ACCESS_KEY_SECRET>
    with your actual Lara API credentials.
</details> <details> <summary><strong>Option 3: Building from Source</strong></summary>

Using Node.js

  1. Clone the repository:
git clone https://github.com/translated/lara-mcp.git
cd lara-mcp
  1. Install dependencies and build:
# Install dependencies
pnpm install

# Build
pnpm run build
  1. Add the following to your MCP configuration file:
{
  "mcpServers": {
    "lara-translate": {
      "command": "node",
      "args": ["<FULL_PATH_TO_PROJECT_FOLDER>/dist/index.js"],
      "env": {
        "LARA_ACCESS_KEY_ID": "<YOUR_ACCESS_KEY_ID>",
        "LARA_ACCESS_KEY_SECRET": "<YOUR_ACCESS_KEY_SECRET>"
      }
    }
  }
}
  1. Replace:
    • <FULL_PATH_TO_PROJECT_FOLDER>
      with the absolute path to your project folder
    • <YOUR_ACCESS_KEY_ID>
      and
      <YOUR_ACCESS_KEY_SECRET>
      with your actual Lara API credentials.

Building a Docker Image

  1. Clone the repository:
git clone https://github.com/translated/lara-mcp.git
cd lara-mcp
  1. Build the Docker image:
docker build -t lara-mcp .
  1. Add the following to your MCP configuration file:
{
  "mcpServers": {
    "lara-translate": {
      "command": "docker",
      "args": [
        "run",
        "-i",
        "--rm",
        "-e",
        "LARA_ACCESS_KEY_ID",
        "-e",
        "LARA_ACCESS_KEY_SECRET",
        "lara-mcp"
      ],
      "env": {
        "LARA_ACCESS_KEY_ID": "<YOUR_ACCESS_KEY_ID>",
        "LARA_ACCESS_KEY_SECRET": "<YOUR_ACCESS_KEY_SECRET>"
      }
    }
  }
}
  1. Replace
    <YOUR_ACCESS_KEY_ID>
    and
    <YOUR_ACCESS_KEY_SECRET>
    with your actual credentials.
</details>

πŸ’» Popular Clients that supports MCPs

For a complete list of MCP clients and their feature support, visit the official MCP clients page.
ClientDescription
Claude DesktopDesktop application for Claude AI
CursorAI-first code editor
Cline for VS CodeVS Code extension for AI assistance
GitHub Copilot MCPVS Code extension for GitHub Copilot MCP integration
WindsurfAI-powered code editor and development environment

πŸ†˜ Support

  • For issues with Lara Translate API: Contact Lara Support
  • For issues with this MCP Server: Open an issue on GitHub

Related Servers

E

Everything

reference

Reference / test server with prompts, resources, and tools

View Details
M

Memory

reference

Knowledge graph-based persistent memory system

View Details
P

Puppeteer

reference

Browser automation and web scraping

View Details
S

Sentry

reference

Retrieving and analyzing issues from Sentry.io

View Details
S

Sequential Thinking

reference

Dynamic and reflective problem-solving through thought sequences

View Details