Prompt Engine
STDIOMCP server for managing dynamic prompt templates with Go template engine
MCP server for managing dynamic prompt templates with Go template engine
A Model Control Protocol (MCP) server for managing and serving dynamic prompt templates using elegant and powerful text template engine. Create reusable, logic-driven prompts with variables, partials, and conditionals that can be served to any compatible MCP client like Claude Code, Claude Desktop, Gemini CLI, VSCode with Copilot, etc.
_header.tmpl) and reuse them across your prompts.Install using Go:
go install github.com/vasayxtx/mcp-prompt-engine@latest
(For other methods like Docker or pre-built binaries, see the Installation section below.)
Create a prompts directory and add a template file. Let's create a prompt to help write a Git commit message.
First, create a reusable partial named prompts/_git_commit_role.tmpl:
```go
{{ define "_git_commit_role" }}
You are an expert programmer specializing in writing clear, concise, and conventional Git commit messages.
Commit message must strictly follow the Conventional Commits specification.
The final commit message you generate must be formatted exactly as follows:
```
<type>: A brief, imperative-tense summary of changes
[Optional longer description, explaining the "why" of the change. Use dash points for clarity.]
```
{{ if .type -}}
Use {{.type}} as a type.
{{ end }}
{{ end }}
```
Now, create a main prompt prompts/git_stage_commit.tmpl that uses this partial:
```go
{{- /* Commit currently staged changes */ -}}
{{- template "_git_commit_role" . -}}
Your task is to commit all currently staged changes.
To understand the context, analyze the staged code using the command: `git diff --staged`
Based on that analysis, commit staged changes using a suitable commit message.
```
Validate your prompt to ensure it has no syntax errors:
mcp-prompt-engine validate git_stage_commit ✓ git_stage_commit.tmpl - Valid
Add MCP Server to your MCP client. See Connecting to Clients for configuration examples.
Your git_stage_commit prompt will now be available in your client!
For example, in Claude Desktop, you can select the git_stage_commit prompt, provide the type MCP Prompt argument and get a generated prompt that will help you to do a commit with a perfect message.
In Claude Code or Gemini CLI, you can start typing /git_stage_commit and it will suggest the prompt with the provided arguments that will be executed after you select it.
Download the latest release for your OS from the GitHub Releases page.
git clone https://github.com/vasayxtx/mcp-prompt-engine.git cd mcp-prompt-engine make build
A pre-built Docker image is available. Mount your local prompts and logs directories to the container.
# Pull and run the pre-built image from GHCR docker run -i --rm \ -v /path/to/your/prompts:/app/prompts:ro \ -v /path/to/your/logs:/app/logs \ ghcr.io/vasayxtx/mcp-prompt-engine
You can also build the image locally with make docker-build.
Create a directory to store your prompt templates. Each template should be a .tmpl file using Go's text/template syntax with the following format:
{{/* Brief description of the prompt */}} Your prompt text here with {{.template_variable}} placeholders.
The first line comment ({{/* description */}}) is used as the prompt description, and the rest of the file is the prompt template.
Partial templates should be prefixed with an underscore (e.g., _header.tmpl) and can be included in other templates using {{template "partial_name" .}}.
The server uses Go's text/template engine, which provides powerful templating capabilities:
{{.variable_name}} - Access template variables{{.date}} - Current date and time{{if .condition}}...{{end}}, {{if .condition}}...{{else}}...{{end}}{{if and .condition1 .condition2}}...{{end}}, {{if or .condition1 .condition2}}...{{end}}{{range .items}}...{{end}}{{template "partial_name" .}} or {{template "partial_name" dict "key" "value"}}See the Go text/template documentation for more details on syntax and features.
The server automatically parses argument values as JSON when possible, enabling rich data types in templates:
true, false → Go boolean values42, 3.14 → Go numeric values["item1", "item2"] → Go slices for use with {{range}}{"key": "value"} → Go maps for structured dataThis allows for advanced template operations like:
{{range .items}}Item: {{.}}{{end}} {{if .enabled}}Feature is enabled{{end}} {{.config.timeout}} seconds
To disable JSON parsing and treat all arguments as strings, use the --disable-json-args flag for the serve and render commands.
The CLI is your main tool for managing and testing templates.
By default, it looks for templates in the ./prompts directory, but you can specify a different directory with the --prompts flag.
1. List Templates
# See a simple list of available prompts mcp-prompt-engine list # See a detailed view with descriptions and variables mcp-prompt-engine list --verbose
2. Render a Template
Render a prompt directly in your terminal, providing arguments with the -a or --arg flag.
It will automatically inject environment variables as fallbacks for any missing arguments. For example, if you have an environment variable TYPE=fix, it will be injected into the template as {{.type}}.
# Render the git commit prompt, providing the 'type' variable mcp-prompt-engine render git_stage_commit --arg type=feat
3. Validate Templates
Check all your templates for syntax errors. The command will return an error if any template is invalid.
# Validate all templates in the directory mcp-prompt-engine validate # Validate a single template mcp-prompt-engine validate git_stage_commit
4. Start the Server
Run the MCP server to make your prompts available to clients.
# Run with default settings (looks for ./prompts) mcp-prompt-engine serve # Specify a different prompts directory and a log file mcp-prompt-engine --prompts /path/to/prompts serve --log-file ./server.log
To use this engine with any client that supports MCP Prompts, add a new entry to its MCP servers configuration.
Global configuration locations (MacOS):
~/.claude.json (mcpServers section)~/Library/Application\ Support/Claude/claude_desktop_config.json (mcpServers section)~/.gemini/settings.json (mcpServers section)Example for a local binary:
{ "prompts": { "command": "/path/to/your/mcp-prompt-engine", "args": [ "--prompts", "/path/to/your/prompts", "serve", "--quiet" ] } }
Example for Docker:
{ "mcp-prompt-engine-docker": { "command": "docker", "args": [ "run", "-i", "--rm", "-v", "/path/to/your/prompts:/app/prompts:ro", "-v", "/path/to/your/logs:/app/logs", "ghcr.io/vasayxtx/mcp-prompt-engine" ] } }
This project is licensed under the MIT License - see the LICENSE file for details.