← 返回
未分类 Key 中文

Find Cpa Firm

Use whenever the user wants to find, shortlist, vet, or enrich US accounting and tax firms (CPA firms) — financial-statement audit, SOC 1/2 audit, corporate...
用于在需要查找、筛选、审查或完善美国会计税务事务所(CPA事务所)信息时,如财务报表审计、SOC 1/2审计、企业等。
nostrband nostrband 来源
未分类 clawhub v1.0.1 1 版本 100000 Key: 需要
★ 1
Stars
📥 135
下载
💾 1
安装
1
版本
#latest

概述

find-cpa-firm

Drive the ServiceGraph API (https://api.servicegraph.co) to find,

shortlist, and enrich US business-to-business accounting and tax

firms (CPA firms) via the pro_services dataset.

The catalog is B2B-only. Personal tax prep (individual 1040s,

retirement planning, individual estate planning, personal bookkeeping

for freelancers) is out of scope — those firms were filtered during

the catalog audit.

Always pin industry:accounting_tax. Sub-services (audit, tax,

bookkeeping, advisory, M&A diligence, 409A, R&D credits, etc.) are

NOT separate tags — industry:accounting_tax is the most specific

structured level — so practice-area specialization is a keyword

substring search on firm text.

Any HTTP client works (curl, fetch, requests). Examples below use curl.

When NOT to use this skill

  • Personal/individual tax matters: 1040 prep, IRA/Roth conversions, personal estate planning, "what should I do with my refund".
  • Bookkeeping for a freelancer or solo creator's personal income.
  • In-house finance hires (Controller, CFO, Accountant).
  • DIY tax/accounting questions ("how do I claim X", "explain depreciation").
  • Accounting-software comparisons (QuickBooks, Xero, NetSuite).
  • Non-US firms / individual freelance bookkeepers.

MCP server (preferred for authed calls)

If your harness has the ServiceGraph MCP server loaded (tools

containing servicegraph), prefer those — OAuth 2.1 + PKCE keeps the

token in the harness sandbox. Otherwise use the REST flow below.

API surface (dataset id: pro_services)

Every endpoint requires the bearer (Authorization: Bearer vk_…).

No anonymous tier.

EndpointCostUse it for
---------
GET /v1/datasets/pro_services/fields[?include_values=1]freeConfirm accounting_tax is in the industry value list.
GET /v1/datasets/pro_services/check?filter=…freeValidate filter.
POST /v1/datasets/pro_services/translate-intentfree{intent} → DSL filter + sanity count.
GET /v1/datasets/pro_services/search?filter=…&limit=freeBrief firm cards + per-row unlock hint + total.
GET /v1/datasets/pro_services/:apexfreeOne row brief; detail only if unlocked.
POST /v1/datasets/pro_services/unlocks10 credits / firm{apexes:[...]} ≤100; atomic; 30-day TTL on detail.
GET /v1/me/creditsfreeBalance.

Cost model. Discovery / validation / search / brief reads are

free. Detail (url, phone, email, social, address, full platforms

map) costs 10 credits per firm and lasts 30 days.

Auth

vk_ API keys minted in the dashboard. *Keep the token out of the

LLM context* — never read .env into your context; dispatch via

shell.

  1. Try the call first through a shell wrapper that sources .env.local:

```bash

( set -a; [ -f .env.local ] && . ./.env.local; set +a;

curl -sS -H "Authorization: Bearer $SERVICEGRAPH_API_KEY" \

'https://api.servicegraph.co/v1/datasets/pro_services/fields' )

```

  1. On 401 prompt the user:

> "Open https://servicegraph.co/profile/api-keys, create a

> key, and add SERVICEGRAPH_API_KEY=vk_… to .env.local here

> (or export it). Tell me when done. Please don't paste the key

> into chat."

  1. Retry after the user signals ready.

Filter DSL

GitHub-search-style.

filter   := orExpr
orExpr   := andExpr ("OR" andExpr)*
andExpr  := notExpr (("AND")? notExpr)*    # whitespace = implicit AND
notExpr  := ("NOT" | "-") notExpr | atom
atom     := "(" filter ")" | predicate
predicate:= IDENT op valueOrList | bareword
op       := ":" | "=" | ">=" | "<=" | ">" | "<"
valueOrList := value ("," value)*
value    := IDENT | NUMBER | tagAtEvidence
tagAtEvidence := IDENT "@" ("low"|"medium"|"high")
bareword := IDENT | NUMBER          # → keyword:<bareword>

Four rules that bite: AND binds tighter than OR (use parens);

comma list = OR within one predicate; negation is -x or NOT x;

bareword = keyword search (quote multi-word phrases).

Accounting-flavored examples (validate yours with /check):

industry:accounting_tax state:CA audit saas
industry:accounting_tax cpa state:DE,NY
industry:accounting_tax "m&a" diligence
industry:accounting_tax tax 409a
industry:accounting_tax "fractional cfo"
industry:accounting_tax "r&d" tax
industry:accounting_tax "soc 2"
industry:accounting_tax -company_size_signal:solo rating>=4

Practice area → keyword mapping:

User asks forAdd as keyword(s)
------
Audit / financial-statement auditaudit
SOC 1 / SOC 2 audit"soc 2"
Corporate tax / 1120tax, "corporate tax", 1120
Bookkeeping (for a business)bookkeeping
Advisory / fractional CFO"fractional cfo", advisory
M&A diligencem&a, diligence
409A valuation409a
R&D tax credits"r&d", "r&d tax"
IPO readinessipo, readiness
Sales-and-use tax"sales tax", "sales and use"
International tax / transfer pricing"international tax", "transfer pricing"

Identifying firms — apex

Firms are identified by their apex domain (pwc.com, not

www.pwc.com/about).

Recipes

A. CPA firm for a Delaware C-corp audit

User: "CPA firm for our delaware c-corp series A audit, under 50 ppl."

GET /v1/datasets/pro_services/search?filter=industry:accounting_tax+audit+state:DE,NY,CA+-company_size_signal:large_50plus&limit=10
# Present, get pick of 3. "Unlocking 3 = 30 credits, 30-day TTL."
POST /v1/datasets/pro_services/unlocks
  { "apexes": ["firm-a.com", "firm-b.com", "firm-c.com"] }

B. SaaS-experienced audit firms

GET /v1/datasets/pro_services/search?filter=industry:accounting_tax+audit+saas&limit=10

C. M&A diligence

User: "Tax advisor for our M&A — Series-B-stage tech company."

GET /v1/datasets/pro_services/search?filter=industry:accounting_tax+"m&a"+diligence+tech&limit=10

D. Fractional CFO (indirect intent)

User: "Fractional CFO to help us through a Series-A close."

GET /v1/datasets/pro_services/search?filter=industry:accounting_tax+"fractional cfo"&limit=10

If thin, drop the cfo qualifier — fractional alone catches

fractional finance leaders broadly.

E. R&D tax credits

User: "R&D tax credit specialists for biotech."

GET /v1/datasets/pro_services/search?filter=industry:accounting_tax+"r&d"+biotech&limit=10

F. Multi-state DTC sales tax

User: "Outside accountant for state and local tax filings — multi-state DTC business."

GET /v1/datasets/pro_services/search?filter=industry:accounting_tax+("sales tax" OR salt)+multi-state&limit=10

If barely any results, drop multi-state and surface the dimension

from the unlocked detail later.

G. BYO apex list — enrich domains

User pastes 8–20 accounting-firm domains:

  1. GET /v1/datasets/pro_services/:apex per domain — free brief

(404 = not in catalog, no charge).

  1. User picks N to fully enrich. POST /unlocks = 10×N credits,

atomic, detail returned.

  1. Re-runs within 30-day TTL are free.

A 404 here often means the firm focuses on personal tax prep and was

filtered out of the B2B catalog.

Gotchas

  • Always pin industry:accounting_tax. Without it, "tax" / "audit" / "cfo" as keywords match management consulting and other industries.
  • Refuse personal-tax asks. 1040 prep, IRA conversion strategy, personal estate planning, "should I use QuickBooks Self-Employed?" — not in catalog. Tell the user the catalog is B2B-only.
  • industry:accounting_tax is the only structured handle. Practice areas (audit, tax, M&A, 409A, R&D credits) are keyword-only. Multi-word areas split into ANDed barewords unless quoted ("r&d tax credits" → one phrase).
  • In-house finance hires (Controller, CFO, Accountant) are NOT procurement. Recruiting an employee is out of scope.
  • Accounting-software comparisons (QuickBooks vs Xero vs NetSuite) are NOT procurement either.
  • Briefs DO include apex, name, location, ratings. They DON'T include url, phone_primary, email_primary, legal_name, address_full, full platforms — those require an unlock.
  • not_found / not_in_dataset 404 = not in pro_services. Skip; not charged.
  • Unlock is atomic. N apexes either all charge (up to 10×N credits) or none on 402.
  • Within-TTL re-views are free (was_cached:true).

Errors

JSON envelope: {"error": {"code": "...", "message": "..."}}.

StatusCodeWhat to do
---------
400filter_parse_errorposition included; fix and re-validate with /check.
400kind_in_filterStrip any kind: from filter — URL is authoritative.
400field_not_in_datasetDrop the disallowed field.
400invalid_apexRe-normalize.
401unauthorized / invalid_audienceRe-prompt for fresh vk_….
402insufficient_creditsneeded and balance in payload; nothing charged.
404not_found / not_in_datasetSkip; not charged.
429rate_limitedHonor Retry-After.

End-to-end example

User: *"CPA firm for our delaware c-corp series A audit, recommend 5

options under 50 ppl, ideally with SaaS experience and 4-star ratings."*

GET /v1/datasets/pro_services/fields?include_values=1
GET /v1/datasets/pro_services/check?filter=industry:accounting_tax+audit+saas+rating>=4+-company_size_signal:large_50plus
GET /v1/datasets/pro_services/search?filter=...&limit=10
# Present briefs. "Unlocking 5 = 50 credits, 30-day TTL."
POST /v1/datasets/pro_services/unlocks
  { "apexes": ["firm-a.com", "firm-b.com", "firm-c.com", "firm-d.com", "firm-e.com"] }
GET /v1/me/credits

版本历史

共 1 个版本

  • v1.0.1 当前
    2026-06-04 13:56

安全检测

腾讯云安全 (Keen)

队列中

腾讯云安全 (Sanbu)

队列中

🔗 相关推荐

Find Ai Consultancy

nostrband
当用户想查找、筛选、审查或丰富美国AI/ML/数据咨询公司(包括AI/ML开发、MLOps、生成式AI/LLM等)时使用。
★ 0 📥 161

Find Design Agency

nostrband
用于当用户想要寻找、筛选、审查或扩充美国设计和创意机构——平面设计、用户体验/用户界面、产品设计、品牌标识、包装设计
★ 0 📥 163

Servicegraph

nostrband
品牌的入口点指向 ServiceGraph — 当用户明确提及 ServiceGraph 时使用 — "使用 ServiceGraph 来…","ServiceGraph 有哪些数据集?"
★ 1 📥 154