Skip to main content
Glama

Playwright MCP for macOS

by mb-dev
pyproject.tomlโ€ข5.15 kB
[project] name = "macos-ui-automation-mcp" version = "0.2.0" description = "MCP server for macOS UI automation with Claude Desktop/Code integration, plus Python library and CLI interfaces" authors = [{name = "mochen"}] readme = "README.md" requires-python = ">=3.10" keywords = ["mcp", "macos", "automation", "ui", "accessibility", "claude", "jsonpath"] classifiers = [ "Development Status :: 4 - Beta", "Intended Audience :: Developers", "License :: OSI Approved :: MIT License", "Operating System :: MacOS", "Programming Language :: Python :: 3", "Programming Language :: Python :: 3.10", "Programming Language :: Python :: 3.11", "Programming Language :: Python :: 3.12", "Programming Language :: Python :: 3.13", "Topic :: Software Development :: Libraries :: Python Modules", "Topic :: System :: Systems Administration", "Topic :: Desktop Environment :: Window Managers", "Topic :: Scientific/Engineering :: Human Machine Interfaces", "Environment :: MacOS X" ] dependencies = [ "pydantic>=2.10.0", "python-jsonpath>=1.0.0", "pyobjc-core>=10.0", "pyobjc-framework-cocoa>=10.0", "pyobjc-framework-applicationservices>=10.0", "typing-extensions>=4.0.0", "mcp[cli]>=1.0.0", ] [project.scripts] macos-ui-automation = "macos_ui_automation.cli:main" macos-ui-automation-mcp = "macos_ui_automation.interfaces.mcp_server:main" [project.urls] Homepage = "https://github.com/mb-dev/macos-ui-automation-mcp" Repository = "https://github.com/mb-dev/macos-ui-automation-mcp.git" Issues = "https://github.com/mb-dev/macos-ui-automation-mcp/issues" Documentation = "https://github.com/mb-dev/macos-ui-automation-mcp#readme" [build-system] requires = ["hatchling"] build-backend = "hatchling.build" [tool.hatch.build.targets.wheel] packages = ["src/macos_ui_automation"] [tool.mypy] python_version = "0.2.0" warn_return_any = true warn_unused_configs = true disallow_untyped_defs = true strict = true # Ignore PyObjC modules that don't have type stubs [[tool.mypy.overrides]] module = [ "ApplicationServices", "ApplicationServices.*", "Cocoa", "Cocoa.*", "Quartz", "Quartz.*", "PyObjCCore", "PyObjCCore.*" ] ignore_missing_imports = true # Less strict typing for bridge modules that interface with PyObjC [[tool.mypy.overrides]] module = "macos_ui_automation.bridges.real_bridge" warn_return_any = false disallow_any_unimported = false [tool.ruff] line-length = 88 target-version = "0.2.0" [tool.ruff.lint] select = ["E", "F", "W", "I", "N", "UP", "YTT", "S", "BLE", "FBT", "B", "A", "C4", "DTZ", "T10", "EM", "EXE", "FA", "ICN", "G", "INP", "PIE", "T20", "PYI", "PT", "Q", "RSE", "RET", "SLF", "SIM", "TID", "TCH", "INT", "ARG", "PTH", "ERA", "PD", "PGH", "PL", "TRY", "FLY", "NPY", "PERF", "RUF"] ignore = [ "S101", # assert-used - pytest uses asserts "T201", # print-found - CLI tool needs print statements "PLR0913", # too-many-arguments - acceptable for factory functions "PLR0915", # too-many-statements - acceptable for complex functions "COM812", # trailing-comma-missing - conflicts with formatter "ISC001", # implicit-string-concatenation - conflicts with formatter "PLW0603", # global-statement - acceptable for singleton/factory patterns "TRY300", # try-consider-else - acceptable for readable try-return patterns "ERA001", # commented-out-code - acceptable for documentation/safety comments "PLR0912", # too-many-branches - acceptable for CLI command handlers "PLR0911", # too-many-returns - acceptable for complex control flow "PLC0415", # import-outside-top-level - required for conditional PyObjC imports "SLF001", # private-member-access - required for PyObjC bridge implementation "RUF001", # ambiguous-unicode-character - acceptable for emoji in examples "BLE001", # blind-except - acceptable for top-level exception handlers "EXE001", # shebang-not-executable - example files don't need to be executable ] [tool.ruff.lint.per-file-ignores] "tests/**/*.py" = [ "FBT001", "FBT002", "FBT003", # Boolean arguments acceptable in test fixtures "PLR2004", # Magic values acceptable in tests "E501", # Line length acceptable in test data ] "examples/**/*.py" = [ "FBT001", "FBT002", "FBT003", # Boolean arguments acceptable in examples "PLR2004", # Magic values acceptable in examples "E501", # Line length acceptable in example code ] "src/macos_ui_automation/core/*.py" = [ "FBT001", "FBT002", # Boolean arguments acceptable in core API functions "E501", # Line length acceptable for complex conditions ] "src/macos_ui_automation/selectors/*.py" = [ "E501", # Line length acceptable for JSONPath expressions ] [tool.ruff.format] quote-style = "double" indent-style = "space" skip-magic-trailing-comma = false line-ending = "auto" [dependency-groups] dev = [ "pytest>=8.4.1", "pytest-cov>=4.0.0", ] lint = [ "ruff>=0.1.0", "mypy>=1.0.0", ] [tool.uv] dev-dependencies = [ "pytest>=8.4.1", "pytest-cov>=4.0.0", "ruff>=0.1.0", "mypy>=1.0.0", ]

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/mb-dev/macos-ui-automation-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server