channel-bridge
Cross-channel routing: Signal/TG/Discord formatting, message vs sessions_send, broadcast, reactions
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o channel-bridge.zip https://jpskill.com/download/22198.zip && unzip -o channel-bridge.zip && rm channel-bridge.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/22198.zip -OutFile "$d\channel-bridge.zip"; Expand-Archive "$d\channel-bridge.zip" -DestinationPath $d -Force; ri "$d\channel-bridge.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
channel-bridge.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
channel-bridgeフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-18
- 取得日時
- 2026-05-18
- 同梱ファイル
- 1
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
channel-bridge
目的
このスキルは、Signal、Telegram、Discord 間でのクロスチャネルメッセージルーティングを容易にします。メッセージのフォーマット(例:Markdown をプレーンテキストに変換)を処理し、単純なメッセージ送信とセッションベースの送信を区別し、複数のチャネルへのブロードキャストをサポートし、プラットフォーム間でのリアクションを管理します。
使用する場面
Signal から Discord へチーム通知のためにアラートを転送する、分散チームのために Telegram と Signal 全体で更新をブロードキャストする、または統一されたフィードバック追跡のために Discord から Signal へユーザーリアクション(例:いいね)をルーティングするなど、異なるメッセージングアプリを統合する際にこのスキルを使用します。手動介入なしにリアルタイムのクロスプラットフォーム通信が必要なシナリオに適用してください。
主な機能
- メッセージフォーマット: コンテンツフォーマットを自動的に変換します。例:Discord の Markdown 構文を使用し、
formatフラグを介して Signal 用にそれを除去します。 - ルーティングオプション: API パラメータ
type: "message"またはtype: "sessions_send"を使用して、message(単純な送信)とsessions_send(永続的なセッションベースのルーティング)を区別します。 - ブロードキャスト: 複数のチャネルに同時にメッセージを送信します。例:
["signal:group1", "discord:channel2"]のような JSON 配列でターゲットを指定します。 - リアクション処理: リアクション(例:絵文字)をプラットフォーム間で伝播させます。例:事前定義された設定マッピングを介して Discord のリアクションを Signal のリアクションにマッピングします。
- エラー耐性: 失敗した送信のための再試行ロジックを含み、設定可能なしきい値があります。
使用パターン
常に環境変数(例:$SIGNAL_API_KEY、$TELEGRAM_BOT_TOKEN)を介した認証で初期化してください。CLI の場合、入力を直接パイプします。API の場合、JSON ペイロードを含む HTTP リクエストを使用します。パターン 1:シングルチャネルルーティング—あるプラットフォームから別のプラットフォームへメッセージを送信します。パターン 2:ブロードキャスト—単一のコマンドで複数のターゲットを指定します。パターン 3:リアクション処理—ウェブフックを使用してリアクションを監視し、転送します。まず入力を検証してください(例:プラットフォームごとのメッセージ長制限を確認します:Signal=4096文字、Discord=2000文字)。セッションの場合、コマンドに --session-id を含めることで永続的な接続を確立します。
一般的なコマンド/API
CLI ツールまたは REST API を使用して操作します。CLI コマンドには channel-bridge バイナリが必要です。API エンドポイントは /api/v1/ の下にあります。
-
メッセージ送信のための CLI コマンド:
channel-bridge send --from signal --to telegram --message "Hello team" --format markdownこれはフォーマットされたメッセージをルーティングします。複数ターゲットの場合、
--broadcastを追加します。例:--to "discord:channel1,signal:group2"。 -
セッション送信のための API エンドポイント: POST /api/v1/sessions_send Body:
{"from": "discord", "to": ["telegram"], "content": "Update", "type": "sessions_send", "session_id": "abc123"}ヘッダーを含めます:Authorization: Bearer $DISCORD_API_KEY。 -
リアクション付きブロードキャストのための CLI:
channel-bridge broadcast --from tg --to "signal,discord" --message "Alert" --reactions trueこれはリアクション転送を有効にします。リアクションは設定ファイル(例:JSON:
{"👍": "thumbsup"})を介してマッピングされます。 -
リアクション処理のための API: POST /api/v1/reactions Body:
{"source": "discord", "reaction": "👍", "targets": ["signal"]}リアクションを伝播させるためにこれを使用します。事前のウェブフック設定が必要です。
設定形式:プラットフォーム設定には YAML ファイルを使用します。例:
signal:
api_key: $SIGNAL_API_KEY
default_group: group1
telegram:
bot_token: $TELEGRAM_BOT_TOKEN
統合に関する注意点
認証のために環境変数を設定して統合します。例:Signal アクセスのために $SIGNAL_API_KEY をエクスポートします。API 統合の場合、Python の requests のようなライブラリを使用します。
import requests
response = requests.post('http://localhost:8080/api/v1/send', json={'from': 'tg', 'to': 'discord', 'message': 'Test'}, headers={'Authorization': f'Bearer {os.environ["TELEGRAM_BOT_TOKEN"]}'})
アプリが Discord ウェブフックのようなプラットフォーム固有の要件を処理することを確認してください。マルチサービス設定の場合、このスキルを共有セッション ID を介して他の分散通信ツールと連携させます。まずサンドボックス環境で統合をテストしてください。
エラー処理
コマンド/API からの応答コードを確認してください。例:CLI は失敗の場合にゼロ以外の終了コードを返します。一般的なエラー:認証の問題に対する 401($SERVICE_API_KEY を確認)、無効なフォーマットに対する 400(例:メッセージタイプの不一致)。指数関数的バックオフを伴う再試行を実装してください。コードでは、次のようなループを使用します。
for attempt in range(3):
try:
response = requests.post(...) # API call
break
except Exception as e:
if attempt == 2:
log_error(e)
エラーを詳細にログに記録し(例:「ブロードキャスト失敗:Signal タイムアウト」)、詳細な出力のために CLI で --debug フラグを使用してください。リアクションの場合、サポートされていないタイプをスキップすることでプラットフォームの不一致を処理します。
使用例
- Telegram から Signal および Discord へのメッセージルーティング: アラートにこれを使用します:
channel-bridge send --from tg --to "signal:alerts, discord:general" --message "System down" --format plain。これはメッセージをブロードキャストし、適切にフォーマットし、追跡のために送信 ID をログに記録します。 - ブロードキャストシナリオでのリアクション処理: フィードバックループの場合:
channel-bridge broadcast --from discord --to "tg:group1" --message "Vote now" --reactions true。ユーザーが Discord で 👍 でリアクションした場合、設定からのリアクションマッピングを使用して、カスタム絵文字として Telegram に転送されます。
グラフの関係
- クラスタ関係: 「distributed-comms」クラスタに属し、他の通信スキルとの相互運用性を可能にします。
- サービスリンク: メッセージングのために「signal」、ボット操作のために「telegram」、ウェブフックイベントのために「discord」と連携します。
- タグ接続: タグ
["signal", "telegram", "discord", "messaging", "channel"]に関連付けられ、グラフ内の関連スキルにリンクします。
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
channel-bridge
Purpose
This skill facilitates cross-channel messaging routing between Signal, Telegram, and Discord. It handles message formatting (e.g., converting Markdown to plain text), differentiates between simple message sends and session-based transmissions, supports broadcasting to multiple channels, and manages reactions across platforms.
When to Use
Use this skill when integrating disparate messaging apps, such as forwarding alerts from Signal to Discord for team notifications, broadcasting updates across Telegram and Signal for distributed teams, or routing user reactions (e.g., likes) from Discord to Signal for unified feedback tracking. Apply it in scenarios requiring real-time cross-platform communication without manual intervention.
Key Capabilities
- Message Formatting: Automatically converts content formats; e.g., use Discord's Markdown syntax and strip it for Signal via the
formatflag. - Routing Options: Distinguishes between
message(simple send) andsessions_send(persistent session-based routing) using API parameters liketype: "message"ortype: "sessions_send". - Broadcasting: Sends messages to multiple channels simultaneously; e.g., specify targets with a JSON array like
["signal:group1", "discord:channel2"]. - Reactions Handling: Propagates reactions (e.g., emojis) across platforms; e.g., map Discord reactions to Signal reactions via a predefined config mapping.
- Error Resilience: Includes retry logic for failed transmissions, with configurable thresholds.
Usage Patterns
Always initialize with authentication via environment variables (e.g., $SIGNAL_API_KEY, $TELEGRAM_BOT_TOKEN). For CLI, pipe inputs directly; for API, use HTTP requests with JSON payloads. Pattern 1: Single-channel routing—send a message from one platform to another. Pattern 2: Broadcast—specify multiple targets in a single command. Pattern 3: Reaction handling—monitor and forward reactions using webhooks. Validate inputs first (e.g., check message length limits per platform: Signal=4096 chars, Discord=2000 chars). For sessions, establish a persistent connection by including --session-id in commands.
Common Commands/API
Use the CLI tool or REST API for interactions. CLI commands require the channel-bridge binary; API endpoints are under /api/v1/.
-
CLI Command for Sending a Message:
channel-bridge send --from signal --to telegram --message "Hello team" --format markdownThis routes a formatted message; add
--broadcastfor multi-target, e.g.,--to "discord:channel1,signal:group2". -
API Endpoint for Sessions Send: POST /api/v1/sessions_send Body:
{"from": "discord", "to": ["telegram"], "content": "Update", "type": "sessions_send", "session_id": "abc123"}Include headers:Authorization: Bearer $DISCORD_API_KEY. -
CLI for Broadcasting with Reactions:
channel-bridge broadcast --from tg --to "signal,discord" --message "Alert" --reactions trueThis enables reaction forwarding; reactions are mapped via a config file, e.g., JSON:
{"👍": "thumbsup"}. -
API for Reaction Handling: POST /api/v1/reactions Body:
{"source": "discord", "reaction": "👍", "targets": ["signal"]}Use this to propagate reactions; requires prior webhook setup.
Config format: Use a YAML file for platform settings, e.g.:
signal:
api_key: $SIGNAL_API_KEY
default_group: group1
telegram:
bot_token: $TELEGRAM_BOT_TOKEN
Integration Notes
Integrate by setting environment variables for authentication: e.g., export $SIGNAL_API_KEY for Signal access. For API integrations, use libraries like requests in Python:
import requests
response = requests.post('http://localhost:8080/api/v1/send', json={'from': 'tg', 'to': 'discord', 'message': 'Test'}, headers={'Authorization': f'Bearer {os.environ["TELEGRAM_BOT_TOKEN"]}'})
Ensure your app handles platform-specific requirements, like Discord webhooks for real-time updates. For multi-service setups, chain this skill with other distributed-comms tools via shared session IDs. Test integrations in a sandbox environment first.
Error Handling
Check response codes from commands/API; e.g., CLI returns non-zero exit codes for failures. Common errors: 401 for auth issues (verify $SERVICE_API_KEY), 400 for invalid formats (e.g., mismatched message types). Implement retries with exponential backoff: in code, use a loop like:
for attempt in range(3):
try:
response = requests.post(...) # API call
break
except Exception as e:
if attempt == 2:
log_error(e)
Log errors with details (e.g., "Failed broadcast: Signal timeout") and use the --debug flag in CLI for verbose output. For reactions, handle platform mismatches by skipping unsupported types.
Usage Examples
- Route a Message from Telegram to Signal and Discord: Use this for alerts:
channel-bridge send --from tg --to "signal:alerts, discord:general" --message "System down" --format plain. This broadcasts the message, formats it appropriately, and logs the transmission ID for tracking. - Handle Reactions in a Broadcast Scenario: For feedback loops:
channel-bridge broadcast --from discord --to "tg:group1" --message "Vote now" --reactions true. If a user reacts with 👍 on Discord, it forwards as a custom emoji to Telegram, using the reaction mapping from your config.
Graph Relationships
- Cluster Relation: Belongs to "distributed-comms" cluster, enabling interoperability with other comms skills.
- Service Links: Interacts with "signal" for messaging, "telegram" for bot operations, and "discord" for webhook events.
- Tag Connections: Associated with tags ["signal", "telegram", "discord", "messaging", "channel"], linking to related skills in the graph.