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.
npx claudepluginhub yusuflisawi/viberelay --plugin vibemind-telegramThis skill is limited to using the following tools:
Writes the bot token to `${TELEGRAM_STATE_DIR:-~/.claude/channels/telegram}/.env` and orients the
Guides Next.js Cache Components and Partial Prerendering (PPR): 'use cache' directives, cacheLife(), cacheTag(), revalidateTag() for caching, invalidation, static/dynamic optimization. Auto-activates on cacheComponents: true.
Guides building MCP servers enabling LLMs to interact with external services via tools. Covers best practices, TypeScript/Node (MCP SDK), Python (FastMCP).
Share bugs, ideas, or general feedback.
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.