Skip to content
HN On Hacker News ↗

GitHub - stephenlthorn/auto-identity-remove: Automated data broker opt-out runner — removes your personal info from 30+ people-search sites on a monthly schedule

▲ 325 points 135 comments by stephenlthorn 6d ago HN discussion ↗

Pangram verdict · v3.3

We believe that this document is fully AI-generated

99 %

AI likelihood · overall

AI
0% human-written 100% AI-generated
SEGMENTS · HUMAN 0 of 4
SEGMENTS · AI 4 of 4
WORD COUNT 905
PEAK AI % 100% · §1
Analyzed
May 18
backend: pangram/v3.3
Segments scanned
4 windows
avg 226 words each
Distribution
0 / 100%
human / AI fraction
Verdict
AI
Pangram v3.3

Article text · 905 words · 4 segments analyzed

Human AI-generated
§1 AI · 100%

Automated data broker opt-out runner for macOS. Removes your personal information from 500+ people-search sites and data broker databases on a monthly schedule — with CAPTCHA solving, persistent state tracking (so completed opt-outs aren't resubmitted every run), and an iMessage notification when done. What it does Each month, the script:

Searches each data broker site for your name + state Finds your specific listing (for sites that need a profile URL) Fills and submits the opt-out form automatically Solves CAPTCHAs via CapSolver (AI-powered, ~$0.001/solve) Skips brokers you were already removed from recently (90-day re-check window) Sends you an iMessage with the results summary Opens any sites that require manual action in your browser

Requirements

macOS (uses launchd for scheduling and Messages for iMessage) Node.js 18+ Playwright browsers installed

npx playwright install chromium

Quick Start # 1. Clone the repo git clone https://github.com/stephenlthorn/auto-identity-remove.git cd auto-identity-remove

# 2. Install dependencies npm install

# 3. Run interactive setup (creates config.json and schedules the monthly job) node setup.js

# 4. Run manually anytime ./run.sh

Setup walkthrough node setup.js guides you through:

Step What it does

Personal info Name, city, state, ZIP, email, phone

Aliases Past names or variations (e.g. "Steve Doe")

CapSolver key For CAPTCHA-protected opt-out forms

One-time accounts Creates accounts on sites that require login (stored in config.json, gitignored)

iMessage Phone number to text the results summary to

launchd schedule Registers a monthly job to run on the 1st at 9am

Your personal info never leaves your machine. config.json and state.json are both gitignored.

CapSolver (optional but recommended) Some opt-out forms have reCAPTCHA. Without CapSolver, those sites go to your manual list instead of being handled automatically.

§2 AI · 100%

Sign up at capsolver.com — free, pay-as-you-go Add $1–2 of credits (enough for months of use at ~$0.001/solve) Paste your API key when setup.js asks, or add it to config.json:

"capsolver": { "apiKey": "CAP-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" }

Files auto-identity-remove/ ├── setup.js ← Run once: interactive setup + scheduling ├── watcher.js ← Main runner ├── brokers.js ← Broker list with opt-out strategies ├── run.sh ← Manual trigger ├── config.example.json ← Template (copy → config.json) ├── package.json ├── .gitignore │ ├── config.json ← YOUR personal info (gitignored, created by setup.js) ├── state.json ← Opt-out history / skip logic (gitignored) └── logs/ ← Per-run JSON logs (gitignored)

State tracking state.json tracks when each broker was last successfully opted out. The default re-check window is 90 days — brokers typically re-add your data within that window, so the script re-submits when it's time. { "optOuts": { "Spokeo": { "lastSuccess": "2026-05-01T09:00:00.000Z", "totalRuns": 3, "detail": "" } } } On each run you'll see:

✅ Removed — opt-out submitted this run ⏭ Skipped (fresh) — removed recently, re-check not due yet 🔍 Not listed — your name wasn't found on that site 📋 Manual needed — opened in your browser for you to handle ❌ Error — network/timeout issue, will retry next run

Brokers covered Auto-removed (30+)

Site Method

Spokeo Search → find listing → opt-out form

WhitePages Search → find listing →

§3 AI · 100%

suppression form

FastPeopleSearch Search → opt-out form

TruePeopleSearch Direct opt-out form

BeenVerified Opt-out search form

Radaris Search → privacy form

Intelius Direct opt-out form

PeopleFinders Direct opt-out form

PeopleSmart Direct opt-out form

MyLife Search → opt-out

Nuwber Search → removal form

FamilyTreeNow Direct opt-out form

CheckPeople Direct opt-out form

ThatsThem Direct opt-out form

USPhonebook Direct opt-out form

PublicDataUSA Direct opt-out form

SmartBackgroundChecks Direct opt-out form

SearchPeopleFree Direct opt-out form

PeopleSearchNow Direct opt-out form

InfoTracer Direct opt-out form

SocialCatfish Direct opt-out form

NationalPublicData Direct opt-out form

ClustrMaps Direct opt-out form

PrivateRecords Direct opt-out form

Acxiom Direct form (feeds dozens of downstream brokers)

LexisNexis Direct form (legal/financial data)

ZoomInfo Direct form (B2B professional data)

Clearbit Direct form (B2B enrichment data)

Pipl Email opt-out via Mail.app

Generic — 500+ additional brokers (auto-detected) generic-runner.js handles the remaining ~470 brokers from two public datasets:

Dataset Source Count

The Markup's data broker list Journalism research, 494 opt-out URLs ~494

BADBOOL Community-maintained people-search list ~27 extra

For each site it tries four strategies in order:

Click a "Do Not Sell My Personal Information" button Opt out via OneTrust / TrustArc / Osano privacy manager Fill any generic opt-out form (email, name, state) and submit Find and record a DSAR / data request link for manual follow-up

Sites requiring manual action are opened in your browser automatically.

§4 AI · 100%

Manual (opened in browser for you)

Site Why manual

Google — Results About You Requires Google account interaction

Google — Outdated Content Case-by-case URL submission

Adding more brokers Edit brokers.js and add an entry: { name: 'NewBrokerSite', method: 'direct-form', // or 'search-form', 'email', 'manual' optOutUrl: 'https://example.com/opt-out', formFields: { 'input[name*="first" i]': F, // F, L, N, E, ST, Z are from config 'input[name*="last" i]': L, 'input[type="email"]': E, }, submitSelector: 'button[type="submit"]', captchaLikely: false, priority: 2, } PRs welcome — especially for brokers with verified working selectors.

Manual run ./run.sh Or to run in the background and log output: ./run.sh >> logs/manual-run.log 2>&1 &

Uninstall / disable schedule launchctl unload ~/Library/LaunchAgents/com.auto-identity-remove.plist rm ~/Library/LaunchAgents/com.auto-identity-remove.plist

Why not just use a paid service? Paid services like Incogni ($96/yr) or Optery ($39/yr) are excellent and cover more brokers with professionally maintained opt-out flows. This tool is for people who want full control, transparency, and no recurring subscription — or who want to handle the gaps those services miss (Acxiom, LexisNexis, ZoomInfo, Clearbit). Using both is the strongest approach: a paid service for the bulk of brokers + this script for the gaps.

License MIT