MCP HubMCP Hub
스킬 목록으로 돌아가기

hubspot-audit

TomGranot
업데이트됨 2 days ago
6 조회
33
11
33
GitHub에서 보기
디자인data

정보

이 스킬은 연락처, 회사, 거래 및 데이터 품질에 걸쳐 포괄적인 HubSpot CRM 감사를 수행합니다. 핵심 지표를 수집하고 성과를 평가하며, 실행 가능한 권장 사항이 포함된 우선순위 보고서를 생성합니다. CRM 정리, 고객 온보딩 또는 분기별 상태 점검에 활용하세요.

빠른 설치

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

디자인

executing-plans 스킬은 검토 체크포인트가 포함된 통제된 배치로 실행할 완전한 구현 계획이 있을 때 사용합니다. 이 스킬은 계획을 불러와 비판적으로 검토한 후, 소규모 배치(기본값 3개 작업)로 작업을 실행하면서 각 배치 사이에 진행 상황을 아키텍트 검토를 위해 보고합니다. 이를 통해 내재된 품질 관리 체크포인트를 갖춘 체계적인 구현이 보장됩니다.

스킬 보기

requesting-code-review

디자인

이 스킬은 코드 변경 사항을 요구 사항에 따라 분석하기 위해 코드 리뷰어 하위 에이전트를 호출합니다. 작업 완료 후, 주요 기능 구현 후, 또는 메인 브랜치에 병합하기 전에 사용해야 합니다. 이 리뷰는 현재 구현체와 원래 계획을 비교하여 문제를 조기에 발견하는 데 도움이 됩니다.

스킬 보기

connect-mcp-server

디자인

이 스킬은 개발자들이 HTTP, stdio 또는 SSE 전송 방식을 통해 MCP 서버를 Claude Code에 연결하는 포괄적인 가이드를 제공합니다. GitHub, Notion 및 사용자 정의 API와 같은 외부 서비스를 통합하기 위한 설치, 구성, 인증 및 보안을 다룹니다. MCP 통합 설정, 외부 도구 구성 또는 Claude의 모델 컨텍스트 프로토콜 작업 시 활용하세요.

스킬 보기

web-cli-teleport

디자인

이 스킬은 작업 분석을 기반으로 개발자가 Claude Code 웹 인터페이스와 CLI 인터페이스 중 선택할 수 있도록 돕고, 두 환경 간 원활한 세션 텔레포트를 가능하게 합니다. 웹, CLI 또는 모바일 환경 전환 시 세션 상태와 컨텍스트를 관리하여 워크플로를 최적화합니다. 다양한 단계에서 서로 다른 도구가 필요한 복잡한 프로젝트에 사용하세요.

스킬 보기