返回技能列表

hubspot-audit

TomGranot
更新于 2 days ago
2 次查看
33
11
33
在 GitHub 上查看
设计data

关于

This skill performs a comprehensive HubSpot CRM audit across contacts, companies, deals, and data quality. It collects metrics, grades performance, and generates a prioritized report with actionable recommendations. Use it for CRM cleanup, client onboarding, or quarterly health checks.

快速安装

Claude Code

推荐
主要方式
npx skills add TomGranot/hubspot-admin-skills -a claude-code
插件命令备选方式
/plugin add https://github.com/TomGranot/hubspot-admin-skills
Git 克隆备选方式
git clone https://github.com/TomGranot/hubspot-admin-skills.git ~/.claude/skills/hubspot-audit

在 Claude Code 中复制并粘贴此命令以安装该技能

技能文档

HubSpot CRM Database Audit

Run a full diagnostic audit of a HubSpot CRM portal. This skill collects metrics across eight dimensions, grades each one, and produces a prioritized report with actionable recommendations.

Setup

  1. Get the API token. Check .env for HUBSPOT_API_TOKEN. If it is not set, ask the user to provide their HubSpot private app API token and store it in .env:

    HUBSPOT_API_TOKEN=pat-na1-xxxxxxxx
    
  2. Install dependencies. Use uv (not pip):

    uv pip install hubspot-api-client python-dotenv
    
  3. Create the output directory if it does not exist:

    mkdir -p reports
    

Audit Dimensions

Run queries for each of the following eight dimensions. Collect exact counts for every metric listed.

1. Database Size

  • Total contacts
  • Total companies
  • Total deals
  • Marketing contacts vs non-marketing contacts (if Marketing Hub is active)

2. Email Deliverability

  • Hard bounced contacts (hs_email_hard_bounce_reason_enum is not empty)
  • Soft bounced contacts (hs_email_bounce > 0 AND no hard bounce)
  • Global unsubscribes (hs_is_unworked or hs_email_optout = true)
  • Never-emailed contacts (no hs_email_last_send_date)
  • Invalid email format (regex check on email property)
  • Contacts with 3+ bounces

3. Data Completeness

  • Missing email
  • Missing company (contact-level)
  • Missing industry (contact-level)
  • Missing country and/or state
  • Missing lifecyclestage
  • Missing hubspot_owner_id
  • Missing jobtitle
  • Companies missing domain
  • Companies missing industry
  • Companies missing city / state / country

4. Engagement Health

  • Last activity distribution: active in last 30 days, 31-90 days, 91-180 days, 181-365 days, 365+ days, never engaged
  • Email open rate (last 90 days)
  • Email click rate (last 90 days)
  • Contacts with zero page views
  • Contacts with zero form submissions

5. Duplicate Analysis

  • Duplicate email addresses (exact match)
  • Companies sharing the same domain
  • Companies with very similar names (fuzzy — note: API cannot do fuzzy matching natively; count exact duplicates on name and flag for manual review)

6. Owner Health

  • Deactivated owners who still have assigned contacts
  • Deactivated owners who still have assigned companies
  • Deactivated owners who still have assigned deals
  • Contacts with no owner
  • Companies with no owner

7. List & Workflow Health

  • Total active lists vs static lists
  • Lists with zero members
  • Workflows currently active
  • Workflows that have not enrolled anyone in 90+ days
  • Forms with zero submissions
  • Forms with submissions in last 30 days

8. Deal Pipeline Health

  • Deals without amount
  • Deals without closedate
  • Deals in each pipeline stage
  • Stale deals (no activity in 60+ days, still open)
  • Average deal age by stage

API Technical Notes

These details are critical for getting accurate results:

  • Null checks: Use the NOT_HAS_PROPERTY filter operator to find contacts where a property has never been set. HubSpot stores "never happened" as null (property absent), not as 0 or empty string.

    {
        "filterGroups": [{
            "filters": [{
                "propertyName": "hs_email_last_send_date",
                "operator": "NOT_HAS_PROPERTY"
            }]
        }]
    }
    
  • Search API pagination limit: The Search API returns a maximum of 10,000 results per query. If you expect more than 10K, segment queries by another property (e.g., createdate ranges, lifecycle stage, or first letter of email) and sum the results.

  • Deactivated owners: The Owners API does not return deactivated owners by default. Pass archived=True:

    api_client.crm.owners.owners_api.get_page(archived=True)
    
  • Rate limiting: Private apps are limited to 100 requests per 10 seconds. Add a small delay between batch calls or use exponential backoff on 429 responses.

  • Engagement timestamps: Use hs_last_sales_activity_timestamp and notes_last_contacted for activity dating. hs_email_last_open_date and hs_email_last_click_date are useful for email engagement specifically.

  • Marketing contact status: The property hs_marketable_status indicates whether a contact is set as a marketing contact. This property is read-only via API.

