cc-connect-ai-bridge

Bridge local AI coding agents (Claude Code, Cursor, Gemini CLI, Codex) to messaging platforms (Feishu, Telegram, Slack, Discord, DingTalk, WeChat Work, LINE) without a public IP.

22 stars

Best use case

cc-connect-ai-bridge is best used when you need a repeatable AI agent workflow instead of a one-off prompt.

Bridge local AI coding agents (Claude Code, Cursor, Gemini CLI, Codex) to messaging platforms (Feishu, Telegram, Slack, Discord, DingTalk, WeChat Work, LINE) without a public IP.

Teams using cc-connect-ai-bridge should expect a more consistent output, faster repeated execution, less prompt rewriting.

When to use this skill

  • You want a reusable workflow that can be run more than once with consistent structure.

When not to use this skill

  • You only need a quick one-off answer and do not need a reusable workflow.
  • You cannot install or maintain the underlying files, dependencies, or repository context.

Installation

Claude Code / Cursor / Codex

$curl -o ~/.claude/skills/cc-connect-ai-bridge/SKILL.md --create-dirs "https://raw.githubusercontent.com/Aradotso/trending-skills/main/skills/cc-connect-ai-bridge/SKILL.md"

Manual Installation

  1. Download SKILL.md from GitHub
  2. Place it in .claude/skills/cc-connect-ai-bridge/SKILL.md inside your project
  3. Restart your AI agent — it will auto-discover the skill

How cc-connect-ai-bridge Compares

Feature / Agentcc-connect-ai-bridgeStandard Approach
Platform SupportNot specifiedLimited / Varies
Context Awareness High Baseline
Installation ComplexityUnknownN/A

Frequently Asked Questions

What does this skill do?

Bridge local AI coding agents (Claude Code, Cursor, Gemini CLI, Codex) to messaging platforms (Feishu, Telegram, Slack, Discord, DingTalk, WeChat Work, LINE) without a public IP.

Where can I find the source code?

You can find the source code on GitHub using the link provided at the top of the page.

Related Guides

SKILL.md Source

# CC-Connect AI Bridge

