← 返回 Skills 市场
nostrband

Find Software Developer

作者 nostrband · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ⚠ suspicious
50
总下载
0
收藏
1
当前安装
1
版本数
在 OpenClaw 中安装
/install find-software-developer
功能描述
Use whenever the user wants to find, shortlist, vet, or enrich US software development firms — custom software, web development, mobile app development, back...
使用说明 (SKILL.md)

find-software-developer

Drive the ServiceGraph API (https://api.servicegraph.co) to find, shortlist, and enrich US software development firms via the pro_services dataset. The catalog has tens of thousands of US IT-services firms tagged across ~21 service sub-tags including web-development, mobile-app-development, api-integration (singular), devops-services, cloud-services, system-integration, application-modernization, staff-augmentation, and managed-services.

The catalog has no custom-software, devops, api-integrations (plural), or hosting tag — for those user-facing concepts, pin application-modernization + web-development (for custom software), devops-services, or api-integration (singular) as the closest tags and add the keyword.

Always pin industry:it_services. This skill exists to do that automatically — the user shouldn't have to think about catalog taxonomy.

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

Sibling skills — defer when scope is narrow

  • Strictly website / landing-page work (build or refresh a marketing site, simple WordPress) → find-web-developer. If unsure, this skill is the safer default — it covers web dev too.
  • AI/ML modeling specifically (recommendation engines, LLM apps, ML pipelines as the core deliverable) → find-ai-consultancy. Those firms live in a sibling industry (data_ai_consulting), not it_services.
  • Strictly marketing work (SEO, paid media, branding, content) → find-marketing-agency or find-seo-agency.

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.

Endpoint Cost Use it for
GET /v1/datasets/pro_services/fields[?include_values=1] free Confirm it_services industry value and sub-tag names.
GET /v1/datasets/pro_services/check?filter=… free Validate filter.
POST /v1/datasets/pro_services/translate-intent free {intent} → DSL filter + sanity count.
GET /v1/datasets/pro_services/search?filter=…&limit= free Brief firm cards + per-row unlock hint + total.
GET /v1/datasets/pro_services/:apex free One row brief; detail only if unlocked.
POST /v1/datasets/pro_services/unlocks 10 credits / firm {apexes:[...]} ≤100; atomic; 30-day TTL on detail.
GET /v1/me/credits free Balance.

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:

    ( 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' )
    
  2. 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."

  3. 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       := ":" | "=" | ">=" | "\x3C=" | ">" | "\x3C"
valueOrList := value ("," value)*
value    := IDENT | NUMBER | tagAtEvidence
tagAtEvidence := IDENT "@" ("low"|"medium"|"high")
bareword := IDENT | NUMBER          # → keyword:\x3Cbareword>

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).

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

industry:it_services custom software state:TX
industry:it_services service_provided:mobile-app-development
industry:it_services service_provided:devops-services aws
industry:it_services service_provided:api-integration fintech
industry:it_services python aws state:CA
industry:it_services service_provided:system-integration@high rating>=4 has:clutch
industry:it_services service_provided:application-modernization legacy

Tech stack / vertical → keyword mapping (the catalog tags services, not languages or industries served):

User mentions Add as keyword
Python / Django / Flask python
Node.js / TypeScript / React node, react
Go / Rust / Java / .NET go, rust, java, .net
AWS / GCP / Azure aws, gcp, azure
Fintech / healthcare / govtech / SaaS fintech, healthcare, govtech, saas
SOC 2 / HIPAA / compliance soc2, hipaa, compliance

Identifying firms — apex

Firms are identified by their apex domain (thoughtworks.com, not www.thoughtworks.com/about).

Recipes

A. Custom-software shop in a state

GET /v1/datasets/pro_services/search?filter=industry:it_services+service_provided:application-modernization+custom+software+state:TX&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. Mobile app — vertical and platform

GET /v1/datasets/pro_services/search?filter=industry:it_services+service_provided:mobile-app-development+ios&limit=10

iOS / Android distinctions aren't separate tags — use barewords.

C. DevOps + cloud migration

GET /v1/datasets/pro_services/search?filter=industry:it_services+service_provided:devops-services+aws+migration&limit=10

If thin, drop migration first — it's a vertical keyword, not a service tag.

D. Indirect intent — "technical partner to build out tooling"

User: "We need a technical partner to build out our internal tooling, Northeast preferred."

GET /v1/datasets/pro_services/search?filter=industry:it_services+custom+software+state:NY,MA,CT,NJ,PA&limit=10

Or use the translator:

POST /v1/datasets/pro_services/translate-intent
  { "intent": "technical partner to build internal tooling, Northeast preferred" }

E. Vertical + cert (fintech + SOC 2)

GET /v1/datasets/pro_services/search?filter=industry:it_services+custom+software+fintech+soc2&limit=10

F. Quality threshold + third-party signals

GET /v1/datasets/pro_services/search?filter=industry:it_services+service_provided:application-modernization+custom+software+rating>=4+review_count_total>=50&limit=10

G. API/backend specialty + remote

User: "API/backend team to extend our SaaS — Bay Area or remote-friendly."

remote-friendly isn't structured. Use geography_served:national_US (national-scope firms typically serve remotely) plus keywords:

GET /v1/datasets/pro_services/search?filter=industry:it_services+service_provided:api-integration+(state:CA OR geography_served:national_US)+saas&limit=10

H. BYO apex list — enrich domains

User pastes 8–20 domains:

  1. GET /v1/datasets/pro_services/:apex per domain — free brief (404 = not in catalog, no charge).
  2. User picks N to fully enrich. POST /unlocks = 10×N credits, atomic, detail returned.
  3. Re-runs within 30-day TTL are free.

Gotchas

  • Always pin industry:it_services. Without it, web-development / mobile-app-development keywords leak into marketing or design firms.
  • Tag drift: there is no custom-software, devops, api-integrations (plural), or hosting tag. Map to application-modernization + web-development, devops-services, api-integration (singular) plus keywords.
  • industry:data_ai_consulting is a sibling industry, not a sub-tag. AI/ML-focused firms live there — defer to find-ai-consultancy.
  • Defer to find-web-developer for strictly website/landing-page projects. This skill covers web dev as a sub-service, but the dedicated skill ranks higher on narrow web-only asks.
  • Programming language and tech stack are NOT structured tags. python, react, aws, kubernetes, rust are keyword substring matches. Multi-word stacks split into ANDs unless quoted ("ruby on rails").
  • Client-vertical (fintech, healthcare, govtech) is NOT a structured tag. Keyword it.
  • Catalog is US-only B2B. Refuse offshore asks ("a software firm in Bangalore"), individual freelancers, in-house engineering hires, and DIY/code tasks ("debug this", "review this PR").
  • Cloud product comparisons aren't procurement. "Which is better, AWS or GCP?" is a knowledge question.
  • 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": "..."}}.

Status Code What to do
400 filter_parse_error position included; fix and re-validate with /check.
400 kind_in_filter Strip any kind: from filter.
400 field_not_in_dataset Drop the disallowed field.
400 invalid_apex Re-normalize.
401 unauthorized / invalid_audience Re-prompt for fresh vk_….
402 insufficient_credits needed and balance; nothing charged.
404 not_found / not_in_dataset Skip; not charged.
429 rate_limited Honor Retry-After.

End-to-end example

User: "Three custom software firms with healthcare-industry experience, SOC 2-ready, ideally with at least a 4-star rating."

GET /v1/datasets/pro_services/fields?include_values=1
GET /v1/datasets/pro_services/check?filter=industry:it_services+service_provided:application-modernization+custom+software+healthcare+soc2+rating>=4
GET /v1/datasets/pro_services/search?filter=...&limit=10
# Present briefs. "Unlocking 3 = 30 credits, 30-day TTL."
POST /v1/datasets/pro_services/unlocks
  { "apexes": ["firm-a.com", "firm-b.com", "firm-c.com"] }
GET /v1/me/credits
安全使用建议
Install only if you trust the publisher and expect maintainer-grade workflows. Before using it, review the autoreview helper and prefer its no-yolo mode unless full local access is intentional; also require explicit confirmation before moderation, GitHub publishing, production deploys, or account-impacting actions.
能力标签
requires-oauth-tokenrequires-sensitive-credentials
能力评估
Purpose & Capability
The Convex setup, auth, migration, performance, UI proof, PR maintenance, and moderation workflows are generally coherent with their stated purposes, but several are high-impact by design.
Instruction Scope
The autoreview workflow directs use after non-trivial edits and its helper defaults to `--dangerously-bypass-approvals-and-sandbox --sandbox danger-full-access`, which is broader authority than a review-only task normally needs.
Install Mechanism
No obfuscated installer or hidden persistence mechanism was found in the skill files; referenced package and CLI installs are visible in the documentation.
Credentials
The moderation skill can ban or unban users, change roles, and hide or unhide content, and the UI proof workflow can publish artifacts to GitHub; these are disclosed and guarded, but they materially affect accounts, public content, or remote services.
Persistence & Privilege
The artifacts mainly write temporary review files, optional proof artifacts, or project configuration such as `.env.local`; they also rely on existing CLI/auth tokens for staff and GitHub operations rather than bypassing auth.
如何使用
  1. 确保已安装 OpenClaw(本地或 Docker 部署)
  2. 在对话框中输入安装命令:/install find-software-developer
  3. 安装完成后,直接呼叫该 Skill 的名称或使用 /find-software-developer 触发
  4. 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v1.0.0
- Initial release driving the ServiceGraph API to find, shortlist, and vet US software development firms. - Supports search across custom software, web, mobile app, API/back-end, DevOps/cloud, system integration, and hosting-related needs. - Automatically maps user-friendly requests to catalog filters and closest tag matches. - Default focus: IT-services firms based in the US; excludes in-house hires, non-US firms, freelancers, and non-software/AI-specific work. - Includes guidance on authentication, API endpoints, filter syntax, tech/vertical keyword mapping, and usage recipes. - Defers to sibling skills for web-only, AI/ML, or marketing-specific requests.
元数据
Slug find-software-developer
版本 1.0.0
许可证 MIT-0
累计安装 1
当前安装数 1
历史版本数 1
常见问题

Find Software Developer 是什么?

Use whenever the user wants to find, shortlist, vet, or enrich US software development firms — custom software, web development, mobile app development, back... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 50 次。

如何安装 Find Software Developer?

在 OpenClaw 或 Claude Code 对话框中运行命令「/install find-software-developer」即可一键安装,无需额外配置。

Find Software Developer 是免费的吗?

是的,Find Software Developer 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。

Find Software Developer 支持哪些平台?

Find Software Developer 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。

谁开发了 Find Software Developer?

由 nostrband(@nostrband)开发并维护,当前版本 v1.0.0。

💬 留言讨论