watchcheck
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., "@watchcheckScan for Chinese enterprise monitoring tools"
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.
watchcheck ๐
English | ็ฎไฝไธญๆ
See what's actually running on your Mac โ and who's watching.
watchcheck reads the processes on your Mac (read-only) and turns cryptic names into plain language: what each one is, who makes it, and โ its specialty โ whether it's endpoint-monitoring software (EDR / DLP / MDM / network & print auditing). It has first-class coverage of Chinese enterprise monitoring agents (ๆทฑไฟกๆ Sangfor, ไบฟ่ต้ ESafeNet, IP-Guard, ๅฅๅฎไฟก, 360, ่่ฝฏ, ๅคฉ็ฉบๅซๅฃซ, ๅไฟกๆบ, and other domestic EDR/DLP/MDM tools) that Western tools โ Little Snitch, KnockKnock, even general-purpose LLMs โ consistently misidentify or don't know at all.
Two ways to use it
One read-only engine, two front-ends โ pick either or both:
๐ฅ๏ธ Live panel | ๐ค MCP server | |
What | A local, auto-refreshing dashboard that reads your current processes โ like Activity Monitor, but it explains each one and flags monitoring software | Plugs into your AI assistant (Claude, Cursor, โฆ) so the LLM can read your live processes and answer questions about them |
For | Anyone โ no AI, no account, no setup beyond install | People who live in an AI client and want to ask in their own words |
Run |
| add to your MCP config, then ask Claude |
Network | none โ binds | none โ local stdio |
watchcheck is read-only and honest by design. It identifies software and describes what that class of software is capable of per vendor docs. It does not prove any tool is actively capturing you right now, and it cannot see the content of any data being sent. It is a transparency tool, not a way to evade legitimate corporate policy. On a company-managed device, removing or tampering with required software may violate your employment agreement.
Related MCP server: Screeny MCP Server
Install
Requires Python 3.10+ and macOS.
# with uv (recommended)
uv tool install watchcheck # once published
# or from source
git clone https://github.com/derkcc/watchcheck && cd watchcheck
uv venv --python 3.12 && uv pip install -e .๐ฅ๏ธ The live panel
A local, read-only dashboard that re-collects your processes / CPU / memory / GPU
every couple of seconds and explains them. Binds 127.0.0.1 only โ never touches
the network, never modifies anything.
watchcheck panel # opens http://127.0.0.1:8787/
watchcheck panel --lang en --interval 2 --port 8787Activity-Monitor-style tabs โ Monitoring / CPU / Memory / GPU / All processes โ where every process row carries an inline plain-language explanation and a ๐ข/๐ด/โช marker; monitoring software is flagged with its capabilities and evidence.
Prefer a static, shareable file instead of a live server?
watchcheck report # one-shot HTML snapshot โ ~/watchcheck-report.html
watchcheck report --lang en # English (~/watchcheck-report.en.html)Both are bilingual (--lang zh|en). GPU is reported system-wide โ macOS exposes
no per-process GPU without sudo.
๐ค The MCP server
Let your AI assistant read and explain your live processes. Add to your MCP client
config โ Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json):
{
"mcpServers": {
"watchcheck": { "command": "watchcheck" }
}
}From source (no install):
{
"mcpServers": {
"watchcheck": {
"command": "uv",
"args": ["--directory", "/path/to/watchcheck", "run", "watchcheck"]
}
}
}Then just ask:
"Scan my Mac โ is my company monitoring me, and what can they see?" "What is
acnvmagent?" "What monitoring tools does watchcheck know about?"
How it works (no screenshots needed)
You never copy process names or paste screenshots. The server runs on your Mac and reads the live process list itself; Claude calls it and explains the result.
flowchart TD
A["You โ ask in plain language<br/>(no screenshots, no copy-paste)"] --> B["Claude picks a tool:<br/>scan / overview / explain_process"]
B --> C["watchcheck runs locally on your Mac<br/>reads processes via ps / launchd / certs<br/>read-only ยท no network ยท nothing modified"]
C --> D["Returns structured facts:<br/>vendor / type / capabilities / CPU ยท memory<br/>(things it doesn't know are marked 'unknown')"]
D --> E["Claude explains in plain language<br/>and answers follow-ups"]
E --> ADivision of labor: watchcheck reads the processes and supplies the facts
(from its signature DB); Claude orchestrates the calls, turns the facts into
plain language, and fills in anything marked unknown from its own knowledge.
Tools exposed
Tool | What it does |
| Read-only scan โ identified monitoring software with evidence, capabilities, privacy impact |
| Typed breakdown of everything running (Apple system / browser / cloud / your own VPN / monitoring / unknown โฆ), duplicates collapsed, with CPU/memory/GPU |
| Explain one process / label / bundle id in plain language |
| The full catalog of what watchcheck can identify (transparency) |
| Raw collected artifacts, no matching (for investigating unknowns / contributing) |
How it works
watchcheck reads only what macOS already exposes โ nothing is modified, no files are read for content, no network calls:
Source | Command | What it reveals |
Processes |
| Running agents + CPU / memory |
Persistence | LaunchDaemons/Agents plists | What auto-starts |
System extensions |
| Network / endpoint-security filters |
Kernel extensions |
| Kernel-level agents (highest privilege) |
MDM |
| DEP / MDM enrollment |
Certificates |
| Corporate root CAs (HTTPS interception) |
GPU |
| System-wide GPU utilization |
It then matches these against two data files: a curated, community-maintained
monitoring signature DB
(signatures.yaml โ the part that knows
Chinese enterprise tools) and a common-process catalog
(common_processes.yaml โ everyday
macOS processes), so it can reassure you that most of what's running is normal
and clearly flag what isn't. The signature DB is the whole point; everything else
is a thin, replaceable shell.
Contributing signatures (the important part)
Coverage of Chinese enterprise tools on macOS is the gap, and it's where you can
help most. If raw_inventory (or the panel's "unknown" rows) shows something
watchcheck doesn't recognize:
Find the artifact (process name, launchd label, bundle id, kext id, cert CN, path).
Add an entry to
signatures.yamlfollowing the schema and the honesty rules at the top of that file.Set
verified: trueonly if you confirmed it on a real machine.Open a PR. See CONTRIBUTING.md.
Signatures are facts about software, contributed by people who see it in the wild. That's the moat โ and it only grows with help.
Roadmap
Windows + Linux collectors
Optional
outbound_activity(which monitoring processes have live connections โ volume/destination only, never content)Wider Chinese-vendor macOS signatures
Per-process CPU sparklines in the live panel
License
MIT. See LICENSE.
Vendor and product names are used nominatively to identify software. No affiliation with or endorsement by any vendor is implied.
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/derkcc/watchcheck'
If you have feedback or need assistance with the MCP directory API, please join our Discord server