npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

cc2cc

v0.1.0

Published

File-based agent-to-agent messaging for Claude Code — multiple AI instances communicate via JSON files, MCP channels, and auto-wake on a single machine

Readme

CC2CC: Claude Code ↔ Claude Code Communication

File-based agent-to-agent communication between Claude Code instances running on the same machine.

Two Claude Code sessions can't talk to each other. CC2CC fixes that with a file mailbox + MCP push channel.

Extracted from a working multi-agent setup. Built on Claude Code hooks, MCP channels, and plain JSON files.

⚠️ Experimental: CC2CC relies on Claude Code's development channels — an experimental feature not yet publicly stable. You must launch Claude Code with the --dangerously-load-development-channels flag for channel push notifications to work. Without it, the MCP server starts but cannot push messages into the session.

Tested with Claude Code v2.1.86. Channel API may change in future versions.

Demo

5 Claude Code agents debating in split panes via cc2cc:

Use Cases

  • A devops agent and a coding agent collaborating on the same project
  • A monitoring agent that alerts a main agent when something breaks
  • Two agents with different tool access splitting a complex task
  • An always-on agent delegating subtasks to a specialist

Architecture

┌─────────────────┐                              ┌─────────────────┐
│  Claude Code A   │                              │  Claude Code B   │
│  (auto: brave-fox)│                             │  (auto: calm-owl)│
│                  │                              │                  │
│  MCP Server ◄────┼─── to-brave-fox/inbox/ ◄─────┼── send tool     │
│  (polls inbox)   │                              │                  │
│  send tool ──────┼──► to-calm-owl/inbox/ ───────┼──► MCP Server   │
│                  │                              │  (polls inbox)   │
│  Tools:          │    status/                   │  Tools:          │
│  send, broadcast │    brave-fox-heartbeat.json  │  send, broadcast │
│  reply, register │    calm-owl-heartbeat.json   │  reply, register │
│  list_agents     │                              │  list_agents     │
│  whoami          │                              │  whoami          │
└─────────────────┘                              └─────────────────┘

How it works: Agent A drops a JSON file into an inbox directory. Agent B's MCP server polls that directory, reads the message, and pushes it into B's session as a channel notification. B replies using an MCP tool, which writes a response back into A's inbox. Messages for offline agents wait in the inbox and get delivered on the next session start.

Quick Start

The easy way: copy this prompt, paste it into any Claude Code session — Claude does the rest!

Install cc2cc — a file-based agent-to-agent messaging system that lets
multiple Claude Code sessions communicate with each other on the same machine.

Steps:
1. Clone: git clone https://github.com/non4me/cc2cc.git ~/.cc2cc/repo
2. Install deps: cd ~/.cc2cc/repo/channel && npm install
3. Copy server files to bridge:
   cp ~/.cc2cc/repo/channel/server.mjs ~/.cc2cc/server.mjs
   cp ~/.cc2cc/repo/channel/names.mjs ~/.cc2cc/names.mjs
   cp ~/.cc2cc/repo/channel/package.json ~/.cc2cc/package.json
   cp -r ~/.cc2cc/repo/channel/node_modules ~/.cc2cc/node_modules
4. Create status dir: mkdir -p ~/.cc2cc/status
5. Add MCP server to ~/.claude.json (mcpServers section):
   "cc2cc": {
     "command": "node",
     "args": ["~/.cc2cc/server.mjs"],
     "env": { "CC2CC_BRIDGE_DIR": "~/.cc2cc" }
   }
6. Verify: run "node ~/.cc2cc/server.mjs" to check it starts without errors.

After install, restart Claude Code with:
claude --dangerously-load-development-channels server:cc2cc

Requirements

  • Claude Code (CLI)
  • Node.js ≥ 18 (for the MCP channel server)
  • Python 3.8+ (for scripts)

1. Clone and initialize

git clone https://github.com/non4me/cc2cc.git
cd cc2cc
pip install -e .
cc2cc init

2. Configure Claude Code

Add to ~/.claude/settings.json:

{
  "mcpServers": {
    "cc2cc": {
      "command": "node",
      "args": ["~/.cc2cc/server.mjs"],
      "env": {
        "CC2CC_BRIDGE_DIR": "~/.cc2cc"
      }
    }
  }
}

Every Claude Code instance you open will auto-register with a unique name and discover other agents automatically.

3. Open two terminals

# Terminal 1
claude --dangerously-load-development-channels server:cc2cc
# You'll see: [cc2cc] You are brave-fox. No other agents online

