pp-company-goat
Original:🇺🇸 English
Translated
Look up startups across SEC Form D, GitHub, Hacker News, Companies House, YC, and Wikidata in one command — including the SEC fundraising data hidden behind paid Crunchbase tiers. Trigger phrases: `look up this startup`, `research <company>`, `what does <company> do`, `form D for <company>`, `is <company> still active`, `compare <a> and <b>`, `use company-goat`, `run company-goat-pp-cli`.
11installs
Added on
NPX Install
npx skill4agent add mvanhorn/printing-press-library pp-company-goatTags
Translated version includes tags in frontmatterSKILL.md Content
View Translation Comparison →Company GOAT — 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:
company-goat-pp-cli- Install via the Printing Press installer:
bash
npx -y @mvanhorn/printing-press install company-goat --cli-only - Verify:
company-goat-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/developer-tools/company-goat/cmd/company-goat-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
Use Company GOAT when an agent or human needs structured company-research data on a small or midsize startup — fundraising, engineering signal, mention timeline, legal entity, domain age — without paying for Crunchbase Pro. Best for one-company-at-a-time deep research. Not for bulk discovery (sources don't scale to thousands of queries) and not for global private-market funding-graph queries (no source has that for free).
The killer feature: SEC Form D, free
Most US startups raising priced equity rounds (Series Seed → Series C, Reg D 506(b)/506(c)) file Form D with the SEC within 15 days of first sale. The filing names the issuer, the offering amount, the exemption claimed, and the related persons (officers, directors, promoters). Crunchbase Pro charges $999/year for a wrapper around this same source; this CLI extracts it directly from EDGAR for free. Reach for when an agent needs to verify a US startup's actual fundraising history rather than quote Crunchbase Free's empty "undisclosed" rows.
fundingCoverage at a glance
- SEC Form D / /
funding— US-only. Reg D priced rounds. Pre-Series-A SAFEs are not covered. Empty filings + afunding-trendis the expected response for non-US companies, pre-priced-round companies, and companies that just haven't filed yet. When Form D is empty,coverage_notefalls back to a broader EDGAR full-text search and surfaces mentions binned by signal class: subsidiary (10-K parent mentions), debt (Venture Lending and Leasing portfolio mentions), acquisition (8-K parent disclosures), and other.fundingalso searches across all form types, not just Form D. Disambiguation: EDGAR's full-text search matches by name fragment, so "Notion" hits both Notion Labs and Notion Capital VC. The result includesfunding --whoandcik_summarieswhenever multiple distinct CIKs match. Re-call withis_ambiguous: true(CIK from the summary) to filter to the correct entity. The compound commands (--cik <id>,snapshot,compare) propagate the ambiguity flag through their output and refuse to synthesize a side-by-side number when ambiguous — the agent decides which CIK is correct using broader context (Wikidata founders, GitHub org alignment, the user's intent) and re-runssignalto confirm.funding --ciksurfacessignalas its own signal class so cross-source consistency checks aren't trusted blindly.Form D match is ambiguous - Companies House / — UK Ltd / PLC only. Requires
legal --region uk(free at developer.companieshouse.gov.uk).COMPANIES_HOUSE_API_KEY - GitHub / — Any public org. Optional
engineeringraises rate limits from 60/hr to 5000/hr.GITHUB_TOKEN - Hacker News / /
mentions— Algolia full-text search across HN since 2007. No auth.launchesreturns both a year-month histogram AND the top-N stories sorted by points (usementionsto widen, default 5).--top Nis the Show-HN-only flavor — use it for "did this company ever post a Show HN" questions; uselaunchesfor "what do people say about this company on HN."mentions - YC directory / — YC-backed companies only.
yc - Wikidata / — Sparse on early-stage; mostly useful for established companies.
wiki - RDAP / DNS / — Any registered domain.
domain
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.
Multi-source orchestration
-
— Look up a company across SEC Form D, GitHub, Hacker News, Companies House, YC, Wikidata, and DNS in one command — rendered as a unified terminal summary in seconds.
snapshotWhen you need to evaluate a startup quickly, this is the one command that tells you whether they raised, are shipping code, are talked about, and are legitimate — without 8 browser tabs.bashcompany-goat-pp-cli snapshot --domain stripe.com --json -
— Surface suspicious cross-source patterns. Example: 'Form D says raised $5M in 2024 but GitHub org has 0 commits since 2022' or 'YC entry says Active but website domain expired'.
signalWhen deciding whether to engage with a startup, this command flags zombie companies and stale fundraising stories without you having to open every tab.bashcompany-goat-pp-cli signal --domain acme-corp.com --json
Killer feature
-
— See structured SEC Form D filings for a US private company — offering amount, filing date, exemption claimed (Reg D 506(b) vs 506(c)), related entities, and state of incorporation.
fundingWhen an agent needs to verify a US startup's actual fundraising history, this is the single most reliable free signal. Avoid agents quoting Crunchbase Free's empty 'undisclosed' rows.bashcompany-goat-pp-cli funding --domain stripe.com --json -
— Time series of Form D filings for a company across years — shows fundraising cadence and gaps. Useful for spotting 'they haven't raised since 2022' silently.
funding-trendUse this when an agent needs to summarize a company's fundraising arc, not just the latest round.bashcompany-goat-pp-cli funding-trend --domain stripe.com --since 2018 --json -
— Show every Form D filing that names a given person (officer, large holder). Reveals serial founders, repeat advisors, prolific investors.
funding --whoUse when an agent needs to map who's behind a constellation of startups, or verify a founder's actual filing history.bashcompany-goat-pp-cli funding --who 'Patrick Collison' --json
Local state that compounds
-
— Search the YC directory by free text + --batch and --industry filters. Free-text matches against name, one-liner description, industry, and location.
searchAn agent tasked with 'find a YC fintech with "agent" in the description' has a one-shot query rather than scrolling the YC directory.bashcompany-goat-pp-cli search 'agent' --industry fintech -
— Two snapshots aligned column-by-column for direct comparison. Free in this CLI; paid feature elsewhere.
compareWhen evaluating two competing startups, this is the one-shot comparison that doesn't require flipping between tabs.bashcompany-goat-pp-cli compare stripe.com adyen.com --json
Command Reference
filings — SEC EDGAR Form D filings — the primary data source for US private fundraising disclosure
- — Fetch all SEC submissions for a given CIK (Central Index Key). Used as the seed call when resolving a company's...
company-goat-pp-cli filings
Hand-written commands
- — Resolve a company name to a canonical domain. Returns numbered candidates if ambiguous; --pick N or --domain to...
company-goat-pp-cli resolve <name-or-domain> - — SEC EDGAR Form D filings + YC batch lookup. Shows offering amount, filing date, exemption claimed, related entities...
company-goat-pp-cli funding <co> - — GitHub org metadata: repo count, contributor count, commit cadence, top languages.
company-goat-pp-cli engineering <co> - — Show HN posts about this company, sorted by points. Includes launch year for spotting dead vs. active launches.
company-goat-pp-cli launches <co> - — Hacker News mention timeline: monthly histogram of mentions over time via Algolia full-text search.
company-goat-pp-cli mentions <co> - — Legal entity lookup. UK via Companies House (optional COMPANIES_HOUSE_API_KEY); US via SEC EDGAR Form D issuer...
company-goat-pp-cli legal <co> - — Y Combinator directory entry if the company was YC-backed: batch, status, location, description.
company-goat-pp-cli yc <co> - — Wikidata company facts: founded date, founders, HQ, industry, key people. Sparse on early-stage startups.
company-goat-pp-cli wiki <co> - — Domain age via RDAP/WHOIS, DNS records, and CNAME-based hosting hint (Vercel/Netlify/Heroku/Cloudflare Pages/AWS/GCP).
company-goat-pp-cli domain <co> - — Fan out across all 7 sources in parallel and render a unified summary. The headline command. Uses cliutil.FanoutRun...
company-goat-pp-cli snapshot <co> - — Two snapshots side-by-side, aligned by section. For evaluating which of two startups looks healthier.
company-goat-pp-cli compare <a> <b> - — Search the YC directory by free text +
company-goat-pp-cli search <query>and--batchfilters. Cross-source FTS5 over the synced store is on the v1 roadmap; today this is YC-only.--industry - — Cross-source consistency check. Flags suspicious patterns like 'raised in 2024 but no GitHub commits since 2022'....
company-goat-pp-cli signal <co> - — Time series of Form D filings over time. Useful for charting a startup's fundraising cadence.
company-goat-pp-cli funding-trend <co> - — Pull syncable resources (YC directory and any other configured) into local SQLite. Use
company-goat-pp-cli syncto pick a subset. Subsequent reads with--resourcesquery offline.--data-source local
Finding the right command
When you know what you want to do but not which command does it, ask the CLI directly:
bash
company-goat-pp-cli which "<capability in your own words>"which02--helpRecipes
Quick due diligence on a US startup
bash
company-goat-pp-cli snapshot --domain anthropic.com --jsonFan out across all 7 sources and render a unified summary. Use to skip name resolution and go straight to the canonical entity. Each source returns so partial failures are visible.
--domain{status, data, note, elapsed}Find every SEC filing for a founder
bash
company-goat-pp-cli funding --who 'Patrick Collison' --jsonReturns every Form D filing where this person is named — useful for mapping serial founders and repeat investors.
Compare two competing startups
bash
company-goat-pp-cli compare ramp.com brex.comAligns snapshots side-by-side; agent-readable. Use for tradeoff analysis.
Build a research database
bash
company-goat-pp-cli sync && company-goat-pp-cli search 'fintech'Pulls the YC directory and any other syncable resources into local SQLite, then full-text searches the synced index. Subsequent reads can use to query offline.
--data-source localSurface suspicious patterns
bash
company-goat-pp-cli signal --domain acme-corp.com --jsonCross-source consistency check — flags cases like 'raised $X in 2024 but GitHub silent since 2022' that no single source would catch.
Auth Setup
No required keys. Three optional environment variables expand coverage and rate limits:
- — Sent in the SEC EDGAR User-Agent header to comply with EDGAR's fair-access policy. Recommended for any non-trivial use of
COMPANY_PP_CONTACT_EMAIL=you@example.com/funding/funding-trend.snapshot - — Raises GitHub API rate limit from 60/hr to 5000/hr.
GITHUB_TOKENworks. Used bygh auth token,engineering.snapshot - — Required for
COMPANIES_HOUSE_API_KEY. Register free at developer.companieshouse.gov.uk and create a REST application.legal --region uk
SEC EDGAR requests are paced and retried automatically. The CLI honors , backs off on 429/5xx responses, and exits with code 7 if SEC continues throttling after retries.
Retry-AfterRun to verify which of these are detected.
company-goat-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:
--selectbashcompany-goat-pp-cli filings --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:
company-goat-pp-cli feedback "the --since flag is inclusive but docs say exclusive"
company-goat-pp-cli feedback --stdin < notes.txt
company-goat-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.
~/.company-goat-pp-cli/feedback.jsonlCOMPANY_FEEDBACK_ENDPOINT--sendCOMPANY_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.
company-goat-pp-cli profile save briefing --json
company-goat-pp-cli --profile briefing filings
company-goat-pp-cli profile list --json
company-goat-pp-cli profile show briefing
company-goat-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--helpoutputcompany-goat-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/developer-tools/company-goat/cmd/company-goat-pp-mcp@latest - Register with Claude Code:
bash
claude mcp add company-goat-pp-mcp -- company-goat-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 company-goat-pp-cli - Match the user query to the best command from the Unique Capabilities and Command Reference above.
- Execute with the flag:
--agentbashcompany-goat-pp-cli <command> [subcommand] [args] --agent - If ambiguous, drill into subcommand help: .
company-goat-pp-cli <command> --help