mcp-local-files
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-local-fileslist the files in my project folder"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Local Files MCP
English | 日本語
A small local MCP server that lets ChatGPT/Codex read, search, and edit a single allowed folder on this Windows machine through OpenAI Secure MCP Tunnel.
This project is intentionally simple and local-first. The server runs over stdio, and tunnel-client.exe forwards ChatGPT MCP requests to it. The exposed folder is controlled by root-dir.txt, not hardcoded in server.js.
Current folder
This repository lives at:
%USERPROFILE%\mcp-local-filesThe folder currently exposed to ChatGPT/Codex is stored in:
%USERPROFILE%\mcp-local-files\root-dir.txtTo see or change it manually:
type %USERPROFILE%\mcp-local-files\root-dir.txt
notepad %USERPROFILE%\mcp-local-files\root-dir.txtRelated MCP server: Sparkle MCP Server
Files
server.js MCP stdio server implementation
cli.js npm CLI wrapper and tunnel-client downloader
package.json Node.js dependencies and npm scripts
run-mcp.cmd Starts the MCP server using ROOT_DIR from root-dir.txt
mcp-here.cmd Writes the current terminal directory into root-dir.txt
root-dir.txt Current allowed folder for Local Files MCP
AGENTS.md Instructions for Codex/agents working on this folderInstall
From PowerShell:
cd %USERPROFILE%\mcp-local-files
npm installWhen installed as an npm package, the CLI command is:
mcp-local-files --helpFirst-time tunnel setup
The CLI can guide the first tunnel profile setup:
mcp-local-files setupIt will:
download OpenAI tunnel-client if needed
open the OpenAI Tunnels page
open the OpenAI Runtime API keys page
ask for a tunnel_id and Runtime API key
create the default tunnel-client profile
save the Runtime API key outside this project folderOpenAI setup pages:
https://platform.openai.com/settings/organization/tunnels
https://platform.openai.com/settings/organization/api-keysThe default profile is:
local-filesThe Runtime API key is stored in the user's private config file:
%USERPROFILE%\.mcp-local-files\secrets.jsonDo not commit this file. It is intentionally outside the npm package folder.
Non-interactive values can be passed like this:
mcp-local-files setup --profile local-files --tunnel-id tunnel_xxx --no-openThe Runtime API key is still requested interactively so it does not appear in shell history.
On Windows, the default MCP command saved by setup is:
cmd /d /s /c "%USERPROFILE%/mcp-local-files/run-mcp.cmd"This keeps the existing run-mcp.cmd / root-dir.txt flow intact.
Change the exposed folder quickly
Open Windows Terminal, cd into the folder you want ChatGPT/Codex to access, then run:
%USERPROFILE%\mcp-local-files\mcp-here.cmdExample:
cd C:\path\to\your-project
%USERPROFILE%\mcp-local-files\mcp-here.cmdAfter changing the folder, restart the tunnel client so the new ROOT_DIR is applied.
With the npm CLI, this can be done in one step:
cd C:\path\to\your-project
mcp-local-files --tunnel-here--tunnel-here writes the current folder to the root file, downloads OpenAI tunnel-client on first use if needed, verifies its SHA256 checksum, and starts the existing tunnel profile.
Use a different profile when needed:
mcp-local-files --tunnel-here --profile local-filesStart the local MCP server directly
For a local smoke test:
cmd /d /s /c "%USERPROFILE%/mcp-local-files/run-mcp.cmd"The process should keep running. Stop it with Ctrl+C.
The npm CLI can also start the stdio server directly:
mcp-local-files --root C:\path\to\folderRun through OpenAI Tunnel
The profile already created is:
local-filesNormal run command:
cd C:\path\to\tunnel-client-folder
.\tunnel-client.exe run --profile local-filesThe npm CLI can download and run OpenAI tunnel-client automatically:
mcp-local-files tunnel run --profile local-filesIf mcp-local-files setup saved a Runtime API key for that profile, the CLI passes it to tunnel-client as CONTROL_PLANE_API_KEY only for the child process.
On first use, it downloads the matching platform zip from the official openai/tunnel-client GitHub release, downloads SHA256SUMS.txt, verifies the archive, extracts the binary into the user cache, and runs it from there.
Default cache locations:
Windows: %USERPROFILE%\.cache\mcp-local-files\tunnel-client
macOS/Linux: ~/.cache/mcp-local-files/tunnel-clientTo use an existing binary instead of auto-download:
mcp-local-files --tunnel-client C:\path\to\tunnel-client.exe tunnel run --profile local-filesUseful diagnostic command:
cd C:\path\to\tunnel-client-folder
.\tunnel-client.exe doctor --profile local-files --explainIf the profile must be recreated, prefer forward slashes in the MCP command to avoid Windows escaping problems:
.\tunnel-client.exe init --sample sample_mcp_stdio_local --profile local-files --tunnel-id tunnel_xxx --mcp-command 'cmd /d /s /c "%USERPROFILE%/mcp-local-files/run-mcp.cmd"'Do not commit or paste Runtime API keys into this project. Set them only in the terminal environment when needed.
The tunnel-client binary is not bundled in this package. It is fetched from OpenAI's public release artifacts when the CLI needs it. Keep the Apache-2.0 LICENSE and OpenAI NOTICE terms in mind if redistributing downloaded artifacts yourself.
Exposed MCP tools
The server registers these tools:
list_files List files and folders inside ROOT_DIR
read_file Read UTF-8 text files inside ROOT_DIR
search_files Search text files inside ROOT_DIR
write_file Create or overwrite UTF-8 text files inside ROOT_DIR
replace_in_file Replace exact text inside a UTF-8 text file inside ROOT_DIR
read_binary_file_base64 Read a binary file inside ROOT_DIR and return base64
write_base64_file Decode base64 and write a binary file inside ROOT_DIRBinary file tools
Use these only for files that must be transferred as bytes, such as PNG, JPEG, WebP, GIF, ZIP, or PDF files.
read_binary_file_base64 input:
{
"path": "images/example.png",
"maxBytes": 10000000
}It returns path, size, base64, encoding: "base64", and a simple mimeType guess. If the file is larger than maxBytes, the server returns an error instead of truncating the data.
write_base64_file input:
{
"path": "images/example.png",
"base64": "iVBORw0KGgo...",
"overwrite": false
}It creates parent folders when needed. Existing files are protected unless overwrite is explicitly set to true. Decoded binary writes are capped at 25 MB.
Safety model
The server is scoped to one folder only. All paths passed to tools must be relative to ROOT_DIR.
The server blocks:
absolute paths
.. path traversal outside ROOT_DIR
text reads for non-allowlisted file types
large text search over files bigger than 2 MB
binary reads above the requested maxBytes limit
binary writes above the server write-size limitThe directory walker skips:
node_modules
.git
.venvThis is intentional. Do not expose C:\, the full user profile, or folders containing secrets unless the user explicitly requests it and understands the risk.
Troubleshooting
If ChatGPT says connector creation failed and the tunnel log shows file already closed, usually the local MCP process exited immediately. Run this first:
cmd /d /s /c "%USERPROFILE%/mcp-local-files/run-mcp.cmd"If the log says the command is not recognized, check the profile command path. Prefer this form:
cmd /d /s /c "%USERPROFILE%/mcp-local-files/run-mcp.cmd"If ROOT_DIR is required appears, check run-mcp.cmd and root-dir.txt.
If Node cannot find packages, run:
cd %USERPROFILE%\mcp-local-files
npm installNotes
Keep the MCP server stdio-clean. Do not print normal logs to stdout from server.js, because stdout is used by the MCP protocol. Use stderr only for critical startup errors.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/YoshiaKefasu/mcp-local-files'
If you have feedback or need assistance with the MCP directory API, please join our Discord server