Give it a URL. Get back a deployed, full-stack clone.
A three-phase autonomous pipeline that inspects any SaaS product, builds a working clone with real cloud infrastructure, and QA-tests everything — no human in the loop.
Note for AI agents: This README is structured as step-by-step instructions you can follow to set up and run the pipeline for a user. Each step includes verification commands. If you're an agent reading this, start at Setup.
We pointed Ralph-to-Ralph at resend.com during Ralphthon Seoul 2026 and walked away (see the result: namuh-send):
| Metric | Result |
|---|---|
| Features built | 52 |
| Lines of code | 24,000+ |
| Unit tests passing | 388 |
| Dashboard pages | 10 |
| API endpoints | 16+ |
| Total time | ~4 hours (fully autonomous) |
| Human intervention | Zero |
The clone sends real emails via AWS SES, verifies real domains, auto-configures DNS via Cloudflare, and deployed itself to AWS App Runner. It placed 2nd at the hackathon.
Three autonomous phases managed by a watchdog orchestrator:
| Phase | Agent | What It Does |
|---|---|---|
| 1. Inspect | Claude + Ever CLI | Browses the target product, extracts docs, captures screenshots, generates a PRD with 50+ features |
| 2. Build | Claude | Implements each feature with TDD, provisions real cloud infrastructure, commits after every feature |
| 3. QA | Codex + Ever CLI | Tests every feature against the original, finds and fixes bugs, verifies results |
The watchdog auto-restarts failures, pushes commits after every iteration, and runs up to 5 build-QA-fix cycles until everything passes.
Install and verify each tool before proceeding. Run the Verify command to confirm each is ready.
| # | Tool | Purpose | Install | Verify | Required For |
|---|---|---|---|---|---|
| 1 | Node.js 20+ | Runtime | brew install node or download |
node -v (expect v20+) |
All phases |
| 2 | Claude Code CLI | Onboarding, Inspect, Build | npm install -g @anthropic-ai/claude-code |
claude -v |
Onboarding, Phase 1, Phase 2 |
| 3 | Codex CLI | Independent QA evaluator | npm install -g @openai/codex |
codex --version |
Phase 3 only |
| 4 | Ever CLI | Browser automation for inspection + QA | Install from foreverbrowsing.com | ever --version |
Phase 1, Phase 3 |
| 5 | Cloud CLI | Infrastructure provisioning | See cloud setup below | See cloud setup below | Onboarding, Phase 2 |
Which phases need what: Onboarding needs Claude Code + your cloud CLI. Inspect needs Claude Code + Ever CLI. Build needs Claude Code only. QA needs Codex + Ever CLI. You can run onboarding and build without Ever CLI, but Inspect and QA won't work without it.
Install and authenticate the CLI for your chosen cloud provider:
| Provider | Install | Authenticate | Verify |
|---|---|---|---|
| Vercel (default) | npm install -g vercel |
vercel login |
vercel whoami returns a username |
| AWS | brew install awscli |
aws configure |
aws sts get-caller-identity returns account JSON |
| GCP (experimental) | Install gcloud | gcloud auth login |
gcloud auth print-identity-token returns a token |
| Azure (experimental) | brew install azure-cli |
az login |
az account show returns subscription JSON |
Follow these steps in order. Each step has a verification command — run it before moving to the next step.
Step 1 — Fork this repo on GitHub (top-right "Fork" button). This gives you your own copy to push SaaS features into, and lets you pull pipeline improvements from upstream later.
Step 2 — Clone your fork:
git clone https://github.com/YOUR_USERNAME/ralph-to-ralph.git
cd ralph-to-ralph
# Optional: track upstream for future pipeline improvements
git remote add upstream https://github.com/jaeyunha/ralph-to-ralph.gitThen continue:
Verify:
ls ralph-config.json 2>/dev/null || echo "No config yet (expected — created by onboarding)"
ls .ralph-setup-done 2>/dev/null || echo "Stack not set up yet (expected — done by onboarding)"cp .env.example .envThen set these values in .env:
| Variable | Required | Where to get it |
|---|---|---|
ANTHROPIC_API_KEY |
Yes (if clone has AI features) | console.anthropic.com |
DASHBOARD_KEY |
Yes | Generate with openssl rand -hex 32 |
DATABASE_URL |
Set by onboarding | Auto-configured during onboarding |
OPENAI_API_KEY |
Yes (for QA phase) | platform.openai.com |
CLOUDFLARE_API_TOKEN |
Optional (DNS automation) | Cloudflare dashboard |
CLOUDFLARE_ZONE_ID |
Optional (DNS automation) | Cloudflare dashboard → your domain → Overview |
Verify:
# Check that .env exists and has content
test -f .env && echo ".env exists" || echo "ERROR: .env missing"
grep -c '=' .env # Should show number of configured variablesOnboarding researches the target product, configures the stack, installs dependencies, and starts the build loop. Choose one of two paths:
./ralph/onboard.shThe script asks for:
- Target product URL
- Clone name
- Cloud provider (Vercel / AWS / GCP / Azure / Custom)
- Deploy after build? (Y/n)
- Browser agent (Ever CLI / Playwright / Stagehand / Custom)
Then it hands off to Claude for research and config generation, and auto-starts the build loop on success.
In any Claude Code session inside the repo:
/ralph-to-ralph-onboard
Claude researches the product live, explains what needs to be set up in plain English, walks you through each decision, and verifies your setup. Both paths produce the same ralph-config.json and project setup.
Verify onboarding completed:
# Config exists and has required fields
python3 -c "
import json, sys
c = json.load(open('ralph-config.json'))
required = ['targetUrl', 'targetName', 'language', 'stackProfile']
missing = [k for k in required if k not in c]
if missing:
print(f'FAIL: missing fields: {missing}', file=sys.stderr)
sys.exit(1)
print(f'OK: target={c[\"targetUrl\"]}, lang={c[\"language\"]}, stack={c[\"stackProfile\"]}')
"
# Stack is set up and project compiles
test -f .ralph-setup-done && echo "Stack: $(cat .ralph-setup-done)"
make check && make testIf Ralph-to-Ralph saved you time, a star helps others find it:
gh repo star namuh-eng/ralph-to-ralphOr open in your browser: https://github.com/namuh-eng/ralph-to-ralph
./ralph/onboard.sh # Onboard target → generates ralph-config.json
↓
./scripts/start.sh # Starts the watchdog
↓
./ralph/ralph-watchdog.sh # Orchestrates all phases (auto-restart, git push)
↓
┌─────────────────────────────────────────────────┐
│ Phase 1: INSPECT (Claude + Ever CLI) │
│ → Browse target, capture screenshots │
│ → Extract docs and API structure │
│ → Generate prd.json (50+ features) │
└────────────────────┬────────────────────────────┘
↓
┌─────────────────────────────────────────────────┐
│ Phase 2: BUILD (Claude, one feature at a time) │
│ → TDD: write tests first, then implement │
│ → make check && make test after each feature │
│ → git commit + push after each feature │
└────────────────────┬────────────────────────────┘
↓
┌─────────────────────────────────────────────────┐
│ Phase 3: QA (Codex + Ever CLI) │
│ → Playwright regression suite │
│ → Ever CLI verification against original │
│ → Fix bugs and re-test (up to 5 cycles) │
└────────────────────┬────────────────────────────┘
↓
All features pass? → Deploy
No? → Back to Phase 2
ralph-to-ralph/
├── ralph/
│ ├── onboard.sh # Entry point — onboards then starts the loop
│ ├── onboard-prompt.md # Onboarding agent instructions
│ ├── ralph-watchdog.sh # Orchestrator (inspect → build → QA loop)
│ ├── inspect-ralph.sh # Phase 1 runner
│ ├── build-ralph.sh # Phase 2 runner
│ ├── qa-ralph.sh # Phase 3 runner
│ ├── inspect-prompt.md # Inspect agent instructions
│ ├── inspect-spec.md # Inspection strategy
│ ├── build-prompt.md # Build agent instructions
│ ├── qa-prompt.md # QA agent instructions
│ ├── pre-setup.md # Pre-configured setup (read by all agents)
│ ├── ever-cli-reference.md # Ever CLI command reference
│ └── docs/ # Documentation and diagrams
├── .claude/skills/
│ └── ralph-to-ralph-onboard/ # Interactive onboarding skill (Claude Code)
│ ├── scripts/setup-stack.sh # Generic stack scaffolding script
│ └── templates/ # Stack templates (typescript-nextjs, etc.)
├── scripts/
│ ├── start.sh # Starts the build loop
│ ├── preflight.sh # Provisions cloud infrastructure
│ └── generate-demo-keys.sh # Generate API keys for demos
├── src/ # Source code (scaffolded by onboarding)
├── tests/ # Unit tests
├── tests/e2e/ # E2E tests
├── packages/sdk/ # SDK package (if target product has one)
├── ralph-config.json # Generated by onboarding (single source of truth)
├── prd.json # Product requirements (generated by Inspect phase)
├── BUILD_GUIDE.md # Stack-specific build instructions (from template)
├── CLAUDE.md # Instructions for Claude agents (Build)
├── AGENTS.md # Instructions for Codex agent (QA)
├── Makefile # Contract targets — real recipes appended by onboarding
└── .ralph-setup-done # Marker file — contains template name
| Command | What It Does |
|---|---|
make check |
Typecheck + lint/format (stack-specific) |
make test |
Run unit tests |
make test-e2e |
Run E2E tests (needs dev server) |
make all |
check + test |
make fix |
Auto-fix lint/format issues |
make dev |
Dev server on port 3015 |
make build |
Production build |
make db-push |
Push schema to database |
| Agent | What It Reads | What It Produces | Phase |
|---|---|---|---|
| Onboarding (Claude) | ralph/onboard-prompt.md, ralph/pre-setup.md, CLAUDE.md |
ralph-config.json, installed deps, rewritten config files |
Pre-loop |
| Inspect (Claude + Ever CLI) | ralph/inspect-prompt.md, ralph/inspect-spec.md, ralph/ever-cli-reference.md |
prd.json, screenshots in ralph/screenshots/inspect/ |
Phase 1 |
| Build (Claude) | ralph/build-prompt.md, prd.json, CLAUDE.md |
Source code in src/, tests in tests/, SDK in packages/sdk/ |
Phase 2 |
| QA (Codex + Ever CLI) | AGENTS.md, ralph/qa-prompt.md, ralph/ever-cli-reference.md |
Bug fixes, QA screenshots in ralph/screenshots/qa/ |
Phase 3 |
The pipeline produces a fully functional, deployed product — not a mockup.
| Capability | Implementation | When |
|---|---|---|
| Full-stack app | Language + framework from ralph-config.json |
Always |
| REST API | Bearer token auth | Always |
| Database | Postgres (ORM depends on language) | Always |
| Unit + E2E tests | Stack-specific test runner + E2E framework | Always |
| Deployment | Docker + cloud provider | Always (unless skipDeploy: true) |
| Email delivery | AWS SES / SendGrid | If the target sends emails |
| DNS management | Cloudflare API | If the target manages domains |
| File storage | AWS S3 / Cloud Storage | If the target handles uploads |
| SDK package | Language-native SDK | If the target has an SDK |
Re-run onboarding:
./ralph/onboard.sh --reset # Clear previous config
./ralph/onboard.sh # Start freshThe pipeline is controlled by prompt files:
| File | Controls |
|---|---|
ralph/inspect-prompt.md |
How the Inspect agent analyzes the target |
ralph/build-prompt.md |
How the Build agent implements features |
ralph/qa-prompt.md |
How the QA agent tests features |
ralph/pre-setup.md |
Pre-configured setup context (read by all agents) |
If you already have a prd.json, run phases individually:
./ralph/build-ralph.sh # Phase 2 only
./ralph/qa-ralph.sh # Phase 3 onlyHow much does a run cost in API credits?
A full run (inspect + build + QA) against a complex product like Resend costs roughly $30–60 in combined Claude and Codex API usage, depending on feature count and how many QA fix cycles are needed.
Does it work on non-SaaS products?
It's optimized for SaaS products with dashboards, APIs, and documentation. Static sites or native apps won't produce great results. The Inspect phase needs browsable UI and ideally public docs to generate a meaningful PRD.
What if a phase fails?
The watchdog orchestrator automatically restarts failed phases (up to 5 times for Inspect, 10 for Build). It commits progress after every iteration, so you never lose work. If it exhausts retries, it stops and you can inspect the logs.
Can I use this without AWS?
Yes. During onboarding, choose Vercel (default), GCP, or Azure as your cloud provider. The onboarding script configures the project for your chosen provider. Vercel + Neon is the easiest path (free tier, zero ops). GCP and Azure support is experimental.
Can I resume interrupted onboarding?
Yes. If you interrupt onboard.sh (Ctrl+C), your answers are saved to .onboard-answers.tmp. Re-run ./ralph/onboard.sh and it will offer to resume. Use ./ralph/onboard.sh --reset to start completely fresh.
We welcome contributions — bug fixes, new features, documentation, or new target product test runs.
- Fork the repository
- Create a feature branch (
git checkout -b my-feature) - Make your changes
- Run
make check && make testto verify - Commit with a clear message
- Open a pull request
If you're unsure about a change, open an issue first to discuss it.
Ralph-to-Ralph was built by:
- Jaeyun Ha — github.com/jaeyunha
- Ashley Ha — github.com/ashley-ha
Built at Ralphthon Seoul 2026.
If Ralph-to-Ralph helped you, a star helps others find it.
gh repo star namuh-eng/ralph-to-ralphApache License 2.0 — use it, modify it, ship it. Includes an explicit patent grant.
