返回顶部
h

hn-daily

Generate and deliver a Hacker News daily report (Top-N) with article summaries and multi-view comment synthesis, in user-selected language, with optional file persistence and index update.

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 0.8.2
安全检测
已通过
436
下载量
1
收藏
概述
安装方式
版本历史

hn-daily

# HN Daily ## Release Notes - v0.8.2: Refresh publication for latest HN Daily Brief packaging and worker-oriented execution workflow. - v0.8.1: Tighten anti-padding controls for final write-up (ban repeated boilerplate tails, enforce anti-template validation before send). - v0.8.0: Run scheduled HN jobs in isolated cron sessions (`sessionTarget=isolated`, `payload.kind=agentTurn`) to avoid blocking main chat; keep 3-job retry ladder idempotent. - v0.7.0: Add concurrent retry profile for schedule reliability (primary run + immediate retry + delayed retry) with idempotent completion checks to avoid timeout-caused misses. - v0.6.0: Brand rename for distribution as "HN Daily Brief" + full copy cleanup to English-only wording. - v0.5.1: Language cleanup for public distribution (English-first docs; localized markers still supported). - v0.5.0: First public release. ## Parameters - `language`: output language (default: current user conversation language) - `topN`: number of items (default: 10) - `style`: `strict | lite` (default: strict) - `outputDir`: output directory (default: `/home/ubuntu/.openclaw/workspace/output/hn-daily/`) - `persist`: whether to save file + update index (default: true) - `reminderTime`: cron time in user timezone, or `off` ## First-load behavior - On first load (or when user changes params), show effective params once and confirm. - Otherwise, reuse last confirmed params. ## Mandatory execution order 1. Retry preflight check (required for retry jobs): - If this run is a retry/compensation run, first check whether today's report already exists and is complete (at minimum includes `## Top 10`). - If already complete, return `NO_REPLY` and stop (idempotent exit). 2. Always fetch fresh inputs for this run (required): - Re-pull current HN Top-N items, article snippets, and comments at run time. - Do not reuse previous report body as source input. 3. Collect materials via script (data collection only, never user-facing): - `scripts/generate_hn_daily.py --style <style> --top <topN> --language <language> --outdir /tmp/hn-daily-draft --materials /tmp/hn-daily-draft/HN-materials.json` - Script must only output `HN-materials.json` (no user-facing report body). - Use `HN-materials.json` as the only source for final writing. 4. LLM generation (required, prompt-driven quality): - Use a single strict prompt template to generate final report in selected `language`. - All content quality constraints (summary depth, comment synthesis style, anti-template wording) must be enforced by prompt, not by script templates. - No “summarize then translate”; generate directly in target language. 5. Re-check completion before send (required for retry jobs): - If another concurrent run has already persisted a complete report, do not send duplicate content; return `NO_REPLY`. 6. Send full final report body to current chat. 7. If `persist=true`, write final report to `<outputDir>/HN-daily-YYYY-MM-DD.md` and update `<outputDir>/HN_DAILY_INDEX.md`. ## Success criteria (strict) - `persist=false`: success = full report body delivered in chat. - `persist=true`: success = chat delivery + file write + index update. - Under concurrent retry profile: success can be achieved by primary run or any retry run; retries must skip if the report is already complete. - If any required condition fails, treat run as failed (do not claim completion). ## Output rules - Send only report body to user (no receipts/status metadata). - Never send script draft markdown directly; user-facing report must come from LLM rewrite over materials JSON. - Output must use one language only: the selected `language` for the run (no bilingual/mixed-language output). - Real markdown newlines only; never output literal `\n` in user-visible content. - **Strict source/comment separation (mandatory):** - `Source summary` must summarize only the original article/source content (title/url/snippet and source facts). - `Comment viewpoint synthesis` must summarize only HN comments (`comments_raw`). - Do not put community reactions, usernames, or comment conclusions into `Source summary`. - Do not use source-only facts as a substitute for missing comment viewpoints. - If source content is missing/blocked/too short, mark explicitly: `source is short / info limited`; do not fill the gap with comments. - Top-N structure per item: - Title - Link - HN link - Heat - Source summary - Comment viewpoint synthesis ## Length rules (by selected language) - Default hard rule: source summary must be >=300 chars in zh (>=200 words in en; equivalent depth for others). - Elastic exception: only when source content is genuinely short/information-limited, summary may be shorter than default target. - Comment viewpoint summary target: zh>=80 chars (equivalent depth for others), with the same short-source exception. - When exception is used, explicitly mark "source is short / info limited" (or equivalent in selected language), prioritize verifiable facts + discussion context + actionable implications, and keep concise but information-dense output. - Never inflate length with generic filler text. - Hard anti-padding rule: do **not** append reusable stock tails (e.g., identical “this reflects ...” sentence) across viewpoints/items. - If the same tail sentence appears in 3+ comment viewpoints, the report is invalid and must be rewritten. - **Platform/channel constraints must NOT reduce content quality**: if a single message exceeds platform limits (e.g., Telegram 4096 chars), split into multiple sequential messages rather than compressing or shortening summaries/viewpoints to fit. ## Comment synthesis rules - Must be in selected `language`. - Multi-perspective (not binary pro/con). - Per item, output 5 comment viewpoints when available. - If username exists in source comment, it must be preserved in output. - Only use "insufficient comments" when no usable comments are available. - Summarize viewpoints; do not paste long raw quotes. ## Scheduling rules (concurrent retry profile) - If `reminderTime != off`, create/update a **3-job retry ladder** automatically (no duplicates): 1) Primary run at `reminderTime` (e.g. `HN Daily 06:50`) 2) Immediate retry at `reminderTime + 1m` (e.g. `HN Daily 06:51 Retry`) 3) Delayed retry at `reminderTime + 15m` (e.g. `HN Daily 07:05 Retry`) - **All HN cron jobs must run in isolated sessions**: - `sessionTarget="isolated"` - `payload.kind="agentTurn"` - Never schedule HN generation on `sessionTarget="main"`. - Keep cron payload execution-oriented (not passive reminder), including idempotent checks and send/persist requirements. - All retry jobs must be idempotent via completion checks (see Mandatory execution order step 1 and step 5). - Keep job names aligned with schedule and retry role. - Rationale: cron has no built-in on-failure callback; this retry ladder is the required equivalent for timeout/failure recovery, and isolated execution avoids blocking normal user chat. ## Prompt template requirements (must include) - Generate directly in selected `language`. - Source summary length must meet selected-language threshold. - Each comment viewpoint summary must meet selected-language threshold. - Summaries must be article-specific and fact-based; avoid reusable boilerplate. - Enforce source/comment boundary explicitly in prompt: - Source summary uses only article/source material. - Comment viewpoints use only HN comments. - Never mix the two sections. - Forbid repeated generic closers in comment viewpoints; every viewpoint must end with item-specific substance, not a shared stock sentence. - Comment section must synthesize viewpoints (not raw quote dumping), with usernames when available. ## Pre-send quality gate (mandatory) - Validate final report before sending: - zh summary default >=300 chars per item; - zh comment viewpoint default >=80 chars per viewpoint. - Recommended command: - `scripts/validate_report.py --report <final_report_path> --language <language> --ban-phrase "这也反映了社区对可执行细节与长期影响的关注" --ban-phrase-max 0 --max-repeated-tail 2` - If an item/viewpoint is below default threshold, it must explicitly include a short-source marker (e.g. `source is short / info limited`). - If anti-padding checks fail (banned phrase repetition or repeated tail sentence), rewrite and re-check. - If gate fails, rewrite and re-check; do not send failing report. ## Guardrail - If prompt-driven LLM generation path is not available/validated, keep cron disabled until fixed. - If primary + both retries all fail on the same day, send a concise failure alert to the current chat with the first actionable error cause (do not silently drop the run).

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 hn-daily-brief-1776292608 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 hn-daily-brief-1776292608 技能

通过命令行安装

skillhub install hn-daily-brief-1776292608

下载 Zip 包

⬇ 下载 hn-daily v0.8.2

文件大小: 8.13 KB | 发布时间: 2026-4-16 18:38

v0.8.2 最新 2026-4-16 18:38
v0.8.2: refresh publication; align with worker-oriented execution workflow and latest packaging

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部