{"skill":{"slug":"openclaw-feeds","displayName":"openclaw-feeds","summary":"RSS news aggregator. Fetches headlines from curated feeds across three categories: news, games, and finance. Use when the user asks about current news, headlines, what's happening, what's going on, or says \"what's up in news\", \"what's up in finance\", \"what's up in games\", or the German equivalents \"was geht mit nachrichten\", \"was geht mit money\", \"was geht mit gaming\". Also activates for requests like \"give me a news rundown\", \"latest headlines\", \"market news\", \"gaming news\", \"tech news\", \"finance roundup\", or \"briefing\". Returns structured JSON from public RSS feeds — no API keys, no web search needed.","description":"---\nname: openclaw-feeds\ndescription: >\n  RSS news aggregator. Fetches headlines from curated feeds across three categories: news, games,\n  and finance. Use when the user asks about current news, headlines, what's happening, what's going\n  on, or says \"what's up in news\", \"what's up in finance\", \"what's up in games\", or the German\n  equivalents \"was geht mit nachrichten\", \"was geht mit money\", \"was geht mit gaming\". Also\n  activates for requests like \"give me a news rundown\", \"latest headlines\", \"market news\",\n  \"gaming news\", \"tech news\", \"finance roundup\", or \"briefing\". Returns structured JSON from\n  public RSS feeds — no API keys, no web search needed.\nlicense: MIT\ncompatibility: Requires Python 3, feedparser (pip install feedparser), and network access to fetch RSS feeds.\nallowed-tools: Bash(python3:*)\nmetadata:\n  author: nesdeq\n  version: \"3.1.1\"\n  tags: \"rss, news, feeds, headlines, aggregator\"\n---\n\n# Feeds\n\nRSS news aggregator. Fetches all current entries from curated feeds across three categories — news, games, and finance. Concurrent fetching, streamed JSON output. No API key needed.\n\n## Constraint\n\nDo NOT use web search, WebFetch, browser tools, or any other URL-fetching tool when this skill is active. The RSS feeds are the sole data source. Do not supplement, verify, or expand results with external searches. Do not fetch article URLs — summaries are already included in the output.\n\n## Categories\n\nDetect the category from the user's message:\n\n- \"news\", \"headlines\", \"nachrichten\", \"tech news\" → `news`\n- \"finance\", \"markets\", \"money\", \"stocks\", \"economy\" → `finance`\n- \"games\", \"gaming\" → `games`\n\n| Category | Feeds | Sources |\n|----------|-------|---------|\n| `news` | 21 | Ars Technica, Wired, TechCrunch, The Verge, NYT, Heise, Quanta, Aeon, Nautilus, and more |\n| `games` | 10 | GameStar, GamesGlobal, PC Gamer, Polygon, Kotaku, IGN, Rock Paper Shotgun, GamesIndustry.biz |\n| `finance` | 26 | Bloomberg, WSJ, FT, CNBC, MarketWatch, Seeking Alpha, The Economist, Forbes, CoinDesk, Fed, ECB |\n\nFeed lists are defined in [scripts/lists.py](scripts/lists.py).\n\n## How to Invoke\n\nRun one invocation per category. Run multiple if the user asks for more than one.\n\n```bash\npython3 scripts/feeds.py --category news\npython3 scripts/feeds.py --category games\npython3 scripts/feeds.py --category finance\n```\n\n## Output Format\n\nThe script streams a JSON array. The first element is metadata, the rest are entries:\n\n```json\n[{\"category\": \"news\", \"total_entries\": 142, \"sources\": [\"aeon.co\", \"arstechnica.com\"], \"fetched_at\": \"2026-01-31 22:00:00\"}\n,{\"title\": \"Headline Here\", \"url\": \"https://example.com/article\", \"source\": \"arstechnica.com\", \"date\": \"Fri, 31 Jan 2026 12:00:00 GMT\", \"summary\": \"Brief summary text...\"}\n]\n```\n\n| Field | Description |\n|-------|-------------|\n| `title` | Headline text |\n| `url` | Link to full article |\n| `source` | Domain name of the feed source |\n| `date` | Publication date as provided by the feed |\n| `summary` | Brief description, HTML stripped, max 500 chars |\n\n## CLI Reference\n\n| Flag | Description |\n|------|-------------|\n| `-c, --category` | Feed category: `news`, `games`, or `finance` (required) |\n\n## Presenting Results\n\nAfter parsing the output, present a structured, concise rundown:\n\n1. **Group by theme** — cluster related stories under headings (e.g. \"Tech & Industry\", \"Science\", \"Markets\", \"Crypto\")\n2. **Keep it tight** — headline + one-line summary + source attribution per item\n3. **Link to sources** — use markdown links so the user can read more\n4. **Deduplicate** — if multiple feeds cover the same story, mention it once and note cross-source coverage\n5. **Highlight big stories** — if a story appears across 3+ sources, call it out prominently\n\nExample output:\n\n```\n### Tech & Industry\n- **[Headline](url)** — One-line summary *(Source)*\n- **[Headline](url)** — One-line summary *(Source)*\n\n### Science\n- **[Headline](url)** — One-line summary *(Source)*\n```\n\n## Edge Cases\n\n- Failed or timed-out feeds (15s timeout) are silently skipped — remaining feeds still return results.\n- If zero entries are returned, the script exits with `{\"error\": \"No entries found\", \"category\": \"...\"}`.\n- Some entries may lack summaries — they will still have title, URL, and source.\n","topics":["Web Search","Current News","Json","RSS"],"tags":{"latest":"3.1.1"},"stats":{"comments":0,"downloads":4726,"installsAllTime":178,"installsCurrent":29,"stars":5,"versions":1},"createdAt":1769899361762,"updatedAt":1778485891685},"latestVersion":{"version":"3.1.1","createdAt":1769899361762,"changelog":"Initial release of openclaw-feeds: an RSS-based aggregator providing current headlines in news, games, and finance.\n\n- Fetches and aggregates headlines from 57 curated RSS feeds, organized into \"news\", \"games\", and \"finance\" categories.\n- No API keys or browser tools required—fetches data directly from public RSS feeds.\n- Returns structured JSON arrays with metadata and entry fields (headline, link, source, date, summary).\n- CLI supports category selection with `--category`, outputs results as a streaming JSON array.\n- Output can be parsed and presented with grouping, deduplication, and cross-source highlighting according to provided guidelines.\n- Handles failed or missing feeds gracefully; reports errors if zero entries found.","license":null},"metadata":null,"owner":{"handle":"nesdeq","userId":"s1789jfqr432wa7px6cqnk6ded84y56q","displayName":"nesdeq","image":"https://avatars.githubusercontent.com/u/129054196?v=4"},"moderation":null}