MCP Experiments
Allows executing AppleScript and bash commands on macOS, enabling control of system functions, applications, and scripts.
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 ExperimentsCould you please say 'Hello World!'"
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.
MCP Experiments
This repository contains some MCP (Model Context Protocol) servers I've been playing around with for executing Bash and AppleScript commands from large language models (LLMs) on a Mac. I tested it using the Claude Desktop client.
Example Usage
Once the tool is properly configured and loaded into Claude Desktop, you can ask Claude to do new things. The tools available in restricted mode include:
say: Could you please say "Hello World!"whoami: Which user am I running as?
In arbitrary execution mode (described below), you can ask Claude to perform more complicated actions.
Related MCP server: Command-Line MCP Server
Requirements
macOS (Required for AppleScript tool)
Claude Desktop, or other MCP client
Python 3.13 or higher
mcppackage for Pythonpytestpackage for tests
Installation
Clone the repository:
git clone .../mcp-experiments cd mcp-experimentsCreate and activate a virtual environment:
python3 -m venv .venv source .venv/bin/activateInstall the required dependencies:
pip install -r requirements.txtConfigure Claude Desktop for Mac to load the servers.
i. Modify the configuration file located at:
~/Library/Application Support/Claude/claude_desktop_config.json.ii. An example configuration is provided in
claude_decktop_config.example.jsonin this repository.iii. Ensure the
commandandargsfields point to the correct Python interpreter and script path.iv. Ensure that
MCP_EXECUTION_MODEis set to your desired safety level.
{
"mcpServers": {
"applescript": {
"command": "/path/to/mcp-experiments/.venv/bin/python",
"args": [
"/path/to/mcp-experiments/applescript.py"
],
"env": {
"MCP_EXECUTION_MODE": "restricted"
}
},
"bash": {
"command": "/path/to/mcp-experiments/.venv/bin/python",
"args": [
"/path/to/mcp-experiments/bash.py"
],
"env": {
"MCP_EXECUTION_MODE": "restricted"
}
}
}
}Arbitrary Execution Mode
Setting the environment variableMCP_EXECUTION_MODE to arbitrary will allow this server to execute arbitrary code generated by the client (LLM) on your computer. This is a security concern and may result in unintended consequences. Please consider using a sandbox to play around with this mode.
TO enable arbitrary execution mode, set the environment variable MCP_EXECUTION_MODE to arbitrary. Two more tools are then exposed to the client:
execute_bash: Runs arbitrary bash script as the current user and returns the result.execute_applescript: Runs arbitrary AppleScript script as the current user and returns the result.
File Structure
applescript.py: A server script that defines theexecute_applescripttool, which uses AppleScript to complete tasks.bash.py: A server script that defines theexecute_bashtool, which uses bash to complete tasks.claude_desktop_config.example.json: Example configuration file for the MCP server. Yours may be located in~/Library/Application Support/Claude.requirements.txt: Python dependencies for the project.test: Pytest unit tests for the applescript and bash tools.
License
This project is licensed under the MIT License. See the LICENSE file for details.
Credits
This project was created by Jordan Perr-Sauer. Github Copilot (with GPT-4o and Claude 3.5 Sonnet) was used to generate some of the content in this repository.
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/jordanperr/mcp-experiments'
If you have feedback or need assistance with the MCP directory API, please join our Discord server