Provides a secure environment to execute arbitrary JavaScript code inside a sandboxed QuickJS WASM environment, capturing standard output, standard error, and execution errors.
Utilizes Node.js's built-in WASI implementation to instantiate and run the QuickJS WASM module, enabling secure JavaScript code execution with captured I/O.
Leverages WebAssembly to create a secure sandbox for JavaScript code execution through a pre-compiled QuickJS engine targeting the WebAssembly System Interface (WASI).
MCP QuickJS Runner
A server implementing the Model Context Protocol (MCP) that provides a tool to securely execute arbitrary JavaScript code within a QuickJS engine compiled to WebAssembly (WASM) and run using Node.js's built-in WASI implementation.
Description
This server acts as an MCP tool provider. It exposes a single tool, run_javascript_code, which takes a string of JavaScript code as input. The code is then executed inside a sandboxed QuickJS WASM environment. The server captures the standard output (stdout) and standard error (stderr) streams from the execution and returns them, along with any execution errors, back to the MCP client.
This allows language models or other MCP clients to safely execute potentially untrusted JavaScript code snippets without compromising the host system.
Features
Secure Execution: Runs JavaScript in a WASM sandbox using QuickJS and Node.js WASI.
Standard I/O Capture: Captures
stdoutandstderrfrom the executed JavaScript code.Error Reporting: Reports runtime errors from QuickJS and non-zero exit codes.
MCP Integration: Exposes functionality as a standard MCP tool over
stdio.Built with TypeScript: Provides type safety during development.
How it Works
WASM Module: Uses a pre-compiled QuickJS engine (
qjs-wasi.wasm) targeting the WebAssembly System Interface (WASI).Node.js WASI: Leverages the
node:wasimodule in Node.js to instantiate and run the WASM module.Stdio Redirection (Temporary Files): To capture
stdoutandstderrfrom the WASM environment, the server currently relies on the standard approach compatible withnode:wasi:A temporary directory is created on the host filesystem using
node:fs/promisesandnode:os.Temporary files for
stdoutandstderrare opened within this directory.The real OS file descriptors for these files are passed to the
WASIinstance during initialization (stdout: fd,stderr: fd).The QuickJS WASM module writes its output to these descriptors, which gets routed by WASI to the temporary files.
After execution finishes, the server closes the file handles and reads the content of the temporary files.
The temporary directory and files are cleaned up.
(Note: Attempts to use in-memory pipes or virtual filesystems like
MCP Communication: The server uses
@modelcontextprotocol/sdkto listen for MCP requests viastdioand respond with the execution results formatted according to the protocol.
Prerequisites
Node.js (v23.x or later recommended, check
node:wasicompatibility for your specific version)The QuickJS WASM file (
qjs-wasi.wasm) must be present in the same directory as the compiled server script (e.g.,./dist/qjs-wasi.wasmrelative to./dist/server.js). You may need to obtain or compile this separately.
Installation
Clone the repository (if applicable).
Install dependencies:
npm install
Usage
This server cannot be installed
local-only server
The server can only run on the client's local machine because it depends on local resources.
Provides secure execution of arbitrary JavaScript code within a sandboxed QuickJS WASM environment, allowing language models or other MCP clients to safely run JavaScript code snippets without compromising the host system.
Related MCP Servers
- Asecurity-licenseAqualityProvides a secure, isolated JavaScript execution environment with configurable time and memory limits for safely running code from Claude.Last updated -1135
- -security-license-qualityA secure MCP server that provides controlled ShellJS access for LLMs, enabling AI systems to safely execute shell commands and interact with the filesystem within a configurable security sandbox.
- Asecurity-licenseAqualityA secure JavaScript REPL server that enables executing code snippets in a sandboxed environment with memory protection, timeout handling, and comprehensive error reporting.Last updated -73,295108MIT License
- Asecurity-licenseAqualityA secure Node.js execution environment that allows coding agents and LLMs to run JavaScript dynamically, install NPM packages, and retrieve results while adhering to the Model Control Protocol.Last updated -7524