XRPL NFT Scam Tracker
The XRP-API.com NFT phishing-drain campaign tricks Xaman and other wallet users into signing "Safe XRPL verify message" transactions that drain their funds. This page tracks every confirmed drain on-chain and auto-updates as new scams are detected.
Campaign first observed 2026-01-25 · latest drain 2026-06-17 · data refreshed 0s ago
Ecosystem warning
David "JoelKatz" Schwartz, CTO of Ripple, has publicly warned XRPL users about this campaign. View on X →
Victim testimony
@xZBLUEx, FuzzyBear community member, was drained after accepting a bait NFT offer that swept his FUZZY holdings. View on X →
Fully understand any transaction before you sign it. Transactions on the XRP Ledger are final and cannot be reversed.
How the scam works
How victims are lured in
The hook. The attacker first social-engineers the victim with a fake airdrop, reward, staking, or token-claim opportunity, usually framed with urgency ("limited slots", "ends in 1 hour", "verify in the next 10 minutes"). The lure links to a phishing page that prompts you to connect your wallet. Connecting alone does not drain anything: the wallet just shares its address so the attacker can scan your balances. The drain only happens once you sign a transaction the attacker pushes to your wallet.
The same operator group runs multiple acquisition funnels in parallel:
- X / Twitter spam. Dozens of fake accounts posing as Xaman support, Xaman developers, or admins of trending projects. Profiles are padded with purchased followers and bot engagement (likes, replies, retweets) to look legitimate at a glance. They reply to real users in trending XRPL threads with "verification" instructions linking to the bait.
- Targeted impersonation. The dominant lure is Xaman("your wallet needs verification"), including fake events such as"Xaman Community Day" (no such event exists). Variants impersonate community-favorite projects like PHNIX, FuzzyBear, and other meme or DeFi tokens currently in the spotlight. The same drain mechanic adapts to whichever brand the victim trusts.
- Telegram & Discord DMs. After a user posts a support question or joins a project channel, attackers DM them within minutes claiming to be a "support agent" or "moderator". Attackers will also pose as fellow community members, striking up casual conversation to build rapport before pivoting to social engineering. They funnel the conversation off the official server and into a one-on-one DM where they push the verification link or terminal-paste command.
- "Exclusive group" bait. Inside a project's own Telegram or Discord, the target is invited to a privileged sub-group — a "whale group", an "OG holders" room, or a private alpha channel. Entry is gated behind a "membership verification": only after they agree to join are they asked to verify with their wallet — the same sign-to-drain trap. The exclusivity lowers the victim's guard because the invitation comes from inside a community they already trust.
- Google search hijacking. The campaign runs typo-squatted domains and pays for Google Ads slots that appear above the real result when users search for XRPL wallets, marketplaces, or token names. A single character difference in the URL bar (or just clicking the top "Sponsored" result) lands them on a clone site that runs the same scripts.
Common thread: the attacker's only goal is to get the victim onto a page they control, or to get them to sign a transaction or paste a terminal command without reading it. The on-chain drain or the malware payload then follows automatically.
Attack flow at a glance
End-to-end path from first contact to drained wallet:
Fake airdrop or reward on X, Discord, Telegram, or a Google-Ads phishing site.
Victim connects Xaman / Crossmark / GemWallet. Address shared, no funds moved yet.
Attacker pushes NFTokenCreateOffer prompts non-stop, disguised as 'verification'.
How the scam works (on-chain drain)
The attacker pre-targets the victim. After scanning their wallet, the attacker mints one NFT per asset the victim holds: XRP, LP tokens, IOUs, everything. Each NFT's URI encodes that specific balance, e.g. https://xrpl-api.com/api/nft/metadata?amount=11432359&asset=CSC%3ArCSCManTZ8ME…. The phishing endpoint dynamically returns matching metadata so each NFT renders in the victim's wallet as a stand-in for that exact balance, often dressed up to impersonate Xaman, XRPL.org, or a known marketplace.
The attacker then creates NFTokenCreateOffers with memos like "Verification: Safe XRPL verify message" plus "Info: idx:0;len:11". The wallet UI shows what looks like a routine verification, but each signature actually authorizes a sale of the targeted balance. Signing N "verifications" hands the attacker N specific assets: XRP first, then every held token.
When the victim signs, they are handing their XRP and tokens directly to the attacker. On-chain, the scammer has simply sold them an NFT. The attacker accepts the offer, the transfer settles as a normal on-chain payment indistinguishable from a legitimate trade, and the victim is left holding a worthless bait NFT. There is no path to reverse it.
How the attack got here. The earliest version of this campaign was crude: the attacker simply spammed NFTokenCreateOffer transactions at every wallet on the ledger, hoping a few victims would tap "accept" on whatever showed up in their inbox. Once wallets started flagging unsolicited offers as spam and hiding them by default, the operator shifted up the stack. The current variant abuses the wallet sign-in / push-notification flow: instead of pushing offers directly, the attacker lures the victim to a web app they control, where the page triggers a "verification" sign request that the wallet renders as a routine notification. The malicious payload is now wrapped in a UX the victim already trusts.
Evolving evasion. As detection has tightened across XRPL platforms and wallets, the campaign has shifted. The most recent variants mint blankNFTs with minimal or no on-chain metadata (no URI, no memo, sometimes no name), so URI and memo classifiers have nothing to match. We catch these by issuer-level reputation: any wallet that has ever produced a confirmed scam is auto-flagged on every subsequent mint and offer, URI or not. The list refreshes live and is published as scamIssuersList in the /api/nft/scam response so wallets can mirror it client-side.
Off-chain variant: terminal stealer payload
The same operators run a parallel attack that never touches the ledger. The bait NFT or a linked page prompts the user to "complete verification" by copying a string and pasting it into their desktop terminal (PowerShell on Windows, Terminal on macOS). The pasted line fetches a payload from a short-lived host (e.g. mmzzxcca.xyz/update3.zip) which deploys HijackLoaderplus SnappyClient, a commodity-stealer combo that exfiltrates browser cookies, saved passwords, and cryptocurrency wallet files, and installs persistence via a Run key plus DLL injection into SysWOW64\input.dll. See the public sandbox detonation at tria.ge/260505-k76d4afx2j (severity 10/10).
There is no XRPL signature involved: the loss happens entirely on the victim's machine, and the attacker can sweep funds from any wallet whose seed or session cookie was stored locally. Never paste anything from an NFT, Discord, Twitter, or website prompt into a terminal. No legitimate XRPL service ever asks you to do this.