# Terminal 2
claude --dangerously-load-development-channels server:cc2cc
# You'll see: [cc2cc] You are calm-owl. Online agents: brave-fox
# Terminal 1 sees: [cc2cc] calm-owl joined

Note: The --dangerously-load-development-channels server:cc2cc flag is required for the MCP server to push incoming messages into your Claude Code session. Without it, agents can send messages but won't receive them in real time. Add --dangerously-skip-permissions for fully autonomous operation (no permission prompts).

4. Communicate (from inside Claude Code)

The agent can use MCP tools directly:

  • send(to="brave-fox", text="Hello!") — send to specific agent
  • broadcast(text="Deploy starting") — send to all
  • reply(msg_id="msg-xxx", text="Got it") — reply to a message
  • list_agents() — see who's online
  • whoami() — check your name
  • register(name="devops") — change your name

CC2CC vs Google A2A

| Feature | Google A2A | CC2CC | |---------|-----------|-------| | Transport | HTTP | Filesystem | | Setup | Service discovery, auth, endpoints | cc2cc init | | Dependencies | HTTP server per agent | Node.js (MCP server only) | | Offline delivery | Requires message broker | Built-in (files wait in inbox) | | Same-machine agents | Overkill | Purpose-built | | Cross-network agents | ✅ | ❌ (same filesystem required) |

CC2CC is not a replacement for A2A. It's for the common case where you have multiple Claude Code instances on the same machine that need to coordinate.

Repo Structure

cc2cc/
├── cc2cc/                      # Python package
│   ├── __init__.py
│   ├── core.py                 # Atomic writes, bridge path, size limits
│   ├── signing.py              # HMAC-SHA256 message signing
│   └── cli.py                  # Unified CLI entry point
├── pyproject.toml              # pip installable package
├── channel/
│   ├── server.mjs           # Unified MCP server (dynamic identity, multi-agent)
│   ├── names.mjs            # Name generation (adjective-animal dictionary)
│   └── package.json
├── scripts/
│   ├── init.py              # Bootstrap the bridge
│   ├── send.py              # Send a message
│   ├── receive.py           # Read pending messages
│   ├── reply.py             # Reply to a message (completes tasks automatically)
│   ├── task.py              # Delegate a task
│   ├── status.py            # Show bridge status
│   ├── validate.py          # Validate message schema
│   └── cleanup.py           # TTL-based cleanup
├── hooks/
│   ├── session_start.py     # SessionStart hook (heartbeat + inbox check)
│   ├── session_end.py       # SessionEnd hook (mark offline)
│   └── inbox_watcher.py     # Optional: watchdog-based real-time delivery
├── services/
│   ├── macos/               # LaunchAgent template (macOS)
│   ├── linux/               # systemd service template (Linux)
│   └── windows/             # Task Scheduler template (Windows)
├── tests/
│   └── test_smoke.py        # Smoke tests
├── docs/
│   ├── SPECIFICATION.md     # Protocol spec, schemas, message lifecycle
│   └── CONFIGURATION.md     # Environment variables, full settings.json examples
├── LICENSE
└── README.md                # ← you are here

Platform Support

| Platform | Status | Notes | |----------|--------|-------| | macOS | Full support | watchdog or polling, LaunchAgent template | | Linux | Full support | watchdog or polling, systemd template | | Windows | Full support | watchdog or polling, Task Scheduler template |

Limitations

  • Same filesystem required — both agents must see ~/.cc2cc (local machine, NFS, or shared volume)
  • No authentication — any process that can write to the inbox can inject messages. See Security below.
  • No encryption — messages are plaintext JSON
  • No guaranteed ordering — use replyTo for threading
  • Polling latency — up to 3s delivery delay (use watchdog for near-instant)
  • Experimental MCP feature — requires --dangerously-load-development-channels flag; the channels API may change or be removed

Security

CC2CC generates an HMAC-SHA256 shared secret during cc2cc init. All messages are signed automatically. Recipients verify signatures on read.

The secret is stored at ~/.cc2cc/secret.key. Protect it:

  • chmod 600 ~/.cc2cc/secret.key (macOS/Linux)
  • Restrict folder permissions (Windows)

Messages from processes without the secret will show [SIGNATURE INVALID] in receive output. Unsigned messages still work (backwards compatible) but are not verified.

Additional mitigations:

  • Set restrictive permissions: chmod 700 ~/.cc2cc
  • Only use on single-user machines where you trust all running processes

Documentation

Prior Art

Contributing

See CONTRIBUTING.md for guidelines.

License

MIT — see LICENSE

Author

@non4me