Script Structure

Write a single Python script (scripts/audit_portal.py) that:

  1. Loads the API token from .env
  2. Initializes the HubSpot client:
    from hubspot import HubSpot
    api_client = HubSpot(access_token=os.getenv("HUBSPOT_API_TOKEN"))
    
  3. Runs each dimension's queries sequentially (respect rate limits)
  4. Collects all results into a structured dict
  5. Computes letter grades per dimension (see grading rubric below)
  6. Renders the markdown report
  7. Saves to reports/hubspot-audit-{YYYY-MM-DD}.md

Grading Rubric

Assign a letter grade to each dimension based on severity:

GradeMeaningCriteria
AHealthy< 5% of records affected
BMinor issues5-15% of records affected
CNeeds attention15-30% of records affected
DSignificant problems30-50% of records affected
FCritical> 50% of records affected

For dimensions without a simple percentage (e.g., Owner Health), use judgment based on the number of affected records and business impact.

Output Format

Save the report to reports/hubspot-audit-{YYYY-MM-DD}.md with this structure:

# HubSpot CRM Audit Report

**Date:** YYYY-MM-DD
**Portal ID:** [portal-id]

## Executive Summary

| Dimension | Grade | Key Finding |
|-----------|-------|-------------|
| Database Size | B | ~XX,000 contacts, XX,000 companies |
| Email Deliverability | D | XX% hard bounced, XX% globally unsubscribed |
| Data Completeness | F | XX% missing email, XX% missing industry |
| Engagement Health | D | XX% never engaged, XX% inactive 12+ months |
| Duplicate Analysis | C | ~X,XXX duplicate company domains |
| Owner Health | F | X deactivated owners with XX,XXX assigned contacts |
| List & Workflow Health | B | XX unused lists, X stale workflows |
| Deal Pipeline Health | C | XX% deals missing amount, XX stale deals |

**Overall Grade: X**

## Priority Recommendations

1. **[CRITICAL] Delete contacts with no email** — XX,XXX contacts with no email address
   are unbillable dead weight. Run `/delete-no-email-contacts`.
   *Effort: 1 hour | Fully scriptable*

2. **[CRITICAL] Suppress hard bounced contacts** — XX,XXX hard bounces are destroying
   sender reputation. Run `/suppress-hard-bounced`.
   *Effort: 1 hour | Hybrid (API + workflow)*

3. **[HIGH] Reassign deactivated owner contacts** — XX,XXX contacts assigned to
   X deactivated users. Run `/reassign-deactivated-owners`.
   *Effort: 2 hours | Fully scriptable*

4. ...continue ranked by impact...

---

## Detailed Findings

### 1. Database Size

| Metric | Count | % of Total |
|--------|-------|------------|
| Total Contacts | XX,XXX | — |
| Total Companies | XX,XXX | — |
| Total Deals | X,XXX | — |
| Marketing Contacts | XX,XXX | XX% |

### 2. Email Deliverability

| Metric | Count | % of Contacts |
|--------|-------|---------------|
| Hard Bounced | X,XXX | XX% |
| Soft Bounced | X,XXX | XX% |
| Global Unsubscribes | X,XXX | XX% |
| Never Emailed | XX,XXX | XX% |
| Invalid Email Format | XXX | X% |

...continue for all 8 dimensions...

---

## Next Steps

Run `/hubspot-implementation-plan` to generate a phased cleanup plan based on these findings.

Skill Prescription

After generating the audit report, prescribe a specific ordered list of skills the user should run. Do not just present findings — tell the user exactly what to do next.

Step 1: Map Findings to Skills

For each audit finding that scored C or worse, map it to the appropriate skill. Use this category-ordered lookup:

Database Hygiene (run first — billing and deliverability impact):

FindingSkillPriority
Contacts missing email/delete-no-email-contactsP0
Hard bounced contacts/suppress-hard-bouncedP0
Global unsubscribes/suppress-global-unsubscribesP0
Ghost/never-engaged contacts/suppress-ghost-contactsP1
Duplicate companies/merge-duplicate-companiesP1
Deactivated owners with contacts/reassign-deactivated-ownersP1

Data Enrichment (run second — data quality):

FindingSkillPriority
Missing company name/enrich-company-nameP1
Missing industry/enrich-industryP1
Inconsistent geo data/standardize-geo-valuesP2
Missing geo data/backfill-geo-dataP2
Missing/wrong lifecycle stage/fix-lifecycle-stagesP1
Unowned marketing contacts/assign-unowned-contactsP1

