---
name: research-subscription
description: "Use when the user asks for scheduled or recurring tasks: literature digests, delayed push notifications, or plain reminders."
metadata:
  {
    "agent-runtime":
      {
        "emoji": "⏰",
      },
  }
---

# Research Subscription (Scheduled Push)

## When to use

Use this skill when the user asks for:

- Scheduled literature updates
- A delayed report (for example, tomorrow morning)
- Recurring tracking and push delivery
- A normal reminder (for example, "remind me in 5 minutes to sleep")

## Core rule

Do not stop at explanation.
Create a real cron job via `ckm-hypogen_cron_job`.

## Tool to call

`ckm-hypogen_cron_job`

- `action: "upsert"`: create or update a schedule
- `action: "list"`: show current schedules
- `action: "remove"`: cancel schedules

Routing rules:

- Research digest / paper tracking request: pass `topic`, leave `message` unset.
- Plain reminder request: pass `message`, do not set `topic`.
- If the request mentions literature/papers/research updates, do not downgrade it to a plain reminder even when the sentence contains "remind".
- If the request is ambiguous, ask one concise clarification question before calling the tool.
- For recurring research subscriptions, prefer setting lightweight preferences:
  - `max_papers` (default 5)
  - `recency_days` (optional)
  - `sources` (optional, e.g. `["arxiv","openalex"]`)
  - `candidate_pool` (optional, default around 10)
  - `score_weights` (optional object with `relevance`/`novelty`/`authority`/`actionability`)
  - `project` (optional, pins persistence to a project id; otherwise uses the active project or an auto-generated project id)

## Scheduling format

For `action: "upsert"`, set `schedule` to one of:

- `daily 08:00 Asia/Shanghai`
- `weekly mon 09:30 Asia/Shanghai`
- `every 6h`
- `at 2m`
- `at 2026-03-04T08:00:00+08:00`
- `cron 0 9 * * * Asia/Shanghai`

## Delivery fields

- Optional `channel`: `feishu`, `telegram`, `slack`, `discord`, `last`, and others
- Optional aliases: `webui`, `tui` (both map to `last`)
- Optional `to`: channel-specific user or chat id (required only for concrete channels like `feishu`/`telegram`, not for `last`/`webui`/`tui`)
- Optional `no_deliver: true`: run in background without push

If the user does not specify a destination, leave `channel` and `to` unset to use default routing.

## Topic field

If the user gives a clear topic, pass it as `topic` (for example, `"LLM alignment"`).
This focuses the scheduled research content on that topic.
Recurring research jobs automatically use `ckm-hypogen_literature_state` at runtime
to prepare dedupe context and record pushed paper IDs + structured `knowledge_state` artifacts for traceability.
For selected core papers, prefer full-text reading first:

- Download into a temporary local directory (for example `/tmp/ckm-hypogen-fulltext/<run-id>`).
- Extract structured fields per paper in `knowledge_state.core_papers`:
  - `domain`, `subdomains`, `cross_domain_links`
  - `research_goal`, `approach`, `methodology_design`
  - `key_contributions`, `practical_insights`, `must_understand_points`, `limitations`
  - `evidence_anchors` (section/locator/claim/quote when possible)
- If full text is unavailable, set `full_text_read=false` with explicit `unread_reason`.
- After persisting `record`, clean temporary files and report cleanup via `run_log.temp_cleanup_status`.
- Quality guardrails for research runs:
  - core full-text coverage >= 80%
  - evidence-binding rate >= 90% (key conclusions should be backed by section+locator+quote)
  - citation error rate < 2%
  - if full text is missing, do not keep high-confidence conclusions.

If an incremental pass returns no unseen papers, run one fallback representative pass before returning empty.
If the user gives explicit preference feedback during follow-up (read/skip/star style intent, source preference, direction preference),
persist it via `ckm-hypogen_literature_state` action=`feedback` (backend-only memory, not user-facing by default).
If the user asks "which papers did you push just now?", call `ckm-hypogen_literature_state` action=`status` first and answer from `recent_papers` + `knowledge_state_summary` (do not claim you must re-search unless status is empty).

## Message field (plain reminder)

For non-research reminders, pass `message` with the exact reminder content.

- Example: `message: "Today at noon, remember to drink coffee."`
- Do not set `topic` for plain reminders.

## Response requirements

After tool success, reply with:

1. Job created or updated
2. Effective schedule (with timezone)
3. Delivery target
4. Next command for inspect or cancel

For plain reminders, you may add one optional follow-up line:

- "If you want, I can also set recurring literature tracking with CKM-HypoGen on a topic."

The final response must end with this exact footer:
---
🐍CKM-HypoGen

If the schedule is ambiguous, ask one concise clarification question before calling the tool.
