All Insights
Live On-Chain Tracker

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 →

Total drained (XRP-equiv)
1.84M
1.31M XRP + 531.4K in tokens
Held by scammers
9.6K
99% already laundered
Wallets affected
516
unique victims drained
Drain events
914
243 distinct tokens
NFTs flagged
27.4K
360 offers blocked
Scam wallets tracked
466
auto-flagged on each new mint
Deep dive: we traced one operator behind this campaign — a single actor rotating a fresh "Verification Sign" minting wallet every 1–2 days across 528 wallets, with full addresses, transaction hashes, and the 200+ exchange destination tags he cashes out to. Read the investigation →

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:

1Lure

Fake airdrop or reward on X, Discord, Telegram, or a Google-Ads phishing site.

2Connect wallet

Victim connects Xaman / Crossmark / GemWallet. Address shared, no funds moved yet.

3Spam offers

Attacker pushes NFTokenCreateOffer prompts non-stop, disguised as 'verification'.

4Outcome
Sign → drained.
Revoke → safe.

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.

Phishing page prompting the user to paste a verification code into their desktop terminal
Screenshot of the phishing page: a fake "verification" workflow that instructs the user to open their OS terminal and paste a copied string.
Recording of the lure in the wild. The victim is walked through opening their OS terminal and pasting an "update" command that silently installs the stealer.

Live on-chain data

Monthly drain timeline

MonthXRP drainedEvents
2026-0624.7K45
2026-051.06M483
2026-04229.9K134
2026-03101.8K47
2026-02423.1K148
2026-019.5K44

Top scammer wallets (XRP received)

AddressXRP receivedDrains
r3qAzD…x6ia576.6K10
rKWQGG…MaTp347.4K101
rG8Vfi…1UTq191.2K104
rMKAzY…smaV156.7K39
rNRvAX…ev4k75.1K25
rn98Kz…WRWu61.2K72
rfAJ3d…KHD246.8K23
r4JECs…bWAV38.3K51
rGtC5i…Z22M36.2K13
r3788V…Vug735.9K19

Top victim wallets (XRP paid)

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).

WalletTotal (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…RHAJ79
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.

TokenIssuerAmount heldValue (XRP)Wallets
REITFrLSCBS…LygX6.17M1.1K1
FUZZYrhCAT4…pR6228.30M91367
XIOrfuzio…RoxU174952
666rhvf9f…frxN7953784
PHNIXrDFXbW…ivmN32.27M36963
$BWTZrrpQUE…GMHS67.44M2921
ROOFxrproofxr…r5Jv2.19M2391
MAGrXmagw…vVMJ118111
$XRPLedgerETFraChAW…F74Z26.6K1731
REALrKVyXn…Nz8855.5K16211

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).

FUZZYrhCAT4…pR62684.73M22.2K33
RLUSDrMxCKb…m5De1.4K1.2K24
PHNIXrDFXbW…ivmN2.09B23.8K22
SOLOrsoLo2…rLZz66.4K94518
CSCrCSCMa…gkwr400.65M15.7K13
03C3BE9D…LP XRP/MAGrNZ2ZV…bXce276.8K10.6K12
REALrKVyXn…Nz88229.6K67012
BXErM1J2M…y87r154.1K41712
VGBrhcyBr…knaU33.5K2439
XPMrXPMxB…wkoa21.5K1089

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.

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.com or xrp-api.com is 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.

  1. Open Xaman → SettingsThird-party apps.
  2. 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.
  3. Tap the suspicious app.
  4. 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.

1. Per-NFT scam check: 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...", ... }
2. Tracker snapshot + scam-issuer list: GET /api/nft/scam

Single 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.