Loading...
Loading...
End-to-end protocol replay toolkit for ChatGPT Team subscription with hCaptcha solver and anti-fraud research tools
npx skill4agent add aradotso/trending-skills gpt-pp-team-protocol-replaySkill by ara.so — Daily 2026 Skills collection.
Stripe Checkout → PayPal billing agreement → ChatGPT manual-approval → Codex OAuth + PKCE⚠️ For authorized security research, CTF, and bug bounty in-scope assets only. Readbefore use.NOTICE
git clone https://github.com/DanOps-1/gpt-pp-team
cd gpt-pp-team
pip install requests curl_cffi playwright camoufox browserforge mitmproxy pybase64
playwright install firefox
camoufox fetchpython -m venv ~/.venvs/ctfml
~/.venvs/ctfml/bin/pip install torch transformers opencv-python pillow numpypipeline.py
└─> CTF-reg/browser_register.py (Camoufox + Turnstile)
└─> CTF-pay/card.py (Stripe Checkout replay, 8000 lines)
└─> Stripe confirm + ChatGPT /approve
└─> Camoufox PayPal billing agreement
└─> Stripe poll state=succeeded
└─> Camoufox second login Codex OAuth + PKCE
└─> output/results.jsonl (refresh_token)| File | Purpose |
|---|---|
| Orchestrator, daemon loop, 12-self-healing branches |
| Stripe protocol replay (single file, 8000 lines) |
| hCaptcha VLM solver (~4000 lines, standalone) |
| Account registration with Camoufox |
| 14-step setup wizard + SSE log controller |
cp CTF-pay/config.paypal.example.json CTF-pay/config.paypal.json
cp CTF-reg/config.paypal-proxy.example.json CTF-reg/config.paypal-proxy.jsonCTF-pay/config.paypal.json{
"proxy": {
"host": "your-proxy-host",
"port": 1080,
"username": "$PROXY_USER",
"password": "$PROXY_PASS",
"protocol": "socks5"
},
"paypal": {
"email": "$PAYPAL_EMAIL",
"password": "$PAYPAL_PASSWORD",
"country": "IE"
},
"cloudflare": {
"api_token": "$CF_API_TOKEN",
"zone_id": "$CF_ZONE_ID",
"domain": "yourdomain.com"
},
"vlm": {
"api_key": "$VLM_API_KEY",
"base_url": "$VLM_BASE_URL",
"model": "gpt-4o"
},
"captcha_platform": {
"api_key": "$CAPTCHA_API_KEY",
"provider": "2captcha"
},
"webshare": {
"api_key": "$WEBSHARE_API_KEY"
}
}export PROXY_USER="your_proxy_username"
export PROXY_PASS="your_proxy_password"
export PAYPAL_EMAIL="your@paypal.com"
export PAYPAL_PASSWORD="your_paypal_password"
export CF_API_TOKEN="your_cloudflare_api_token"
export CF_ZONE_ID="your_cloudflare_zone_id"
export VLM_API_KEY="your_openai_compatible_key"
export VLM_BASE_URL="https://api.openai.com/v1"
export WEBSHARE_API_KEY="your_webshare_key"
export CAPTCHA_API_KEY="your_2captcha_key"# Install backend deps
pip install -r webui/requirements.txt
# Build frontend (one-time)
cd webui/frontend && pnpm i && pnpm build && cd ../..
# Start wizard
python -m webui.server
# Open http://127.0.0.1:8765 — redirects to /setup on first visitCTF-pay/config.auto.jsonCTF-reg/config.paypal-proxy.jsonwebui/README.mdxvfb-run -a python pipeline.py \
--config CTF-pay/config.paypal.json \
--paypalxvfb-run -a python pipeline.py \
--config CTF-pay/config.paypal.json \
--paypal \
--daemonxvfb-run -a python pipeline.py \
--config CTF-pay/config.paypal.json \
--paypal \
--batch 10output/results.jsonl{"email": "user@subdomain.yourdomain.com", "refresh_token": "...", "timestamp": "2026-04-29T00:00:00Z", "status": "success"}CTF-pay/hcaptcha_auto_solver.pyimport asyncio
from CTF-pay.hcaptcha_auto_solver import HCaptchaSolver
async def solve_captcha(page):
solver = HCaptchaSolver(
page=page,
vlm_api_key=os.environ["VLM_API_KEY"],
vlm_base_url=os.environ["VLM_BASE_URL"],
vlm_model="gpt-4o",
clip_venv_path=os.path.expanduser("~/.venvs/ctfml"),
debug=True
)
result = await solver.solve()
return result # True if solved, False if failed
asyncio.run(solve_captcha(page))import asyncio
from camoufox.async_api import AsyncCamoufox
from CTF_pay.hcaptcha_auto_solver import HCaptchaSolver
async def main():
async with AsyncCamoufox(headless=True, humanize=True) as browser:
page = await browser.new_page()
await page.goto("https://example.com/page-with-hcaptcha")
solver = HCaptchaSolver(
page=page,
vlm_api_key=os.environ["VLM_API_KEY"],
vlm_base_url=os.environ.get("VLM_BASE_URL", "https://api.openai.com/v1"),
vlm_model="gpt-4o",
)
success = await solver.solve()
if success:
print("hCaptcha solved successfully")
else:
print("Solver failed, check logs")
asyncio.run(main())solver = HCaptchaSolver(
page=page,
vlm_api_key=None, # Disables VLM primary path
clip_venv_path=os.path.expanduser("~/.venvs/ctfml"),
fallback_only=True
)pipeline.py::daemon()| Branch | Trigger | Recovery |
|---|---|---|
| IP rotation | Ban detected / probe fail | Webshare API fetch new IP |
| CF DNS quota | Zone record limit hit | Clean stale catch-all records |
| tmpfs orphan | Crashed browser profile left | Reclaim tmpfs mounts |
| gost relay | Relay process died | Restart watchdog |
| DataDome slider | Slider CAPTCHA on registration | Auto-drag synthesis |
| PayPal 2FA | Session expired | Re-authenticate flow |
| Stripe fingerprint | | Re-align JS checksum |
| Batch correlation | Mass ban detected | Pause + stagger restart |
| DNS propagation | New subdomain not resolving | Poll + retry with backoff |
| OAuth PKCE | Token exchange failure | Regenerate challenge |
| Account approval | Manual approval queue | Poll |
| Memory pressure | Browser OOM | Graceful restart with GC |
docs/anti-fraud-research.md# Access research data programmatically
import json
with open("docs/anti-fraud-research.md") as f:
# Raw markdown with embedded JSON samples
content = f.read()
# Survival curve model (from research):
# P(survival at t hours) ≈ 0.85 * exp(-0.31 * t) for batch size > 5
# P(survival at t hours) ≈ 0.60 * exp(-0.08 * t) for batch size == 1mitmproxyPOST https://checkout.stripe.com/pay/{session_id}
→ Stripe payment intent confirm
POST https://api.openai.com/dashboard/billing/stripe/confirm
→ ChatGPT billing linkage
GET https://api.openai.com/dashboard/billing/subscription/approve?token={t}
→ Manual approval poll
POST https://www.paypal.com/agreements/approve
→ PayPal billing agreement
GET https://auth.openai.com/authorize
→ Codex OAuth + PKCE initiation
POST https://auth.openai.com/oauth/token
→ refresh_token exchangecard.py# In CTF-pay/card.py — fields to re-align after Stripe updates:
STRIPE_RUNTIME = {
"runtime_version": "5.104.0", # Check stripe.js version
"js_checksum": "sha256-...", # Recompute from live stripe.js
"rv_timestamp": 1714000000, # Update to current epoch
}
# To re-capture current values:
# 1. Open browser devtools on any Stripe Checkout page
# 2. Network tab → filter "stripe" → find runtime init request
# 3. Extract from request payload or JS sourcePayPal OTP loop# Run without --daemon first, complete OTP manually
xvfb-run -a python pipeline.py --config CTF-pay/config.paypal.json --paypal --interactivehCaptcha VLM timeout# Test VLM connectivity
python -c "
import openai, os
client = openai.OpenAI(api_key=os.environ['VLM_API_KEY'], base_url=os.environ.get('VLM_BASE_URL'))
print(client.models.list())
"Stripe fingerprint mismatch# Check card.py STRIPE_RUNTIME block, compare to live stripe.js
# Use mitmproxy to capture fresh values:
mitmproxy --mode upstream:http://your-proxy:1080 -s CTF-pay/capture_stripe.pyCF DNS quota exceeded# Manual cleanup
python -c "
import requests, os
headers = {'Authorization': f'Bearer {os.environ[\"CF_API_TOKEN\"]}'}
r = requests.get(f'https://api.cloudflare.com/client/v4/zones/{os.environ[\"CF_ZONE_ID\"]}/dns_records?per_page=100', headers=headers)
print(f'Record count: {len(r.json()[\"result\"])}')
"Camoufox not foundcamoufox fetch
python -c "from camoufox.async_api import AsyncCamoufox; print('OK')"output/results.jsonl # Successful refresh_tokens
output/failed/ # Per-attempt failure dumps
output/screenshots/ # Browser screenshots at failure point
output/mitmproxy-*.har # Protocol capture (if enabled)
/tmp/ctf-*/ # tmpfs browser profiles (cleaned by daemon)export CTF_DEBUG=1
export CTF_SCREENSHOT_ON_ERROR=1
xvfb-run -a python pipeline.py --config CTF-pay/config.paypal.json --paypal --verboseround.jsonround.jsonNOTICENOTICE