← All skills
Tencent SkillHub · Communication & Collaboration

Channel Reminders

Создаёт и доставляет пользователю напоминания в текущий чат мессенджера через systemEvent в main session по расписанию или интервалу.

skill openclawclawhub Free
0 Downloads
0 Stars
0 Installs
0 Score
High Signal

Создаёт и доставляет пользователю напоминания в текущий чат мессенджера через systemEvent в main session по расписанию или интервалу.

⬇ 0 downloads ★ 0 stars Unverified but indexed

Install for OpenClaw

Quick setup
  1. Download the package from Yavira.
  2. Extract the archive and review SKILL.md first.
  3. Import or place the package into your OpenClaw setup.

Requirements

Target platform
OpenClaw
Install method
Manual import
Extraction
Extract archive
Prerequisites
OpenClaw
Primary doc
SKILL.md

Package facts

Download mode
Yavira redirect
Package format
ZIP package
Source platform
Tencent SkillHub
What's included
SKILL.md, package.json

Validation

  • Use the Yavira download entry.
  • Review SKILL.md after the package is downloaded.
  • Confirm the extracted package contains the expected setup assets.

Install with your agent

Agent handoff

Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.

  1. Download the package from Yavira.
  2. Extract it into a folder your agent can access.
  3. Paste one of the prompts below and point your agent at the extracted folder.
New install

I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.

Upgrade existing

I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.

Trust & source

Release facts

Source
Tencent SkillHub
Verification
Indexed source record
Version
1.3.0

Documentation

ClawHub primary doc Primary doc: SKILL.md 28 sections Open source page

Channel Reminders

Навык для создания напоминаний через cron jobs с доставкой в Telegram.

1. Heartbeat должен быть включён