Segmentation & Scoring (run third — targeting):

FindingSkillPriority
No ICP classification/create-icp-tiersP2
No lead scoring/build-lead-scoringP2
No segment lists/build-smart-listsP2

Automation Workflows (run fourth — prevention):

FindingSkillPriority
No new-contact hygiene/new-contact-hygiene-workflowP2
High disengagement rate/engagement-suppression-workflowP2
No lifecycle automation/lifecycle-progression-workflowP3
No bounce monitoring/bounce-monitoring-workflowP2

Ongoing Maintenance (run last — sustainability):

FindingSkillPriority
Unused lists/cleanup-listsP3
Unused forms/cleanup-formsP3
Stale workflows/cleanup-workflowsP3
Dashboard clutter/cleanup-dashboardsP3
Deal pipeline issues/cleanup-dealsP3
Unused properties/cleanup-propertiesP3

Step 2: Present the Ordered Prescription

After the audit report, present a numbered action list — not just findings. Format like this:

## Your Cleanup Prescription

Based on the audit, here are the skills you should run, in order:

### Immediate (this week)
1. `/delete-no-email-contacts` — X,XXX contacts with no email are inflating your bill
2. `/suppress-hard-bounced` — X,XXX hard bounces are hurting deliverability
3. `/suppress-global-unsubscribes` — X,XXX unsubscribes still counting as marketing contacts

### Next (weeks 2-3)
4. `/reassign-deactivated-owners` — X deactivated users still own X,XXX contacts
5. `/enrich-company-name` — XX% of contacts missing company name
6. `/fix-lifecycle-stages` — X,XXX contacts in invalid lifecycle stages
...

### Later (weeks 4-6)
7. `/create-icp-tiers` — No ICP classification exists yet
8. `/build-lead-scoring` — No scoring model in place
...

Step 3: Handle Missing Skills

If the audit reveals a problem that no existing skill covers, do the following:

  1. Tell the user clearly: "This audit found an issue that isn't covered by any existing skill: [description]."

  2. Offer to create it on the spot: "I can create a new skill for this right now. It would be called /[suggested-name] and would handle [brief description]."

  3. Ask about contributing upstream: "Would you like to contribute this new skill back to the community? If yes, I'll:

    • Create the skill in skills/[name]/SKILL.md
    • Fork the repo (if not already forked)
    • Push the new skill to your fork
    • Open a pull request to tomgranot/hubspot-admin-skills

    This helps everyone who uses these skills in the future."

  4. If the user agrees, create the skill following the standard SKILL.md format, commit it, and open the PR.

  5. If the user declines the upstream contribution, still create the skill locally so they can use it.

Step 4: Suggest Next Step

End with:

Ready to start? Run `/hubspot-implementation-plan` to generate a full phased plan,
or jump straight to the first skill: `/delete-no-email-contacts`.

After Running

  • Print the file path of the saved report
  • Present the ordered skill prescription (Step 2 above)
  • Highlight the top 3 most critical findings
  • Flag any findings that have no matching skill (Step 3 above)
  • Suggest running /hubspot-implementation-plan for the full phased plan

GitHub 仓库

TomGranot/hubspot-admin-skills
路径: skills/hubspot-audit
0

相关推荐技能

executing-plans

设计

该Skill用于当开发者提供完整实施计划时,以受控批次方式执行代码实现。它会先审阅计划并提出疑问,然后分批次执行任务(默认每批3个任务),并在批次间暂停等待审查。关键特性包括分批次执行、内置检查点和架构师审查机制,确保复杂系统实现的可控性。

查看技能

requesting-code-review

设计

该Skill可在完成任务、实现主要功能或合并代码前自动调度代码审查子代理,确保实现符合需求和计划。它支持通过指定git SHA范围进行精准的代码变更审查,帮助开发者在关键节点及时发现潜在问题。核心原则是"早审查、勤审查",适用于开发流程的各个关键阶段。

查看技能

connect-mcp-server

设计

这个Skill指导开发者如何将MCP服务器连接到Claude Code,支持HTTP、stdio和SSE三种传输协议。它涵盖了从安装配置到认证安全的完整流程,适用于集成GitHub、Notion、数据库等外部服务。当开发者需要添加集成、配置外部工具或提及MCP相关功能时,这个Skill能提供实用的操作指南。

查看技能

web-cli-teleport

设计

该Skill帮助开发者根据任务特性选择Claude Code的Web或CLI界面,并指导如何在两种环境间无缝迁移会话。它能分析任务复杂度、迭代需求等要素,推荐最优工作界面和工作流。关键特性包括会话状态管理、环境切换指导和上下文优化建议。

查看技能