Live on-chain data
Monthly drain timeline
| Month | XRP drained | Events |
|---|---|---|
| 2026-06 | 24.7K | 45 |
| 2026-05 | 1.06M | 483 |
| 2026-04 | 229.9K | 134 |
| 2026-03 | 101.8K | 47 |
| 2026-02 | 423.1K | 148 |
| 2026-01 | 9.5K | 44 |
Top scammer wallets (XRP received)
| Address | XRP received | Drains |
|---|---|---|
| r3qAzD…x6ia | 576.6K | 10 |
| rKWQGG…MaTp | 347.4K | 101 |
| rG8Vfi…1UTq | 191.2K | 104 |
| rMKAzY…smaV | 156.7K | 39 |
| rNRvAX…ev4k | 75.1K | 25 |
| rn98Kz…WRWu | 61.2K | 72 |
| rfAJ3d…KHD2 | 46.8K | 23 |
| r4JECs…bWAV | 38.3K | 51 |
| rGtC5i…Z22M | 36.2K | 13 |
| r3788V…Vug7 | 35.9K | 19 |
Top victim wallets (XRP paid)
| Address | XRP paid | Drains |
|---|---|---|
| rGhwR5…X2xG | 556.1K | 1 |
| rn6jfs…RvFB | 291.4K | 3 |
| rhQ24R…WzD8 | 100.0K | 2 |
| rnw9bP…T8ZT | 79.0K | 1 |
| rnx9XF…8Lob | 56.0K | 1 |
| rKV3MD…mwc2 | 43.1K | 1 |
| rh1avy…ZVGW | 39.7K | 1 |
| rL8RPD…gsTs | 33.2K | 4 |
| rGVW8W…bBgc | 31.6K | 1 |
| r3miTG…H92u | 30.0K | 1 |
Scammer wallet holdings (live)
Current on-chain holdings of every scam wallet, XRP plus IOU/LP tokens at market value. Compare against the 1.84M XRP-equiv drained from victims: 99% has already been moved off-chain (cashed out, bridged, or pushed through a tumbler).
| Wallet | Total (XRP-eq) | Composition |
|---|---|---|
| rKWQGG…MaTp 6.17M REITF497.1K RIBBLE109.5K DARKNET120.07M LP XRP/PONGO | 1.3K | 41/1.2K XRP / Tokens |
| rn98Kz…WRWu 16 XIO26.6K $XRPLedgerETF106.96B GANJA2.7K XRPH | 988 | 14/973 XRP / Tokens |
| rfotNC…uPKU 746 66667.44M $BWTZ2.7K GRIM2.7K RPR | 675 | 5/670 XRP / Tokens |
| r4JECs…bWAV 2.19M ROOFxrp14.97T PEPE573 EVR1.13M CSC | 574 | 15/559 XRP / Tokens |
| rfAJ3d…KHD2 9.15M FUZZY6.6K XRPH1.59M PHNIX7 RLUSD | 434 | 9/425 XRP / Tokens |
| r4W4fi…8vu4 11.52M FUZZY178 VGB2.7K ELS52 XPM | 380 | 6/374 XRP / Tokens |
| rMMdkU…cxPL 5.0K BEAR | 348 | 332/16 XRP / Tokens |
| rfSMGP…M98F 671.5K PHNIX0 RLUSD | 339 | 331/8 XRP / Tokens |
| rsXHyu…6ruc 23.64M PHNIX14.8K XFT | 274 | 3/271 XRP / Tokens |
| r3kkKv…d5sP 33.3K REAL0 MAG1.74M FUZZY5.3K XRT | 261 | 6/255 XRP / Tokens |
| rMKAzY…smaV 3.82M FUZZY459.38B XRSHIB1.8K XRT8 666 | 183 | 9/174 XRP / Tokens |
| r4GwDN…itsV 0 MAG133 RPR0 DROP | 150 | 135/15 XRP / Tokens |
| r3qAzD…x6ia 16.8K XPM0 MAG90.5K FUZZY63 SOLO | 149 | 6/143 XRP / Tokens |
| rnsMwz…NcTD 11.11M ATM1.04M FUZZY0 MAG999 JUP | 133 | 7/126 XRP / Tokens |
| rG8Vfi…1UTq 2.4K FLR1.1K CTF690 XAH7.9K PLR | 128 | 53/75 XRP / Tokens |
| rp81Bk…6ZEV 368.1K CSC0 PHNIX | 99 | 84/14 XRP / Tokens |
| raMZGe…RCiz 1.0K VGB968 XPM64.2K XDX46.5K FUZZY | 95 | 80/16 XRP / Tokens |
| rhQ63w…QEe7 4.0K CTF2.8K SOLO21.9K ELS0 Opulence | 94 | 6/88 XRP / Tokens |
| rhuTqh…i6cM 167 Factora46 SOLO | 84 | 77/6 XRP / Tokens |
| rMWj9F…RHAJ | 79 | 79/0 XRP / Tokens |
Snapshot from the last cron run (37s ago). Top 20 wallets shown. XRP cash Tokens LP chip
Potential dump pressure: tokens held by scammers
Aggregate token positions across all 138 scam wallets. If any of these tokens see a large market sell, the scammers are likely behind it. Sorted by current XRP-equivalent.
| Token | Issuer | Amount held | Value (XRP) | Wallets |
|---|---|---|---|---|
| REITF | rLSCBS…LygX | 6.17M | 1.1K | 1 |
| FUZZY | rhCAT4…pR62 | 28.30M | 913 | 67 |
| XIO | rfuzio…RoxU | 17 | 495 | 2 |
| 666 | rhvf9f…frxN | 795 | 378 | 4 |
| PHNIX | rDFXbW…ivmN | 32.27M | 369 | 63 |
| $BWTZ | rrpQUE…GMHS | 67.44M | 292 | 1 |
| ROOFxrp | roofxr…r5Jv | 2.19M | 239 | 1 |
| MAG | rXmagw…vVMJ | 1 | 181 | 11 |
| $XRPLedgerETF | raChAW…F74Z | 26.6K | 173 | 1 |
| REAL | rKVyXn…Nz88 | 55.5K | 162 | 11 |
Top 10 by current XRP-equivalent. 40 distinct tokens total.
Tokens drained (top 40 by frequency)
Value in XRP uses current market price for regular tokens, or AMM pool reserves for LP tokens. - means no price feed (illiquid or delisted).
| FUZZY | rhCAT4…pR62 | 684.73M | 22.2K | 33 |
| RLUSD | rMxCKb…m5De | 1.4K | 1.2K | 24 |
| PHNIX | rDFXbW…ivmN | 2.09B | 23.8K | 22 |
| SOLO | rsoLo2…rLZz | 66.4K | 945 | 18 |
| CSC | rCSCMa…gkwr | 400.65M | 15.7K | 13 |
| 03C3BE9D…LP XRP/MAG | rNZ2ZV…bXce | 276.8K | 10.6K | 12 |
| REAL | rKVyXn…Nz88 | 229.6K | 670 | 12 |
| BXE | rM1J2M…y87r | 154.1K | 417 | 12 |
| VGB | rhcyBr…knaU | 33.5K | 243 | 9 |
| XPM | rXPMxB…wkoa | 21.5K | 108 | 9 |
Recent drains (live feed)
Each row links to the on-chain transaction and the bait NFT. Hover any abbreviated value to see the full ID.
| When | Victim | Scammer | Paid | Bait NFT | Tx |
|---|---|---|---|---|---|
| 1d ago | rEwrHx…wkxh | raq3mQ…s45K | 3 XRP | 00080000…FA13 | 162F5D88…D606 |
| 3d ago | rpuB7i…wKFV | rhQ63w…QEe7 | 200 XRP | 00090000…EA20 | 23D86CF8…A87D |
| 3d ago | rhbnMP…Pv82 | rhQ63w…QEe7 | 90.00M LP XRP/XHO≈ 790 XRP | 00090000…EA1E | AC763BC5…9DF7 |
| 3d ago | rhbnMP…Pv82 | rhQ63w…QEe7 | 3.68M LP XHO/Opulence | 00090000…EA1D | 240F0685…1D07 |
| 3d ago | rMGLzB…4GC2 | rhQ63w…QEe7 | 197 XRP | 00090000…EA1C | FA017B6E…C962 |
| 3d ago | rNpd3e…2jhX | rhQ63w…QEe7 | 323 XRP | 00090000…EA1B | 46203EBE…F55C |
| 4d ago | r3g2vr…rLVz | rhQ63w…QEe7 | 10 XRP | 00090000…EA1A | 92D499F3…6DD6 |
| 5d ago | rhbnMP…Pv82 | rhQ63w…QEe7 | 186.03M LP XRP/Opulence≈ 3.8K XRP | 00090000…EA27 | FCE501AA…5DDE |
| 5d ago | rDSFFY…vYBK | rhuTqh…i6cM | 15.2K LP XRP/MAG≈ 585 XRP | 00090000…8A2B | 03C850E2…4956 |
| 6d ago | rNMXyx…PzNM | rp81Bk…6ZEV | 8 XRP | 00090000…E642 | 638F6104…E1B5 |
Drains ≥ 10,000 XRP highlighted in red. Scammer wallets in red, victims in blue.
Protect yourself
How to protect yourself (users)
- Never sign an
NFTokenCreateOffer, or any transaction, you didn't deliberately start. - Treat memos like "Verification", "Safe XRPL verify", or "idx:N;len:N" as red flags. No legitimate XRPL service uses those.
- If an NFT in your wallet shows a huge balance you never bought, do not click it (don't interact with things you do not understand). Check the URI: anything pointing to
xrpl-api.comorxrp-api.comis the drain campaign. - Burn or hide suspect NFTs from your wallet instead of interacting with them.
- Never paste a "verification" code into your terminal. If an NFT description, linked page, Discord/Twitter DM, or "support agent" tells you to open PowerShell/Terminal and paste a command, it is HijackLoader/SnappyClient or an equivalent commodity stealer. It will exfiltrate your browser cookies, saved passwords, wallet files, and stage persistence on your machine. No real XRPL service ever requires this.
- If you've been drained on-chain, the transfer cannot be reversed. If your machine was compromised (terminal-paste variant), assume cookies + saved credentials + locally stored wallet seeds are all leaked: rotate exchange/email/social passwords from a clean device, revoke any active wallet sessions, and move XRPL funds to a fresh seed generated offline on hardware you trust.
Already got the spam offers? Revoke Xaman third-party app access
If you connected your Xaman wallet to one of the phishing sites and are now being spammed with NFT offers, cancelling each offer does not stop the attack. The attacker holds an active third-party app permission on your wallet and will keep pushing offers until you revoke it.
- Open Xaman → Settings → Third-party apps.
- Look for an app you don't recognise. Most commonly the malicious entry is labelled "XPMarket", but the attacker can rename it to anything (Xaman, FuzzyBear, RLUSD, an XRPL marketplace, etc.). The displayed name is not verified.
- Tap the suspicious app.
- Scroll to the bottom and tap Revoke access.
After revoking, the attacker can no longer create offers on your behalf. If you signed anything during the session, or if you can't remember exactly what you authorized, move remaining XRP, tokens, and any LP positions to a fresh seed generated offline.
For developers
For wallet & dapp developers: automatic scam detection
Two free public endpoints cover the full integration surface. No API key required; data updates every minute.
GET /api/nft/<NFTokenID>Already part of the standard NFT API. Returns the full NFT document; check the scam: true and scamType fields before rendering or accepting an offer.
curl https://api.xrpl.to/api/nft/00090000560ABF36DE406A9E7EE3B37CBBE047629EC1C40E956828E50634B54A
# → { "_id": "0009...", "scam": true, "scamType": "phishing_uri_domain", "issuer": "r3qAz...", ... }GET /api/nft/scamSingle endpoint with everything: aggregate stats, monthly timeline, top scammers/victims, recent drains, and a flat scamIssuersList (466 addresses today) for client-side filtering. Cache locally and filter incoming NFTs by issuer against the list; pre-empts any per-NFT round-trip for known-bad wallets. Refresh every few minutes.
curl https://api.xrpl.to/api/nft/scam
# → { "totals": { ... }, "monthlyTimeline": [ ... ], "topScammers": [ ... ],
# "tokensDrained": [ ... ], "recentDrains": [ ... ],
# "scamIssuersList": ["r3qAz...", "rGhwR5...", ...], ... }Suggested integration: on app load, fetch /api/nft/scam once and cache the scamIssuersList. For each NFT before rendering, check nft.issuer ∈ scamIssuersList first (O(1) client-side). If the issuer is clean but you want to verify the specific NFT, follow up with GET /api/nft/<NFTokenID>and check scam in the response. Detection is already live; flags appear on-chain within seconds of a new mint or offer.
The full XRPL.to API surface (tokens, AMM pools, NFTs, traders, OHLC, holders, search, and more) is documented at xrpl.to/docs. Free, no API key required for read endpoints, no rate-limit headaches for normal use. A modern alternative to the Ripple Data API with deeper filtering and richer query parameters.