> Skill by [ara.so](https://ara.so) — Daily 2026 Skills collection.

CC-Connect bridges locally running AI coding agents (Claude Code, Codex, Cursor Agent, Gemini CLI, Qoder CLI, OpenCode, iFlow CLI) to messaging platforms you already use. You can chat with your local agent from Telegram, Feishu, Slack, Discord, DingTalk, WeChat Work, LINE, or QQ — no public IP required for most platforms.

---

## Installation

### Via npm (recommended)

```bash
# Stable
npm install -g cc-connect

# Beta (includes personal WeChat / Weixin ilink and other beta features)
npm install -g cc-connect@beta
```

### Via binary

```bash
# Linux amd64
curl -L -o cc-connect https://github.com/chenhg5/cc-connect/releases/latest/download/cc-connect-linux-amd64
chmod +x cc-connect
sudo mv cc-connect /usr/local/bin/

# macOS arm64
curl -L -o cc-connect https://github.com/chenhg5/cc-connect/releases/latest/download/cc-connect-darwin-arm64
chmod +x cc-connect
sudo mv cc-connect /usr/local/bin/
```

### Build from source (Go 1.22+)

```bash
git clone https://github.com/chenhg5/cc-connect.git
cd cc-connect
make build
# binary appears at ./bin/cc-connect
```

### Self-update

```bash
cc-connect update          # stable
cc-connect update --pre    # beta / pre-release
```

---

## Quick AI-assisted Setup

Send this prompt to Claude Code or any AI coding agent — it will install and configure cc-connect automatically:

```
Follow https://raw.githubusercontent.com/chenhg5/cc-connect/refs/heads/main/INSTALL.md to install and configure cc-connect.
```

---

## Configuration

```bash
mkdir -p ~/.cc-connect
cp config.example.toml ~/.cc-connect/config.toml
```

### Minimal `config.toml` — Claude Code + Telegram

```toml
[project.my-project]
name        = "my-project"
work_dir    = "/home/user/myproject"
data_dir    = "/home/user/.cc-connect/data"
admin_from  = "123456789"          # Your Telegram user ID

[project.my-project.agent]
type = "claude-code"               # claude-code | codex | cursor | gemini | qoder | opencode | iflow

[project.my-project.platform]
type  = "telegram"
token = "$TELEGRAM_BOT_TOKEN"      # set via env or paste value
```

### Multi-project config

```toml
# Project 1: Claude on Telegram
[project.dev]
name     = "dev"
work_dir = "/home/user/project-a"
data_dir = "/home/user/.cc-connect/data/dev"

[project.dev.agent]
type = "claude-code"

[project.dev.platform]
type  = "telegram"
token = "$TELEGRAM_BOT_TOKEN"

# Project 2: Gemini on Feishu
[project.research]
name     = "research"
work_dir = "/home/user/project-b"
data_dir = "/home/user/.cc-connect/data/research"

[project.research.agent]
type = "gemini"

[project.research.platform]
type           = "feishu"
app_id         = "$FEISHU_APP_ID"
app_secret     = "$FEISHU_APP_SECRET"
verification_token = "$FEISHU_VERIFICATION_TOKEN"
```

### All supported platform types

| `type` value | Platform | Public IP needed? |
|---|---|---|
| `telegram` | Telegram | No (long polling) |
| `feishu` | Feishu / Lark | No (WebSocket) |
| `dingtalk` | DingTalk | No (Stream) |
| `slack` | Slack | No (Socket Mode) |
| `discord` | Discord | No (Gateway) |
| `wecom` | WeChat Work | No (WS) / Yes (Webhook) |
| `line` | LINE | Yes (Webhook) |
| `qq` | QQ via NapCat/OneBot | No |
| `qqbot` | QQ Bot Official | No |
| `weixin` | Personal WeChat (beta) | No (ilink long polling) |

### All supported agent types

| `type` value | Agent |
|---|---|
| `claude-code` | Claude Code (Anthropic) |
| `codex` | Codex (OpenAI) |
| `cursor` | Cursor Agent |
| `gemini` | Gemini CLI (Google) |
| `qoder` | Qoder CLI |
| `opencode` | OpenCode / Crush |
| `iflow` | iFlow CLI |

---

## Platform-specific configuration

### Telegram

```toml
[project.mybot.platform]
type  = "telegram"
token = "$TELEGRAM_BOT_TOKEN"
# Get token from @BotFather on Telegram
# No public IP required — uses long polling
```

### Feishu / Lark

```toml
[project.mybot.platform]
type               = "feishu"
app_id             = "$FEISHU_APP_ID"
app_secret         = "$FEISHU_APP_SECRET"
verification_token = "$FEISHU_VERIFICATION_TOKEN"
# Uses WebSocket — no public IP needed
# Set up at https://open.feishu.cn/
```

### Slack

```toml
[project.mybot.platform]
type              = "slack"
bot_token         = "$SLACK_BOT_TOKEN"
app_token         = "$SLACK_APP_TOKEN"
# app_token must start with xapp- (Socket Mode)
# Enable Socket Mode in your Slack app settings
```

### Discord

```toml
[project.mybot.platform]
type  = "discord"
token = "$DISCORD_BOT_TOKEN"
# Uses Discord Gateway — no public IP needed
```

### DingTalk

```toml
[project.mybot.platform]
type       = "dingtalk"
client_id  = "$DINGTALK_CLIENT_ID"
client_secret = "$DINGTALK_CLIENT_SECRET"
# Uses DingTalk Stream — no public IP needed
```

### WeChat Work (WeCom)

```toml
[project.mybot.platform]
type           = "wecom"
corp_id        = "$WECOM_CORP_ID"
agent_id       = "$WECOM_AGENT_ID"
secret         = "$WECOM_SECRET"
connection_type = "websocket"   # websocket (no public IP) or webhook
```

### Personal WeChat (beta only)

```bash
# Install beta build first
npm install -g cc-connect@beta

# Scan QR code to log in
cc-connect weixin setup
```

```toml
[project.mybot.platform]
type = "weixin"
# Auth state is stored after QR scan — no public IP needed
```

---

## Running cc-connect

```bash
# Default config location: ~/.cc-connect/config.toml
cc-connect

# Custom config path
cc-connect --config /path/to/config.toml

# Run specific project only
cc-connect --project my-project
```

---

## Chat Commands (sent in the messaging platform)

| Command | Description |
|---|---|
| `/help` | Show all available commands |
| `/model <name>` | Switch AI model (e.g. `/model claude-opus-4-5`) |
| `/mode <mode>` | Change permission mode (e.g. `/mode auto`) |
| `/reasoning <level>` | Tune reasoning intensity |
| `/dir <path>` | Switch working directory for next session |
| `/dir <number>` | Jump to a directory from history |
| `/dir -` | Toggle to previous directory |
| `/dir reset` | Restore configured `work_dir` |
| `/cd <path>` | Alias for `/dir` |
| `/memory` | Read or write the agent's memory/instruction file |
| `/shell <cmd>` | Run a shell command (admin only) |
| `/session` | Manage sessions (list, continue, new) |
| `/continue` | Continue from last session (forks to avoid inheriting broken state) |
| `/cron <spec> <task>` | Schedule a recurring task |
| `/stop` | Stop the currently running agent |

### Slash command examples (in chat)

```
# Ask the agent to review a PR
Review the changes in branch feature/auth and summarize the risks.

# Switch to a different model
/model gemini-2.0-flash

# Change working directory
/dir /home/user/other-project

# Schedule a daily summary
/cron 0 6 * * * Summarize GitHub trending Go repos and post here

# Read agent memory
/memory

# Update agent memory
/memory Always prefer table-driven tests in Go. Use context.Context for cancellation.
```

---

## Multi-Agent Relay (group chat orchestration)

Bind multiple bots in one group chat so they communicate with each other:

```toml
# Bot 1: Claude
[project.claude-bot]
name     = "claude-bot"
work_dir = "/home/user/project"
data_dir = "/home/user/.cc-connect/data/claude"

[project.claude-bot.agent]
type = "claude-code"

[project.claude-bot.platform]
type  = "telegram"
token = "$TELEGRAM_CLAUDE_BOT_TOKEN"

# Bot 2: Gemini (same group)
[project.gemini-bot]
name     = "gemini-bot"
work_dir = "/home/user/project"
data_dir = "/home/user/.cc-connect/data/gemini"

[project.gemini-bot.agent]
type = "gemini"

[project.gemini-bot.platform]
type  = "telegram"
token = "$TELEGRAM_GEMINI_BOT_TOKEN"
```

Add both bots to the same Telegram group. Mention them by name and they will pick up and respond to each other's output.

---

## Voice and Multimodal

For platforms that support voice (Telegram, Feishu, DingTalk), enable speech in config:

```toml
[speech]
provider = "openai"           # openai | azure | google
api_key  = "$OPENAI_API_KEY"

[speech.stt]
model = "whisper-1"

[speech.tts]
model = "tts-1"
voice = "alloy"
```

Send a voice message in Telegram → cc-connect transcribes it → forwards text to the agent → optionally speaks the response back.

For images/screenshots: just attach the image in chat. cc-connect forwards it to multimodal-capable agents.

---

## Cron Scheduling

```toml
# In config.toml, per-project cron settings
[project.mybot.cron]
timeout = "30m"          # max runtime per job
fresh_session = true     # start a new session for each run
```

From chat:

```
# Every weekday at 9am, run a standup summary
/cron 0 9 * * 1-5 Summarize open PRs and blockers in this repo

# Every hour, check for new issues labeled "urgent"
/cron 0 * * * * Check for new GitHub issues labeled urgent and notify me
```

---

## Admin configuration

```toml
[project.mybot]
admin_from = "alice,123456789"   # comma-separated usernames or IDs
```

Admins can use `/shell`, `/dir`, and other privileged commands. Non-admins cannot.

---

## Directory structure

```
~/.cc-connect/
├── config.toml                          # main config
└── data/
    └── projects/
        └── my-project.state.json        # persisted dir override, session state
```

---

## Common patterns

### Pattern 1: Mobile-first AI development

Install cc-connect on your dev machine, connect it to Telegram. From your phone:
1. Send a task description as a message
2. Agent runs on your machine
3. Streamed response appears in chat
4. Reply to continue the conversation

### Pattern 2: Team shared AI bot (Slack/Feishu)

One cc-connect instance per project, shared in a team channel. Team members can ask questions, trigger code reviews, or run analyses — all without terminal access.

### Pattern 3: Scheduled reports

```
/cron 0 8 * * 1 Generate a weekly summary of commits and open issues, format as markdown
```

### Pattern 4: Multi-project routing

Run multiple projects in one `cc-connect` process, each bot handles a different repo or concern.

---

## Troubleshooting

### Bot not responding

1. Check that `cc-connect` is running: `ps aux | grep cc-connect`
2. Verify the platform token/credentials in config
3. For Telegram: ensure the bot token is valid (`/start` in BotFather chat)
4. For Feishu: check WebSocket connection in Feishu Open Platform console

### Agent not found

```bash
# Verify agent is installed and in PATH
which claude     # for claude-code
which gemini     # for gemini
which codex      # for codex
```

Set explicit path in config if needed:

```toml
[project.mybot.agent]
type = "claude-code"
bin  = "/usr/local/bin/claude"
```

### Session inherits broken state

Use `/continue` which forks the session, or start fresh:

```
/session new
```

### Personal WeChat not available

You need the beta build:

```bash
npm install -g cc-connect@beta
cc-connect weixin setup   # scan QR in terminal
```

### Context too long / auto-compress

Enable in config:

```toml
[project.mybot.agent]
auto_compress        = true
compress_threshold   = 80000   # tokens before compression kicks in
```

### Config not found

Default path is `~/.cc-connect/config.toml`. Pass explicitly:

```bash
cc-connect --config /custom/path/config.toml
```

### Check version

```bash
cc-connect --version
```

---

## Environment variables reference

| Variable | Used for |
|---|---|
| `TELEGRAM_BOT_TOKEN` | Telegram bot token |
| `FEISHU_APP_ID` | Feishu app ID |
| `FEISHU_APP_SECRET` | Feishu app secret |
| `FEISHU_VERIFICATION_TOKEN` | Feishu verification token |
| `SLACK_BOT_TOKEN` | Slack bot OAuth token (`xoxb-...`) |
| `SLACK_APP_TOKEN` | Slack app-level token (`xapp-...`) |
| `DISCORD_BOT_TOKEN` | Discord bot token |
| `DINGTALK_CLIENT_ID` | DingTalk app client ID |
| `DINGTALK_CLIENT_SECRET` | DingTalk app client secret |
| `WECOM_CORP_ID` | WeChat Work corp ID |
| `WECOM_AGENT_ID` | WeChat Work agent ID |
| `WECOM_SECRET` | WeChat Work app secret |
| `OPENAI_API_KEY` | OpenAI API key (for Codex agent or STT/TTS) |

Values in `config.toml` can reference env vars using `$VAR_NAME` syntax.

---

## Platform setup guides

- Feishu/Lark: `docs/feishu.md`
- DingTalk: `docs/dingtalk.md`
- Telegram: `docs/telegram.md`
- Slack: `docs/slack.md`
- Discord: `docs/discord.md`
- WeChat Work: `docs/wecom.md`
- Personal WeChat (beta): `docs/weixin.md`
- QQ / QQ Bot: `docs/qq.md`

Related Skills

weclaw-wechat-ai-bridge

22
from Aradotso/trending-skills

Connect WeChat to AI agents (Claude, Codex, Gemini, Kimi, etc.) using the WeClaw bridge in Go.

```markdown

22
from Aradotso/trending-skills

---

zeroboot-vm-sandbox

22
from Aradotso/trending-skills

Sub-millisecond VM sandboxes for AI agents using copy-on-write KVM forking via Zeroboot

yourvpndead-vpn-detection

22
from Aradotso/trending-skills

Android app that detects VPN/proxy servers (VLESS/xray/sing-box) via local SOCKS5 vulnerability, exposing exit IPs and server configs without root

xata-postgres-platform

22
from Aradotso/trending-skills

Expert skill for Xata open-source cloud-native Postgres platform with copy-on-write branching, scale-to-zero, and Kubernetes deployment

x-mentor-skill-nuwa

22
from Aradotso/trending-skills

AI-powered X (Twitter) content strategy skill that distills methodologies from 6 top creators + open-source algorithm data into actionable writing, growth, and monetization guidance.

wx-favorites-report

22
from Aradotso/trending-skills

End-to-end pipeline to extract, decrypt, and visualize WeChat Mac favorites from encrypted SQLite DB into an interactive HTML report.

wterm-web-terminal

22
from Aradotso/trending-skills

Web terminal emulator with Zig/WASM core, DOM rendering, and React/vanilla JS bindings

worldmonitor-intelligence-dashboard

22
from Aradotso/trending-skills

Real-time global intelligence dashboard with AI-powered news aggregation, geopolitical monitoring, and infrastructure tracking

witr-process-inspector

22
from Aradotso/trending-skills

CLI and TUI tool that explains why processes, services, and ports are running by tracing causality chains across supervisors, containers, and shells.

wildworld-dataset

22
from Aradotso/trending-skills

WildWorld large-scale action-conditioned world modeling dataset with 108M+ frames from a photorealistic ARPG game, featuring per-frame annotations, 450+ actions, and explicit state information for generative world modeling research.

whatcable-macos-usb-inspector

22
from Aradotso/trending-skills

macOS menu bar app that identifies USB-C cable capabilities and charging diagnostics using IOKit