Server data from the Official MCP Registry
A minimal, transparent PowerShell 7 MCP for Windows — one tool: raw exit code, stdout, stderr.
A minimal, transparent PowerShell 7 MCP for Windows — one tool: raw exit code, stdout, stderr.
pwsh-exec is a Windows-specific PowerShell execution MCP with appropriate scope and thoughtful security hardening for its intended purpose. The design is intentionally minimal (one tool) with clear limitations documented. However, the core functionality—arbitrary command execution via PowerShell—represents inherent risk that users must explicitly accept. Input validation is solid, but the lack of sandboxing and the ability to execute any PowerShell command limits the score. Logging and error handling are well-implemented. Supply chain analysis found 3 known vulnerabilities in dependencies (1 critical, 1 high severity). Package verification found 1 issue.
7 files analyzed · 11 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Set these up before or after installing:
Environment variable: PWSH_EXEC_DEFAULT_DIR
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-jason26214-pwsh-exec-mcp": {
"env": {
"PWSH_EXEC_DEFAULT_DIR": "your-pwsh-exec-default-dir-here"
},
"args": [
"pwsh-exec"
],
"command": "uvx"
}
}
}From the project's GitHub README.
A minimal, transparent PowerShell 7 MCP for Windows — one tool: run a command, get raw exit code / stdout / stderr back.
pwsh-exec is a minimal, transparent PowerShell 7 MCP server for Windows. It exposes a single tool, run_command, that runs a command in a fresh pwsh process and returns the raw exit_code, stdout, and stderr — nothing parsed, filtered, or reformatted.
command, timeout (seconds), optional working_directory.It gives any AI agent on Windows a real terminal: you send a command, you get back exactly what the terminal produced.
Feature-complete and stable. One tool, a frozen v1.0.0 API, 38 passing tests, in daily use driving real agent work since April 2026 with no known bugs. Reproducible bugs get fixed; the scope stays intentionally small — it does one thing.
pwsh) on PATH — this is the modern cross-platform PowerShell, not the built-in Windows PowerShell 5.1 (powershell.exe). Install it via winget install Microsoft.PowerShell or from the official install guide.uvx runner used below.No clone required — uvx fetches and runs it on demand. Register it with your MCP client (stdio transport):
Use this as the server's launch command:
uvx pwsh-exec
Edit claude_desktop_config.json:
{
"mcpServers": {
"pwsh-exec": {
"command": "cmd",
"args": ["/c", "uvx", "pwsh-exec"]
}
}
}
The
cmd /cwrapper is recommended on Claude Desktop: as an Electron app it has no console of its own, and launching a console program directly can leave child processes (pwsh → git and other external.exes) without a working console — flickering windows, lost stdout, PATH lookups failing.cmd.exeacquires the hidden console first and every child inherits it. This is the same pattern Desktop Commander and other Windows MCP servers use.
run_command| Parameter | Type | Required | Description |
|---|---|---|---|
command | string | yes | The PowerShell command or script to run. |
timeout | integer | yes | Timeout in seconds (not milliseconds). 1–300. |
working_directory | string | no | Absolute path. Defaults to the resolved working directory (see Configuration). |
The output is plain text: the exit code first, then labelled stdout and stderr sections (empty ones still show, so the two streams are never ambiguous), then a diagnostic footer with a timestamp and elapsed time.
For example, calling run_command with command: "git status" returns the raw git output, untouched:
exit_code: 0
stdout:
On branch main
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: app.py
no changes added to commit (use "git add" and/or "git commit -a")
stderr:
(empty)
[2026-06-13 08:43:11 | 625ms]
Nothing is summarised or filtered. A non-zero exit code, a syntax error written to stderr, an empty result — all of it comes back as the terminal produced it. Output longer than 500 lines per stream is trimmed to the first and last 250 lines so it never floods the context window.
Running a shell on Windows from a host process is full of small traps. pwsh-exec handles them so the agent doesn't have to:
REG_EXPAND_SZ values like %USERPROFILE%\... are expanded correctly).pwsh plus any children it spawned, e.g. node, python), leaving no orphans.The small scope is the design. pwsh-exec deliberately does not do:
cd and variables don't carry over. Pass working_directory, or combine dependent steps into one command.working_directory defaults to a resolved directory, chosen in this order (highest priority first):
working_directory argument passed on the call.PWSH_EXEC_DEFAULT_DIR environment variable, if set.%TEMP%\pwsh-exec.To change the default, set PWSH_EXEC_DEFAULT_DIR in your MCP client's config:
{
"mcpServers": {
"pwsh-exec": {
"command": "cmd",
"args": ["/c", "uvx", "pwsh-exec"],
"env": { "PWSH_EXEC_DEFAULT_DIR": "D:\\scratch" }
}
}
}
An unset or blank value falls back to the built-in default. The default lives under %TEMP% (its own subfolder, so you can wipe it wholesale) rather than scattering files into the shared temp directory.
MIT © 2026 Jason26214
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Web content fetching and conversion for efficient LLM usage
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.