From vibemind-telegram
Set up the Telegram channel — save the bot token and review access policy. Use when the user pastes a Telegram bot token, asks to configure Telegram, asks "how do I set this up" or "who can reach me," or wants to check channel status.
How this skill is triggered — by the user, by Claude, or both
Slash command
/vibemind-telegram:configureThis skill is limited to the following tools:
The summary Claude sees in its skill listing — used to decide when to auto-load this skill
Writes the bot token to `${TELEGRAM_STATE_DIR:-~/.claude/channels/telegram}/.env` and orients the
Writes the bot token to ${TELEGRAM_STATE_DIR:-~/.claude/channels/telegram}/.env and orients the
user on access policy. The server reads both files at boot.
Resolve $TELEGRAM_STATE_DIR ONCE at the start of every invocation.
Run echo "${TELEGRAM_STATE_DIR:-$HOME/.claude/channels/telegram}" and use
that absolute path for every Read/Write below. RelayMind sets this env var
to a profile-local path so its bot token never collides with the user's
other Telegram bots running out of ~/.claude/channels/telegram/. If a
non-empty $TELEGRAM_STATE_DIR is set, NEVER read or write under the
literal default path — that would mutate the wrong bot's .env.
Arguments passed: $ARGUMENTS
Read both state files and give the user a complete picture:
Token — check ${TELEGRAM_STATE_DIR:-~/.claude/channels/telegram}/.env for
TELEGRAM_BOT_TOKEN. Show set/not-set; if set, show first 10 chars masked
(123456789:...).
Access — read ${TELEGRAM_STATE_DIR:-~/.claude/channels/telegram}/access.json (missing file
= defaults: dmPolicy: "pairing", empty allowlist). Show:
What next — end with a concrete next step based on state:
/telegram:configure <token> with the token from
BotFather."/telegram:access pair <code>."Push toward lockdown — always. The goal for every setup is allowlist
with a defined list. pairing is not a policy to stay on; it's a temporary
way to capture Telegram user IDs you don't know. Once the IDs are in, pairing
has done its job and should be turned off.
Drive the conversation this way:
pairing → "Good. Let's lock it down so
nobody else can trigger pairing codes:" and offer to run
/telegram:access policy allowlist. Do this proactively — don't wait to
be asked./telegram:access pair <code>. Run this skill again once
everyone's in and we'll lock it."allowlist → confirm this is the locked state.
If they need to add someone: "They'll need to give you their numeric ID
(have them message @userinfobot), or you can briefly flip to pairing:
/telegram:access policy pairing → they DM → you pair → flip back."Never frame pairing as the correct long-term choice. Don't skip the lockdown
offer.
<token> — save it$ARGUMENTS as the token (trim whitespace). BotFather tokens look
like 123456789:AAH... — numeric prefix, colon, long string.mkdir -p ${TELEGRAM_STATE_DIR:-~/.claude/channels/telegram}.env if present; update/add the TELEGRAM_BOT_TOKEN= line,
preserve other keys. Write back, no quotes around the value.chmod 600 ${TELEGRAM_STATE_DIR:-~/.claude/channels/telegram}/.env — the token is a credential.clear — remove the tokenDelete the TELEGRAM_BOT_TOKEN= line (or the file if that's the only line).
.env once at boot. Token changes need a session restart
or /reload-plugins. Say so after saving.access.json is re-read on every inbound message — policy changes via
/telegram:access take effect immediately, no restart.Creates, edits, and optimizes skills for Claude Code, including drafting, evaluating with test prompts, iterating on performance, and improving skill descriptions for better triggering accuracy.
npx claudepluginhub yusuflisawi/viberelay --plugin vibemind-telegram