How One Team Replaced a 6-Figure HubSpot Agency with Claude Code

A mid-sized e-commerce company (~15 products across Shopify, Recharge, Digistore24, GoAffPro, and ads) needed to migrate from Zoho CRM, Zoho Desk, and KlickTipp to HubSpot Enterprise. Agency quotes ranged from 20k EUR (templated) to 80k EUR (mid-tier custom objects) — but none offered end-to-end custom middleware for sync/reconciliation. The team decided to build it themselves with Claude Code (desktop app, Opus 4.7, subscription plan).
What Was Built (in 4 months, ~30 sessions of 2-4h each)
- 6 Custom Objects + ~100 properties + associations
- 5 source-system integrations on self-hosted n8n: Shopify, Digistore24, Recharge, GoAffPro, Cart-Notifier — each with inbox pattern, idempotent upserts, reconciliation, backoff/retry, audit trail
- 1 custom Cloud Run service for inbox-polling at 15s cadence
- 10 Lifecycle stages + Funnel/Segment property layer
- Aggregator workflow that backfills 9 contact properties from sync-mirror objects (idempotent, Postgres cursor, cron-driven)
- KlickTipp migration: 202 tags audited, custom object for webinar registrations, consent governance
- Google Ads CAPI (11 conversion actions, enhanced conversions) + Meta CAPI (Pixel + server-side)
- 33 ADRs (architecture decisions, append-only, never deleted)
The author estimates the full deliverable would cost 120-180k EUR from an agency — and most can't deliver the custom middleware piece.
The Mental Shift: Claude Code as System-of-Record
Only ~20% of the repo is code. The other 80% is Markdown: architecture decisions, integration specs, runbooks, ADRs, naming conventions, consent governance. The repo becomes the single source of truth for how the business runs in HubSpot. When code is needed (Python helpers, backfill scripts, Cloud Run service), Claude writes it. For workflow logic, they use n8n — Claude builds/updates workflows via the n8n MCP server.
Repo as Memory Between Sessions
Claude Code sessions are stateless. The team treats this as a design constraint: state lives in files. Key practices:
- ADRs capture every architecture decision with reasoning and trade-offs — new sessions read them and don't re-debate
- Spec files per integration/area with a Status header — single source of truth for implementation state
- Slash commands (
/implement,/verify,/new-task) enforce discipline — Definition-of-Done gate, drift checks, atomic status updates - Cheatsheets for HubSpot operations (which work via API tools vs direct API calls vs UI clicks) and known bugs (HubSpot search index latency, Recharge enumeration-vs-bool, n8n auth races)
📖 Read the full source: r/ClaudeAI
👀 See Also

Lessons from Running an AI Business with OpenClaw: Day 14 Insights
After 14 days using OpenClaw to build a business, an AI agent shares insights on implementing effective heartbeats, sub-agent structuring, and system resource management.

AI Agent Overrules Human CEO in Multi-Agent Store Architecture
An AI-operated store running on a Mac Mini with GitHub Actions had its CEO agent overrule a human decision about the deployment pipeline, which turned out to be correct. The architecture involves multiple coordinating agents with mechanisms for handling disagreements.

Onboarding an AI Agent as a Team Member: A Real Business Case
A business shares their experience onboarding their first AI agent as an actual team member handling design, code, marketing, and operations, noting that the hard parts weren't the technical setup.

Real-World MCP Server Use Cases and Development Patterns
A developer shares their experience building an MCP server that connects to live sports data scanners, pulling odds from sportsbooks to find pricing inefficiencies in real-time. They discuss practical lessons learned about tool design and installation formats.