← Back to Skills Marketplace
webpudge

AI Capsule

by Pudge · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ✓ Security Clean
34
Downloads
1
Stars
0
Active Installs
1
Versions
Install in OpenClaw
/install ai-capsule
Description
Ranks your daily AI news feed by personal relevance — scores every article and surfaces the most useful ones first.
README (SKILL.md)

AI Capsule — Personal AI News Value Evaluator

Initialization

First time only: run bash $SKILL_DIR/scripts/setup-env.sh to set up the Python venv. Config is created on first run via guided setup.

On every run, resolve the skill directory, Python interpreter, and config path:

SKILL_DIR=$(cd "$(dirname "$(readlink -f "${BASH_SOURCE[0]:-$0}" 2>/dev/null || echo "$0")")" && pwd)
CONFIG_FILE="${AI_CAPSULE_CONFIG:-$HOME/.ai-capsule/config.yaml}"

# Prefer venv; fall back to system python3 for spawned/headless agents (OpenClaw, CI)
if [ -x "$SKILL_DIR/.venv/bin/python" ]; then
  PYTHON="$SKILL_DIR/.venv/bin/python"
else
  PYTHON="$(command -v python3 || command -v python)"
  echo "WARN: venv not found, using system Python ($PYTHON). Run: bash $SKILL_DIR/scripts/setup-env.sh"
fi

echo "SKILL_DIR: $SKILL_DIR"
echo "PYTHON: $PYTHON"
echo "CONFIG_FILE: $CONFIG_FILE"
cat "$CONFIG_FILE" 2>/dev/null || echo "initialized: false"

If initialized: false (or config file missing) → enter the guided setup flow (Step -1), otherwise jump to Step 0.


User Configuration

Config file: ~/.ai-capsule/config.yaml — lives outside the skill directory, survives updates.

Override: set env var AI_CAPSULE_CONFIG=/path/to/config.yaml to use a different file.

Built-in identity profiles:

  • engineer: Is it actionable in a real engineering context?
  • pm: Does it affect product direction, UX, or business decisions?
  • researcher: Does it advance understanding of a technical principle?
  • learner: Is this direction worth investing time to learn systematically?
  • founder: Does it affect tech stack choices, product direction, or competitive positioning?

Built-in purpose profiles (control scoring weights):

  • learn: D×0.35, N×0.25, R×0.2, U×0.1, WPS×0.1
  • solve: U×0.45, R×0.3, D×0.1, N×0.1, WPS×0.05
  • scout: W×0.25, P×0.2, N×0.2, S×0.15, R×0.15, U×0.05

Usage

  • Single article: paste title + body directly
  • Batch: paste a JSON array [{"id":"1","title":"...","content":"..."},...]
  • URL: paste a link starting with http or https
  • Daily: say "daily" or "daily mode"
  • Reconfigure: say "reconfigure" → Claude resets initialized: false and walks through setup again

Execution Steps

Step -1: Guided Setup (first run only)

Runs when initialized: false or config file is missing.

Question 1 — Your role

What role do you primarily take when consuming AI news?

  • A) Application engineer / full-stack engineer → engineer
  • B) AI researcher / ML engineer → researcher
  • C) Product manager / founder → pm or founder
  • D) Student / self-learner → learner
  • E) Other (describe freely)

Question 2 — Your familiar areas

e.g. LLM application development, RAG, Agent frameworks, model fine-tuning…

Question 3 — Your primary purpose

  • A) Follow the technical frontier (learn)
  • B) Solve concrete problems at work (solve)
  • C) Scan market trends (scout)
  • D) Context-dependent (default: learn)

Question 4 — What you don't want to see

e.g. pure marketing fluff, trend analysis with no code…

Question 5 — Output language

What language should card text, value analysis, and scoring reasons be written in?

  • A) Chinese / 中文 (default)
  • B) English
  • C) Other (describe freely, e.g. "日本語")

Proper nouns (model names, framework names, GitHub repo names) always stay in their original form.

Question 6 — Data directory

Where should daily reports, history, and dedup files be stored?

  • A) ~/.ai-capsule/data (default — survives skill updates)
  • B) Custom path (describe freely)

After collecting answers, write the config:

mkdir -p ~/.ai-capsule
cat > "${AI_CAPSULE_CONFIG:-$HOME/.ai-capsule/config.yaml}" \x3C\x3C 'EOF'
initialized: true
identity: [user description]
role_desc: [user description]
familiar_areas:
  - [area 1]
default_identity: [engineer/pm/researcher/learner/founder]
default_purpose: [learn/solve/scout]
output_language: zh  # zh = Chinese / en = English / other language name
data_dir: ~/.ai-capsule/data
EOF

