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

Porting Quake to Three.js with Claude Code: Workflow and Limitations
A developer used Claude Code to port Quake's source code to JavaScript and Three.js, creating a web-based version. The project involved significant prompting work and revealed Claude's difficulty with porting multiplayer server code to Deno+WebTransport.

Using AI to Port a Wi-Fi Driver from Linux to FreeBSD: A Case Study
A developer used Claude Code and Pi agent to attempt porting the Linux brcmfmac driver for Broadcom BCM4350 Wi-Fi chips to FreeBSD, first through direct code translation and then by generating a detailed 11-chapter specification for clean-room implementation.

Claude as sole art teacher: Week 1 results and critique surprises
A developer used Claude as their only teacher for colored pencil portraits. Claude's critique ignored skin tone mixing and instead flagged the initial five-minute sketch as the root problem.

Building a SwiftUI Line-Art System with Claude Code: One Good Thing Case Study
A developer built an iOS app's line-art illustrations entirely in SwiftUI Canvas using Claude Code as a coding partner. Key lesson: treat Claude like a patient pair programmer, not a vending machine.