В ~/.openclaw/openclaw.json проверь: { "agents": { "defaults": { "heartbeat": { "every": "5m", // ← НЕ должен быть "0m" или отсутствовать "target": "last" // ← Куда отправлять ответы } } } } Если heartbeat.every = "0m" или отсутствует — напоминания НЕ будут работать!

2. HEARTBEAT.md должен содержать инструкцию

  • В HEARTBEAT.md main агента ОБЯЗАТЕЛЬНО добавь раздел для обработки напоминаний:
  • ### Напоминания (systemEvent)
  • Когда получаешь systemEvent с напоминанием (обычно содержит ⏰, 📅, 💰, 📞, ✅, 🔔, 💊, 🏃 и т.д.) — передай его пользователю в Telegram.
  • **Пример:**
  • Получено: `⏰ НАПОМИНАНИЕ: оплатить интернет`
  • Ответ в Telegram: `💰 Напоминаю: пора оплатить интернет!`
  • Просто доставь напоминание без лишних комментариев.

3. wakeMode: "now" в cron job

Всегда указывай "wakeMode": "now" чтобы heartbeat сработал сразу: { "sessionTarget": "main", "wakeMode": "now", // ← ОБЯЗАТЕЛЬНО для немедленного срабатывания "payload": { ... } } Без этого напоминание будет ждать следующего heartbeat (до 5 минут).

🧪 ПОСЛЕ УСТАНОВКИ: Тестирование

После установки навыка обязательно протестируй все подходы с пользователем:

Шаг 1: Тест простого напоминания (main агент)

Поставь тестовое напоминание через 1 минуту

Шаг 2: Тест через message tool (если есть несколько ботов)

Отправь тестовое сообщение через message tool

Шаг 3: Определи рабочий вариант

После тестов запиши в память какой подход работает: Пример записи в MEMORY.md или memory/YYYY-MM-DD.md: ## Напоминания **Рабочий подход:** sessionTarget: "main" + systemEvent + wakeMode: "now" **Проверено:** 2026-02-14 **Chat ID пользователя:** 7977422300

Шаг 4: Если не работает

Проверь: ✅ Heartbeat включён (heartbeat.every ≠ "0m") ✅ HEARTBEAT.md содержит инструкцию для напоминаний ✅ wakeMode: "now" указан в cron job ✅ Telegram канал настроен и работает

Для MAIN агента

{ "name": "Напоминание", "schedule": { "kind": "at", "at": "2026-02-14T15:00:00+03:00" }, "sessionTarget": "main", "wakeMode": "now", "payload": { "kind": "systemEvent", "text": "⏰ НАПОМИНАНИЕ: текст напоминания" } } Main агент получит systemEvent → heartbeat сработает → агент ответит в чат.

Для НЕ-main агентов (Semen, Andrey, Hristofor, Discussions)

Используй схему: main агент + message tool { "agentId": "main", "name": "Напоминание от Semen", "schedule": { "kind": "at", "at": "2026-02-14T15:00:00+03:00" }, "sessionTarget": "main", "wakeMode": "now", "payload": { "kind": "systemEvent", "text": "📤 ОТПРАВИТЬ НАПОМИНАНИЕ:\naccountId: semen\ntarget: 7977422300\nmessage: 🤗 текст напоминания" } } Как это работает: Cron срабатывает → systemEvent идёт в main session main агента Main агент видит 📤 ОТПРАВИТЬ НАПОМИНАНИЕ: в HEARTBEAT.md Main агент парсит accountId, target, message Main агент отправляет через message tool с указанным accountId Пользователь получает сообщение от бота НЕ-main агента

Chat ID пользователя

Где взять: curl "https://api.telegram.org/bot<BOT_TOKEN>/getUpdates" | jq '.result[].message.chat.id' Или из metadata сообщения — в заголовке Telegram сообщения виден id:XXXXXXXX

AccountId для каждого агента

АгентaccountIdДжон Зойдберг (main)mainСемёнsemenАндрейandreyХристофорhristoforDiscussionsdiscussions

Одноразовое (at)

{ "kind": "at", "at": "2026-02-14T15:00:00+03:00" } ⚠️ Всегда указывай таймзону! Без неё = UTC.

Повторяющееся (cron)

{ "kind": "cron", "expr": "0 9 * * *", "tz": "Europe/Moscow" } ВыражениеЗначение0 9 * * *Каждый день в 9:000 9 * * 1-5Будни в 9:000 18 * * 5Каждую пятницу в 18:000 */2 * * *Каждые 2 часа

Интервал (every)

{ "kind": "every", "everyMs": 3600000 } ИнтервалМиллисекунды5 минут3000001 час360000024 часа86400000

Main агент: напомнить через 10 минут

{ "name": "Напоминание через 10 мин", "schedule": { "kind": "at", "at": "<текущее время + 10 мин>" }, "sessionTarget": "main", "wakeMode": "now", "payload": { "kind": "systemEvent", "text": "⏰ НАПОМИНАНИЕ: проверить почту" } }

Semen: ежедневное напоминание

{ "agentId": "main", "name": "Утреннее напоминание от Semen", "schedule": { "kind": "cron", "expr": "0 9 * * *", "tz": "Europe/Moscow" }, "sessionTarget": "main", "wakeMode": "now", "payload": { "kind": "systemEvent", "text": "📤 ОТПРАВИТЬ НАПОМИНАНИЕ:\naccountId: semen\ntarget: 7977422300\nmessage: 🤗 Доброе утро! Проверь задачи на сегодня." } }

Hristofor: напоминание об оплате

{ "agentId": "main", "name": "Оплата интернета", "schedule": { "kind": "at", "at": "2026-02-25T10:00:00+03:00" }, "sessionTarget": "main", "wakeMode": "now", "payload": { "kind": "systemEvent", "text": "📤 ОТПРАВИТЬ НАПОМИНАНИЕ:\naccountId: hristofor\ntarget: 7977422300\nmessage: 💰 Напоминание: оплатить интернет до 28 февраля" } }

Посмотреть все

cron list

Удалить

cron remove jobId: "uuid"

Отключить/включить

cron update jobId: "uuid" patch: { enabled: false } cron update jobId: "uuid" patch: { enabled: true }

Формат systemEvent для НЕ-main агентов

📤 ОТПРАВИТЬ НАПОМИНАНИЕ: accountId: <accountId бота> target: <Chat ID пользователя> message: <текст напоминания с эмодзи> Эмодзи для разных типов: ЭмодзиАгент🤗Semen🧑💻Andrey💰Hristofor💬Discussions

Проверка

Перед использованием навыка убедись, что в HEARTBEAT.md main агента есть инструкция для обработки 📤 ОТПРАВИТЬ НАПОМИНАНИЕ:. Проверь файл: ~/.openclaw/workspace-main/HEARTBEAT.md Ищи раздел: ### Напоминания от других агентов (📤 ОТПРАВИТЬ НАПОМИНАНИЕ)

Если раздела нет — добавь:

### Напоминания от других агентов (📤 ОТПРАВИТЬ НАПОМИНАНИЕ) Когда получаешь systemEvent с `📤 ОТПРАВИТЬ НАПОМИНАНИЕ:` — это запрос от НЕ-main агента отправить сообщение через их бота. **Формат:** \`\`\` 📤 ОТПРАВИТЬ НАПОМИНАНИЕ: accountId: semen target: 7977422300 message: 🤗 текст напоминания \`\`\` **Действие:** Используй `message` tool: \`\`\`json { "action": "send", "channel": "telegram", "accountId": "<accountId из systemEvent>", "target": "<target из systemEvent>", "message": "<message из systemEvent>" } \`\`\` Ничего больше не отвечай после отправки (NO_REPLY).

Как это работает

При получении такого systemEvent, main агент: Парсит accountId, target, message из текста Использует message tool с этими параметрами Сообщение отправляется от бота с указанным accountId Main агент отвечает NO_REPLY (не дублирует в свой чат)

Почему эта схема работает

Main агент имеет стабильный heartbeat — systemEvent всегда обрабатывается Message tool работает — проверено CLI и tool call AccountId маршрутизирует — сообщение идёт от нужного бота Target указывает получателя — Chat ID пользователя

Альтернатива: прямая отправка через message tool

Если агент хочет отправить сообщение СЕЙЧАС (не по расписанию): { "action": "send", "channel": "telegram", "accountId": "semen", "target": "7977422300", "message": "🤗 Текст сообщения" } Это работает для любого агента, если он имеет доступ к message tool.

Category context

Messaging, meetings, inboxes, CRM, and teammate communication surfaces.

Source: Tencent SkillHub

Largest current source with strong distribution and engagement signals.

Package contents

Included in package
1 Docs1 Config
  • SKILL.md Primary doc
  • package.json Config