pp-hackernews
Original:🇺🇸 English
Translated
Hacker News from your terminal — with a local SQLite store, snapshot history, and agent-native output no other HN tool has. Trigger phrases: `check hacker news`, `search hn`, `what is hn saying about`, `diff the hn front page`, `pulse on hn`, `look up hn user`, `hn who is hiring`, `hn top stories`, `use hackernews`, `run hackernews`.
5installs
Added on
NPX Install
npx skill4agent add mvanhorn/printing-press-library pp-hackernewsTags
Translated version includes tags in frontmatterSKILL.md Content
View Translation Comparison →Hacker News — Printing Press CLI
Prerequisites: Install the CLI
This skill drives the binary. You must verify the CLI is installed before invoking any command from this skill. If it is missing, install it first:
hackernews-pp-cli- Install via the Printing Press installer:
bash
npx -y @mvanhorn/printing-press install hackernews --cli-only - Verify:
hackernews-pp-cli --version - Ensure (or
$GOPATH/bin) is on$HOME/go/bin.$PATH
If the install fails (no Node, offline, etc.), fall back to a direct Go install (requires Go 1.23+):
npxbash
go install github.com/mvanhorn/printing-press-library/library/media-and-entertainment/hackernews/cmd/hackernews-pp-cli@latestIf reports "command not found" after install, the install step did not put the binary on . Do not proceed with skill commands until verification succeeds.
--version$PATHWhen to Use This CLI
Reach for hackernews-pp-cli when you need to monitor or analyze HN signal programmatically: agent-driven daily diffs, topic pulses, hiring-thread aggregation, repost checks before submitting, structured thread digests for context windows. The local store makes follow-up queries cheap and offline-friendly.
When Not to Use This CLI
Do not activate this CLI for requests that require creating, updating, deleting, publishing, commenting, upvoting, inviting, ordering, sending messages, booking, purchasing, or changing remote state. This printed CLI exposes read-only commands for inspection, export, sync, and analysis.
Unique Capabilities
These capabilities aren't available in any other tool for this API.
Local snapshots that compound
-
— See exactly what climbed, fell, appeared, or dropped off the front page since your last sync.
sinceReach for this when an agent wakes up daily and needs to know what shifted on HN since yesterday — without re-fetching 500 items every poll.bashhackernews-pp-cli since --json -
— Stories ranked by the highest comment-to-point ratio over a recent window — the discussions everyone is arguing about.
controversialReach for this when you want stories with high engagement-to-approval — heated debate signal — instead of just popularity.bashhackernews-pp-cli controversial --window 7d --json -
— Show a story's rank trajectory over time from local snapshots — climb, plateau, or fall.
velocityReach for this when an agent asks 'is this story still gaining traction or already cresting' — only meaningful answer comes from snapshots.bashhackernews-pp-cli velocity 47998158 --json -
— Pull top/new/best/show/ask/job lists and recently-changed items into local SQLite for offline use and snapshot history.
syncRun this once per day (or per hour for agents) — it is the foundation that turns since/velocity/controversial/users-stats from impossible into one SQL query.bashhackernews-pp-cli sync --resources updates --agent
Algolia leverage
-
— See per-day mentions, average score, and comment volume for any topic over the last N days.
pulseReach for this when the question is 'is this topic heating up or cooling down' rather than 'what's the top story right now'.bashhackernews-pp-cli pulse rust --days 7 --agent -
— Has this URL been posted before? Lists every prior submission, with score, comments, and date.
repostReach for this before submitting a Show HN — duplicate URLs flame out instantly; you want to know how a prior post did first.bashhackernews-pp-cli repost https://example.com/article -
— Offline full-text search over every story and comment you have ever synced — corpus grows with use.
search localReach for this when investigating long-tail topics or replaying last quarter's research — Algolia might rank it down or drop it; your local corpus will not.bashhackernews-pp-cli search local "vector database" --limit 20 --json
Hiring-thread mining
-
— Aggregate the last N monthly Who-is-Hiring threads: top languages, remote ratio, top companies, location distribution.
hiring statsReach for this when you need quarterly or seasonal hiring trends — language popularity, remote-share shifts, location density — not just this month's listings.bashhackernews-pp-cli hiring stats --months 3 --agent -
— Companies that posted in M of the last N hiring threads, with first-seen, last-seen, and months-posted count.
hiring companiesReach for this when sourcing or trend-tracking — which companies are persistent hirers vs one-off posters — without scraping HNHIRING.com.bashhackernews-pp-cli hiring companies --months 6 --min-posts 3 --agent
Cross-entity local queries
-
— Median and p90 score across a user's submissions, plus traction buckets and hour-of-day score distribution.
users statsReach for this before posting your own work to learn your traction patterns, or when sizing up a poster's history before engaging.bashhackernews-pp-cli users stats pg --json
Command Reference
items — Fetch any HN item (story, comment, job, poll) by ID
- — Get details for a specific story, comment, job, or poll
hackernews-pp-cli items <itemId>
maxitem — Current maximum item ID
- — Returns the largest item ID currently assigned by Hacker News
hackernews-pp-cli maxitem
stories — Browse top, new, and best Hacker News stories
- — Get the latest Ask HN posts
hackernews-pp-cli stories ask - — Get the highest-voted stories on Hacker News
hackernews-pp-cli stories best - — Get the latest Hacker News job postings
hackernews-pp-cli stories job - — Get the newest stories on Hacker News
hackernews-pp-cli stories new - — Get the latest Show HN posts
hackernews-pp-cli stories show - — Get the current top stories on Hacker News
hackernews-pp-cli stories top
updates — Recently changed items and profiles
- — Items and user profiles that have changed recently
hackernews-pp-cli updates
users — Look up Hacker News user profiles
- — Get a user's profile including karma and submission history
hackernews-pp-cli users <userId>
Hand-written commands
- — Pull top/new/best/show/ask/job lists and recent items into the local SQLite store
hackernews-pp-cli sync - — Full-text search Hacker News stories and comments via Algolia (use 'search local' for offline FTS)
hackernews-pp-cli search <query> - — Mine 'Ask HN: Who is hiring' threads (filter, stats, companies)
hackernews-pp-cli hiring - — Mine 'Ask HN: Freelancer? Seeking freelancer?' threads (filter)
hackernews-pp-cli freelance - — Show what changed on the front page since the last sync (added, removed, moved stories)
hackernews-pp-cli since - — Show what HN is saying about a topic — per-day mentions, score, and comment volume
hackernews-pp-cli pulse <topic> - — Find stories with the highest comment-to-point ratio (polarizing discussions)
hackernews-pp-cli controversial - — Has this URL been posted on HN? Lists prior submissions with scores and dates
hackernews-pp-cli repost <url> - — Show a story's rank trajectory across local snapshots
hackernews-pp-cli velocity <id> - — Run a self-diagnostic: API reachability, store writability, config sanity
hackernews-pp-cli doctor
Freshness Contract
This printed CLI owns bounded freshness only for registered store-backed read command paths. In mode, those paths check and may run a bounded refresh before reading local data. never refreshes. reads the API and does not mutate the local store. Set to skip the freshness hook without changing source selection.
--data-source autosync_state--data-source local--data-source liveHACKERNEWS_NO_AUTO_REFRESH=1Covered paths:
hackernews-pp-cli storieshackernews-pp-cli stories askhackernews-pp-cli stories besthackernews-pp-cli stories jobhackernews-pp-cli stories newhackernews-pp-cli stories showhackernews-pp-cli stories tophackernews-pp-cli updates
When JSON output uses the generated provenance envelope, freshness metadata appears at . Treat it as current-cache freshness for the covered command path, not a guarantee of complete historical backfill or API-specific enrichment.
meta.freshnessFinding the right command
When you know what you want to do but not which command does it, ask the CLI directly:
bash
hackernews-pp-cli which "<capability in your own words>"which02--helpRecipes
Daily front-page diff for an agent
bash
hackernews-pp-cli sync && hackernews-pp-cli since --json --select added,removed,movedSync, then diff. The --select narrows the payload to just the change deltas — agents process kilobytes instead of megabytes.
Topic monitoring with selected fields
bash
hackernews-pp-cli pulse openai --days 7 --agent --select buckets.day,buckets.hits,buckets.avg_scorePer-day breakdown of mentions, average score, and comment volume — using --select to pull only the trend axes from the deeply-nested response.
Pre-submit dupe check
bash
hackernews-pp-cli repost https://example.com/article --jsonLists every prior submission of that URL with score, comments, and date — answers the 'has this been posted' question in one round-trip.
Filter Who's Hiring for remote Go roles
bash
hackernews-pp-cli hiring filter "(remote|REMOTE).*\\bGo\\b" --jsonRegex against the latest monthly thread. The double-escaped \b is a real regex word boundary; --json gives you structured rows instead of one big match dump.
Quarterly hiring trend
bash
hackernews-pp-cli hiring companies --months 6 --min-posts 3 --agentCompanies posting in 3+ of the last 6 monthly threads — first-seen, last-seen, total months. Cross-month queries you cannot do without a local store.
Auth Setup
No authentication required.
Run to verify setup.
hackernews-pp-cli doctorAgent Mode
Add to any command. Expands to: .
--agent--json --compact --no-input --no-color --yes-
Pipeable — JSON on stdout, errors on stderr
-
Filterable —keeps a subset of fields. Dotted paths descend into nested structures; arrays traverse element-wise. Critical for keeping context small on verbose APIs:
--selectbashhackernews-pp-cli items 47998158 --agent --select id,name,status -
Previewable —shows the request without sending
--dry-run -
Offline-friendly — sync/search commands can use the local SQLite store when available
-
Non-interactive — never prompts, every input is a flag
-
Read-only — do not use this CLI for create, update, delete, publish, comment, upvote, invite, order, send, or other mutating requests
Response envelope
Commands that read from the local store or the API wrap output in a provenance envelope:
json
{
"meta": {"source": "live" | "local", "synced_at": "...", "reason": "..."},
"results": <data>
}Parse for data and to know whether it's live or local. A human-readable summary is printed to stderr only when stdout is a terminal — piped/agent consumers get pure JSON on stdout.
.results.meta.sourceN results (live)Agent Feedback
When you (or the agent) notice something off about this CLI, record it:
hackernews-pp-cli feedback "the --since flag is inclusive but docs say exclusive"
hackernews-pp-cli feedback --stdin < notes.txt
hackernews-pp-cli feedback list --json --limit 10Entries are stored locally at . They are never POSTed unless is set AND either is passed or . Default behavior is local-only.
~/.hackernews-pp-cli/feedback.jsonlHACKERNEWS_FEEDBACK_ENDPOINT--sendHACKERNEWS_FEEDBACK_AUTO_SEND=trueWrite what surprised you, not a bug report. Short, specific, one line: that is the part that compounds.
Output Delivery
Every command accepts . The output goes to the named sink in addition to (or instead of) stdout, so agents can route command results without hand-piping. Three sinks are supported:
--deliver <sink>| Sink | Effect |
|---|---|
| Default; write to stdout only |
| Atomically write output to |
| POST the output body to the URL ( |
Unknown schemes are refused with a structured error naming the supported set. Webhook failures return non-zero and log the URL + HTTP status on stderr.
Named Profiles
A profile is a saved set of flag values, reused across invocations. Use it when a scheduled agent calls the same command every run with the same configuration - HeyGen's "Beacon" pattern.
hackernews-pp-cli profile save briefing --json
hackernews-pp-cli --profile briefing items 47998158
hackernews-pp-cli profile list --json
hackernews-pp-cli profile show briefing
hackernews-pp-cli profile delete briefing --yesExplicit flags always win over profile values; profile values win over defaults. lists all available profiles under so introspecting agents discover them at runtime.
agent-contextavailable_profilesExit Codes
| Code | Meaning |
|---|---|
| 0 | Success |
| 2 | Usage error (wrong arguments) |
| 3 | Resource not found |
| 5 | API error (upstream issue) |
| 7 | Rate limited (wait and retry) |
| 10 | Config error |
Argument Parsing
Parse :
$ARGUMENTS- Empty, , or
help→ show--helpoutputhackernews-pp-cli --help - Starts with → ends with
install→ MCP installation; otherwise → see Prerequisites abovemcp - Anything else → Direct Use (execute as CLI command with )
--agent
MCP Server Installation
- Install the MCP server:
bash
go install github.com/mvanhorn/printing-press-library/library/media-and-entertainment/hackernews/cmd/hackernews-pp-mcp@latest - Register with Claude Code:
bash
claude mcp add hackernews-pp-mcp -- hackernews-pp-mcp - Verify:
claude mcp list
Direct Use
- Check if installed: If not found, offer to install (see Prerequisites at the top of this skill).
which hackernews-pp-cli - Match the user query to the best command from the Unique Capabilities and Command Reference above.
- Execute with the flag:
--agentbashhackernews-pp-cli <command> [subcommand] [args] --agent - If ambiguous, drill into subcommand help: .
hackernews-pp-cli <command> --help