Skip to main content

ACMS is a Model Context Protocol (MCP) server that provides programmatic access to Apple's container CLI tool on macOS.

Project description

ACMS (Apple Container MCP Server)

ACMS is a Model Context Protocol (MCP) server that provides programmatic access to Apple's container CLI tool on macOS. ACMS can be run locally or accessed remotely via HTTP/S.

The point of ACMS is to bring attention to the Containerization package and cli efforts. Inspiration for ACMS came from coderunner.

Features (as pitched by Claude)

  • 50+ Container Operations across 9 functional categories
  • HTTP/WebSocket Transport via FastMCP for modern connectivity
  • Robust Parameter Validation supporting JSON strings and native arrays
  • Production-Ready with 100% tested functionality

Prerequisites

  • Mac with Apple Silicon
  • macOS 26+ - It can run on Sequoia with limitations.
  • Xcode 26 - required to compile containerization
  • Apple Containerization Framework - (required for container functionality)
  • Apple Container Cli - installed and in PATH
  • Python 3.8+ - with asyncio support

Quick Start

Install

Either clone the repository or pip install acms in a venv.

Start Apple Container Services

# Required for most operations
container system start

# Verify system status
container system status

Start ACMS Server

# Recommended: Use the startup script
./start-acms.sh

# Or start directly with custom options
python3 acms/acms.py --port 8765 --host 127.0.0.1 > acms.log 2>&1 &

Configure MCP Client

Add to your MCP client configuration:

claude mcp add --transport http acms http://localhost:8765/mcp

Usage Examples

"acms create an ubuntu x64 container ..."

Testing

ACMS includes comprehensive end-to-end testing, just tell Claude to run the "ACMS CLAUDE TEST GUIDE".

Security Considerations

This is not secure, especially if you run it on a remote Mac OS endpoint on your home net.

mcp-name: io.github.gattjoe/ACMS

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

acms-0.0.6.tar.gz (18.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

acms-0.0.6-py3-none-any.whl (16.6 kB view details)

Uploaded Python 3

File details

Details for the file acms-0.0.6.tar.gz.

File metadata

  • Download URL: acms-0.0.6.tar.gz
  • Upload date:
  • Size: 18.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for acms-0.0.6.tar.gz
Algorithm Hash digest
SHA256 6ed945b086713b565200e17aef58adced2028e330097ab9d09c18d9e2d6a577f
MD5 5d97646d0984d0e2902cd51138ea1775
BLAKE2b-256 13c2bf411d419f4cb3248c3b1e591c605dcca714050a98bae68caa5fa86f3994

See more details on using hashes here.

Provenance

The following attestation bundles were made for acms-0.0.6.tar.gz:

Publisher: main.yaml on gattjoe/ACMS

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file acms-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: acms-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 16.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for acms-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 7ab3219fdc576ca89b1977c6f404560d7464630045e16ecccf8bb9829814b466
MD5 7a7c8ca3e7f5fe3c1ea54eb6e7c78f1f
BLAKE2b-256 8c5ab6e1fdf877c6ccd5b36e37f83bdfb61013e7dfcc625bcd6f0c4dc748d2ab

See more details on using hashes here.

Provenance

The following attestation bundles were made for acms-0.0.6-py3-none-any.whl:

Publisher: main.yaml on gattjoe/ACMS

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page