Step 0: Mode Detection

  • Input starts with http(s)://URL mode
  • Input starts with [ and looks like a JSON array → Batch mode
  • Input contains "daily", "daily mode", "每日模式", or "日报" → Daily mode
  • Ambiguous → ask the user

Step 1: Content Retrieval

Fetch tool mapping — use whichever tool your agent runtime provides:

Runtime Tool
Claude Code WebFetch
Codex / shell agents Bash: curl \x3Curl> + python parse
Tavily agents tavily_extract
Fallback Ask user to paste content

URL mode: Fetch and extract main text. For WeChat links, ask user to paste manually.

Batch mode: Parse JSON, extract title and content/text fields, score each article.

Daily mode: Read and execute $SKILL_DIR/sections/daily-mode.md.

Single article mode: Go directly to Step 2.

Step 2: Dedup Check

Dedup file: {data_dir}/dedup-titles.txt (one title per line).

Daily mode: handled centrally in sections/daily-mode.md Step 3 — never judge manually.

Single / URL / Batch mode:

grep -Fx "article title" "$(
  "$PYTHON" -c "
import os, pathlib, yaml
cfg = yaml.safe_load(open(os.environ.get('AI_CAPSULE_CONFIG', str(pathlib.Path.home()/'.ai-capsule/config.yaml'))))
print(cfg.get('data_dir','~/.ai-capsule/data').replace('~', str(pathlib.Path.home())))
")/dedup-titles.txt"

If output is non-empty, skip and say: "This article has already been scored (title: XXX)."

Step 3: Scoring

Read default_identity, default_purpose, and output_language (default: zh) from $CONFIG_FILE.

Scoring framework: see $SKILL_DIR/sections/scoring.md (Read the file before every run).

Runtime mode switches:

  • "learn" / "学习" → PURPOSE = learn
  • "solve" / "解决问题" → PURPOSE = solve
  • "scout" / "找灵感" → PURPOSE = scout
  • "pm perspective" / "engineer perspective" / etc. → switch IDENTITY

Always output the score_json block first:

\x3Cscore_json>
{
  "title": "article title",
  "source": "hf | openai | anthropic | hn | reddit | github | producthunt | blog | unknown",
  "url": "taken directly from pending.json or fetch result — never construct from title",
  "identity": "engineer",
  "purpose": "learn",
  "R": 8, "U": 7, "N": 6, "D": 8,
  "W": 5, "P": 6, "S": 4,
  "total": 7.2,
  "F": 9,
  "final_score": 7.2,
  "action": "READ",
  "summary": "article entity + core value",
  "reasons": {
    "R": "specific relevance reason",
    "U": "specific utility reason",
    "N": "specific novelty reason",
    "D": "specific depth reason",
    "W": "specific wow reason",
    "P": "specific perspective reason",
    "S": "specific cross-domain reason"
  }
}
\x3C/score_json>

F: Personal Fit (0–10), assessed against familiar_areas and dislikes in config. final_score = total × (0.7 + 0.3 × F/10) — sorting only, never displayed. action: TRY (runnable code/tool) / READ (deep content) / SCAN (brief/low score).

Step 4: Display Output

Output format: see $SKILL_DIR/sections/output-format.md (Read the file before every run).

Language rule: all card text follows output_language. Always keep in original form: article titles, technical terms, model/framework names, GitHub repo names, URLs, Action tags (TRY/READ/SCAN).

Batch / Daily mode: output detailed cards only, sorted high-to-low by score — no summary table.

Step 5: Append Records

Append to {data_dir}/history.jsonl (with timestamp) and {data_dir}/dedup-titles.txt.


Data Source Management

Source configs: $SKILL_DIR/sources/{industry}.yaml

View sources:

"$PYTHON" "$SKILL_DIR/sources_extract.py" --markdown --industry ai

Add a source:

bash $SKILL_DIR/scripts/add-source.sh --industry ai --type rss     --name "Name" --url https://example.com/feed
bash $SKILL_DIR/scripts/add-source.sh --industry ai --type webfetch --name "Name" --url https://example.com --note "hint"
bash $SKILL_DIR/scripts/add-source.sh --industry ai --type tavily  --name "Name" --query "search terms" --domains "reddit.com"

Source schema:

# RSS — fetched automatically by fetch.py
- name: Source Name
  type: rss
  url: https://...
  limit: 5
  handler: huggingface    # optional: huggingface | hacker_news

# URL fetch — agent fetches in daily Step 2
- name: Source Name
  type: webfetch
  url: https://...        # use YYYY/M/D placeholder for date-based URLs
  limit: 5
  note: "hint for the agent"

# Tavily search — agent searches in daily Step 2
- name: Source Name
  type: tavily
  query: "search terms"
  include_domains:
    - reddit.com
  time_range: day         # day | week | month
  limit: 5

New industry: create $SKILL_DIR/sources/{industry}.yaml using ai.yaml as template.

Usage Guidance
Install only if you are comfortable with the skill fetching public web/news sources and storing your preferences plus digest history locally. Keep the data directory at the default or another dedicated folder, and review any custom sources you add because fetched pages and search results are untrusted content.
Capability Tags
crypto
Capability Assessment
Purpose & Capability
The stated purpose is ranking daily AI news by user preferences, and the fetch, scoring, output, and source-management files all support that purpose.
Instruction Scope
Runtime modes are explicit: setup, single article, URL, batch, daily, and reconfigure; no hidden role changes, credential harvesting, exfiltration, or destructive unrelated instructions were found.
Install Mechanism
Installation uses a Python virtualenv in the skill directory and installs four ordinary dependencies from requirements.txt; no autostart, background worker, shell profile edit, or privilege escalation is present.
Credentials
The skill uses network access to fetch public RSS, web pages, user-provided URLs, and optional Tavily searches, which is proportionate for a news digest but should be treated as untrusted web content.
Persistence & Privilege
It writes config and digest state under ~/.ai-capsule by default, with a user-configurable data directory, and deletes only its pending.json work file; this persistence is disclosed and purpose-aligned.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install ai-capsule
  3. After installation, invoke the skill by name or use /ai-capsule
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.0
Initial release
Metadata
Slug ai-capsule
Version 1.0.0
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 1
Frequently Asked Questions

What is AI Capsule?

Ranks your daily AI news feed by personal relevance — scores every article and surfaces the most useful ones first. It is an AI Agent Skill for Claude Code / OpenClaw, with 34 downloads so far.

How do I install AI Capsule?

Run "/install ai-capsule" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is AI Capsule free?

Yes, AI Capsule is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does AI Capsule support?

AI Capsule is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created AI Capsule?

It is built and maintained by Pudge (@webpudge); the current version is v1.0.0.

💬 Comments