End-to-end hiring signal composite. Takes any set of companies, detects job postings that your product augments or replaces, finds relevant people (the hiring manager, buyers, champions, users), and drafts personalized outreach using the job role as the hook. Tool-agnostic — works with any company source, job board, contact finder, and outreach platform.
npx gooseworks install --claude # Then in your agent: /gooseworks <prompt> --skill hiring-signal-outreach
Detects job postings at target companies where the role being hired for is one your product augments, replaces, or directly supports. Finds the right people to contact (not just the person being hired — the hiring manager, budget holder, and potential champions), then drafts personalized outreach using the job posting as the hook.
Why hiring signals work: When a company posts a job, they've already acknowledged the problem your product solves. They've budgeted for it (headcount is budget). They're actively evaluating how to solve it. Your email arrives at exactly the moment they're thinking about this problem — and you're offering a faster, cheaper, or complementary solution.
Load this composite when:
On first run for a client/user, collect and store these preferences. Skip on subsequent runs.
| Question | Purpose | Stored As |
|---|---|---|
| What does your product do? (1-2 sentences) | Match against job descriptions | company_description |
| What job roles does your product replace? | Strongest signal — they're hiring for what you automate | roles_replaced |
| What job roles does your product augment? | Good signal — your product makes this person more effective | roles_augmented |
| What job roles buy your product? | Contact finding — who holds the budget | buyer_titles |
| What job roles champion your product? | Contact finding — who feels the pain daily | champion_titles |
| What job roles use your product? | Contact finding — who would operate it | user_titles |
| What keywords in a job description indicate relevance? | Filters out false positives | jd_keywords |
Example for an AI calling product:
roles_replaced: ["BDC Representative", "Call Center Agent", "Appointment Setter"]
roles_augmented: ["Sales Manager", "BDC Manager", "Service Advisor"]
buyer_titles: ["VP Sales", "Director of Operations", "General Manager", "COO"]
champion_titles: ["BDC Manager", "Sales Manager", "Fixed Ops Director"]
user_titles: ["BDC Rep", "Service Advisor", "Sales Consultant"]
jd_keywords: ["inbound calls", "outbound calls", "appointment setting", "customer follow-up"]| Question | Options | Stored As |
|---|---|---|
| How should we find job postings? | LinkedIn Jobs / Indeed / Apollo / Google Jobs / Web search | job_search_tool |
| How far back should we look? | 7 / 14 / 30 days | lookback_days |
| Question | Options | Stored As |
|---|---|---|
| How should we find contacts at these companies? | Apollo / LinkedIn / Clearbit / Web search | contact_tool |
| Question | Options | Stored As |
|---|---|---|
| Where do you want outreach sent? | Smartlead / Instantly / Outreach.io / Lemlist / CSV export | outreach_tool |
| Email or multi-channel? | Email only / Email + LinkedIn | outreach_channels |
| Question | Purpose | Stored As |
|---|---|---|
| What problem do you solve? | Email hook | pain_point |
| Name 2-3 proof points (customers, metrics, results) | Email credibility | proof_points |
| What's the cost comparison vs. a full-time hire? | ROI angle for outreach | cost_comparison |
| How fast can you deploy vs. a new hire? | Speed angle | deployment_speed |
Store config in: clients/<client-name>/config/signal-outreach.json or equivalent.
Purpose: For each company in the input list, find active job postings that match roles your product replaces or augments.
companies: [
{
name: string # Required
domain: string # Required
industry?: string # Optional
size?: string # Optional
}
]
roles_replaced: string[] # From config
roles_augmented: string[] # From config
jd_keywords: string[] # From config
lookback_days: integer # From config (default: 14)For each company (or in batches):
Search for job postings using the configured job_search_tool:
company_name + role_title for each role in roles_replaced and roles_augmentedsite:linkedin.com/jobs OR site:indeed.com "{company}" "{role}""{company_name}" AND ("hiring" OR "job" OR "careers") AND ("{role_1}" OR "{role_2}")For each job posting found, extract:
Classify each posting:
roles_replaced. Your product could eliminate or reduce the need for this hire. This is the strongest signal.roles_augmented. Your product makes this person more effective — they'd want it as a tool. Good signal.jd_keywords. Weaker signal — verify relevance.Filter: Drop companies with no matching job postings. Drop postings older than lookback_days.
companies_hiring: [
{
company: {
name: string
domain: string
industry: string
}
job_postings: [
{
title: string
location: string
posted_date: string
description_summary: string # 2-3 sentence summary of the role
source_url: string
signal_type: "replaces" | "augments" | "keyword_match"
relevance_reasoning: string # Why this posting matters for your product
}
]
posting_count: integer
strongest_signal: "replaces" | "augments" | "keyword_match"
}
]Found hiring signals at X of Y companies:
| Company | Postings | Strongest Signal | Top Role | Posted |
|---------|----------|-----------------|----------|--------|
| Acme Corp | 3 | Replaces | BDC Representative | 3 days ago |
| Beta Inc | 1 | Augments | Sales Manager | 1 week ago |
| ... | ... | ... | ... | ... |
Signal breakdown: X "replaces" (strongest), Y "augments", Z "keyword match"
Proceed with qualification? (Y/n)Purpose: Rank companies by outreach priority based on signal strength, relevance, and timing. Pure LLM reasoning — inherently tool-agnostic.
companies_hiring: [...] # From Step 1 output
your_company: {
description: string
pain_point: string
proof_points: string[]
cost_comparison: string
deployment_speed: string
}For each company, evaluate:
| Criterion | Weight | How to Assess |
|---|---|---|
| Signal type | Highest | "Replaces" > "Augments" > "Keyword match" |
| Posting volume | High | Multiple relevant postings = scaling that function = bigger need |
| Recency | High | Posted <7 days ago = actively evaluating. 14+ days = may have candidates already |
| Role seniority | Medium | Hiring a VP of the function you sell into = strategic buy. Hiring an individual contributor = operational buy. Both are good, different approach. |
| Industry fit | Medium | Is their industry one where your product has proven results? |
For each qualified company, generate:
qualified_companies: [
{
...company_hiring_fields,
priority_tier: "tier_1" | "tier_2" | "tier_3"
relevance_reasoning: string
outreach_angle: string
recommended_framing: "replace" | "complement" | "scale"
}
]
dropped_companies: [
{ name: string, drop_reason: string }
]## Qualification Results
### Tier 1 — Act Today (X companies)
| Company | Signal | Top Role | Framing | Angle |
|---------|--------|----------|---------|-------|
| Acme Corp | Replaces | BDC Rep (x3) | Replace | Before you hire 3 BDC reps... |
### Tier 2 — Act This Week (X companies)
| ... |
### Tier 3 — Queue (X companies)
| ... |
### Dropped (X companies)
| Company | Reason |
|---------|--------|
| ... | ... |
Approve this list before we find contacts?Purpose: For each qualified company, find the right people to contact. Unlike the funding composite, here we also identify who posted the job (the hiring manager) — they're often the best first contact.
qualified_companies: [...] # From Step 2 output
buyer_titles: string[] # From config
champion_titles: string[] # From config
user_titles: string[] # From config
max_contacts_per_company: integer # Default: 3-5For each qualified company, use the configured contact_tool:
First: Identify the hiring manager. The person who posted or owns the job posting is the most relevant contact.
Second: Find buyer-level contacts. People with buyer_titles at this company — they control budget.
Third: Find champions. People with champion_titles — they feel the pain daily and can advocate internally.
Classify each contact:
Cap at max_contacts_per_company. Prioritize: hiring manager > buyer > champion > user.
contacts: [
{
person: {
full_name: string
first_name: string
last_name: string
title: string
email: string | null
linkedin_url: string | null
role_type: "hiring_manager" | "buyer" | "champion" | "user"
}
company: {
name: string
domain: string
priority_tier: string
outreach_angle: string
recommended_framing: string
}
job_context: {
relevant_posting_title: string # The job posting that triggered this signal
signal_type: string # "replaces" or "augments"
posting_url: string
description_summary: string
}
}
]## Contacts Found
### Acme Corp (Tier 1 — Hiring 3x BDC Reps, "Replace" framing)
| Name | Title | Role Type | Email | LinkedIn |
|------|-------|-----------|-------|----------|
| Sarah Chen | VP Sales | Hiring Manager | sarah@acme.com | ... |
| Mike Johnson | COO | Buyer | mike@acme.com | ... |
| Lisa Park | BDC Manager | Champion | lisa@acme.com | ... |
Relevant posting: "BDC Representative" (posted 3 days ago)
### Beta Inc (Tier 2 — Hiring Sales Manager, "Complement" framing)
| ... |
Total: X contacts across Y companies
Approve before we draft emails?Purpose: For each contact, draft a personalized email sequence using three layers of personalization: the job posting context, your company's value, and the prospect's company context. Pure LLM reasoning — inherently tool-agnostic.
contacts: [...] # From Step 3 output (includes job_context per contact)
your_company: {
description: string
pain_point: string
proof_points: string[]
cost_comparison: string # e.g. "4x cheaper than a full-time hire"
deployment_speed: string # e.g. "Live in 2 weeks vs. 3-month hiring cycle"
}
sequence_config: {
touches: integer # Default: 3
timing: integer[] # Default: [1, 5, 12]
personalization_tier: 1 | 2 | 3
tone: string
cta: string
}Select framework based on framing:
Build three layers of personalization per contact:
| Layer | Source | Used In |
|---|---|---|
| Job posting context | Step 1 — the specific role, responsibilities, what the JD says | Subject line + hook |
| Your company context | Config — what you do, proof points, cost comparison | Body — proof + offer |
| Prospect company context | Step 2 — industry, what they do, why they're hiring | Body — relevance framing |
Adapt email angle by role_type:
| Role Type | Email Angle | Example Hook |
|---|---|---|
| Hiring manager | "Before you fill that role" | "I saw you're hiring a BDC Rep — before you finalize that, worth seeing what [product] does instead." |
| Buyer | Cost/ROI comparison | "You're budgeting for 3 BDC reps ($180K/year). [Product] handles the same workload for a fraction of that." |
| Champion | "This will make your life easier" | "When your new BDC rep starts, they'll need tools to be effective from day one. That's what [product] does." |
| User | "You'll want this on your desk" | "If you're scaling the BDC function at [company], [product] handles [task] so you can focus on [higher-value work]." |
Follow email-drafting skill rules:
email_sequences: [
{
contact: { full_name, email, title, role_type, company_name }
job_context: { posting_title, signal_type }
sequence: [
{
touch_number: integer
send_day: integer
subject: string
body: string
framework: string
personalization_layers: {
job_posting: string # What from the JD was referenced
company_context: string # What proof/value was used
prospect_context: string # What about their company was referenced
}
word_count: integer
}
]
}
]Present 3-5 sample sequences showing each role_type and framing:
## Sample Emails for Review
### Hiring Manager: Sarah Chen, VP Sales @ Acme Corp
Signal: Hiring 3x BDC Representatives | Framing: Replace
**Touch 1 — Day 1**
Subject: Before you fill those BDC roles
> Hi Sarah — I noticed Acme is hiring three BDC reps. Before you go through
> a 3-month hiring cycle, worth seeing what companies like [peer] are doing
> instead...
> [full email]
### Buyer: Mike Johnson, COO @ Acme Corp
Signal: Same | Framing: ROI
**Touch 1 — Day 1**
Subject: $180K/year in BDC hires — or this
> Hi Mike — Acme's hiring 3 BDC reps. At ~$60K each fully loaded, that's
> $180K/year. [Product] handles the same call volume for...
> [full email]
---
Approve these samples? I'll generate the rest in the same style.Identical to funding-signal-outreach Step 5. Package contacts + email sequences for the configured outreach tool. See that composite for the full handoff process.
campaign_package: {
tool: string
file_path: string
contact_count: integer
sequence_touches: integer
estimated_send_days: integer
next_action: string
}## Campaign Ready
Tool: [configured tool]
Signal type: Hiring signal
Contacts: X people across Y companies
Sequence: 3 touches over 12 days
Ready to launch?| Step | Tool Dependency | Human Checkpoint | Typical Time |
|---|---|---|---|
| 0. Config | None | First run only | 5 min (once) |
| 1. Detect | Configurable (LinkedIn Jobs, Indeed, web search) | Review companies with postings | 2-5 min |
| 2. Qualify | None (LLM reasoning) | Approve tier rankings | 2-3 min |
| 3. Find People | Configurable (Apollo, LinkedIn, etc.) | Approve contact list | 2-3 min |
| 4. Draft Emails | None (LLM reasoning) | Review samples, iterate | 5-10 min |
| 5. Handoff | Configurable (Smartlead, CSV, etc.) | Final launch approval | 1 min |
Total human review time: ~15-20 minutes
Check and improve your brand's visibility across AI search engines (ChatGPT, Perplexity, Gemini, Grok, Claude, DeepSeek). Set up tracking, run visibility analyses, audit your website for AI readability, and get actionable recommendations. Uses the npx goose-aeo@latest CLI.
Extract competitor and customer intelligence from any company's landing page HTML. Discovers tech stack, analytics tools, ad pixels, customer logos, SEO metadata, CTAs, hidden elements, and more. No API keys required.
Discover all customers of a given company by scanning websites, case studies, review sites, press, social media, job postings, and more. Use when you need competitive intelligence on who a company sells to.