📊 Full opportunity report: Three Public Vulnerabilities. Chained. on ThorstenMeyerAI.com — validation score, market gap, and execution plan.
TL;DR
On May 11, 2026, attackers exploited a chain of three publicly known vulnerabilities to compromise TanStack npm packages. The attack used publicly documented research and was executed faster than defenses could respond.
On May 11, 2026, attackers exploited a chain of three publicly documented vulnerabilities to publish 84 malicious versions of TanStack npm packages within six minutes, bypassing existing security defenses. This incident underscores the rapid evolution of supply-chain attacks leveraging public research, and it involves a sophisticated use of known vulnerabilities to breach a security-conscious open-source project.
The attack was carried out through a series of chained vulnerabilities that included the ‘pull_request_target’ ‘Pwn Request’ pattern, cache poisoning across trust boundaries, and extraction of OIDC tokens from GitHub Actions runners. Each vulnerability was publicly documented prior to the attack: GitHub Security Lab described the ‘Pwn Request’ pattern years earlier, Adnan Khan detailed cache poisoning in May 2024, and StepSecurity explained OIDC token extraction in March 2025. The attacker created a fork of TanStack/router, injected malicious code via a crafted commit, and used GitHub Actions workflows to exfiltrate credentials without stealing tokens or compromising the workflow itself. The attack was executed within hours of the malicious commit and PR submission, demonstrating the rapid pace at which attacker tradecraft can be deployed using publicly available research.
Three public vulnerabilities.
Chained.
The TanStack npm compromise of May 11, 2026 — published research recombined into working tradecraft, weaponized faster than defenders deploy mitigations.
84 malicious versions across 42 packages. Six-minute publish window. No npm tokens stolen. OIDC minted in memory and exfiltrated via Session Protocol. Three vulnerabilities chained — each documented in public research 12-24 months before the attack. Same date as the GTIG zero-day disclosure. The composition is the attack surface.
Each bridges the trust boundary the others assumed.
PR fork code crossing into base-repo cache. Base-repo cache crossing into release-workflow runtime. Release-workflow runtime crossing into npm registry write access. The composition only works because each vulnerability bridges the trust boundary the others assumed.
pull_request_target for fork PRs and checked out the fork’s PR-merge ref to run a build. Bypasses first-time-contributor approval gate. Author attempted trust split but missed that actions/cache@v5‘s post-job save is not gated by permissions:. Cache scope is per-repo, shared across triggers.Linux-pnpm-store-${hashFiles('**/pnpm-lock.yaml')} — exact match. actions/cache@v5 post-step saves poisoned store to that key. Restored entirely as designed when release.yml next runs on push to main.id-token: write for legitimate npm OIDC trusted publishing. Poisoned cache invokes attacker binaries: locate Runner.Worker via /proc/*/cmdline, dump memory via /proc//maps + /proc//mem , extract OIDC token, POST to registry.npmjs.org. Bypasses workflow’s Publish Packages step entirely.The attacker did not invent novel tradecraft. They recombined published research. Verbatim Python script — attribution comment preserved — from the March 2025 tj-actions disclosure. Every defensive research publication becomes attacker reference material within 12-24 months.

Software Supply Chain Defense: Securing Build Environments, Toolchains, and CI/CD Infrastructure Against Advanced Threats
As an affiliate, we earn on qualifying purchases.
As an affiliate, we earn on qualifying purchases.
May 10 17:16 fork. May 11 19:50 detection.
From the attacker creating a renamed fork (deliberately evading fork-list searches) through the cache poisoning phase, the detonation phase, and the rapid external detection by Ashish Kurmi at StepSecurity. The TanStack postmortem published the complete root cause analysis publicly within hours.
PHASE
65bf499d authored by fabricated identity claude (NOT real Anthropic Claude). [skip ci] prefix suppresses CI on push. Adds packages/history/vite_setup.mjs — ~30,000-line bundled JS payload.PREP
pull_request_target. No first-time-contributor approval — pull_request_target bypasses that gate. pr.yml blocked.TRIGGER
65bf499d on PR head. bundle-size.yml’s benchmark-pr job checks out refs/pull/7378/merge, runs pnpm install + pnpm nx run @benchmarks/bundle-size:build. Executes fork-controlled vite_setup.mjs.EXEC
Linux-pnpm-store-6f9233a50def742c09fde54f56553d6b449a535adf87d4083690539f49ae4da11 (1.1 GB) saved for TanStack/router, scoped to refs/heads/main. Keyed to match what release.yml will compute on next push.ACTIVE
b1c061af). Visible PR diff is 0-file no-op. PR closed and branch deleted in same minute. Cache poison persists. PR appears benign in retrospective review./proc/*/cmdline, dumps memory, extracts OIDC token, POSTs to registry.npmjs.org. Bypasses defined Publish Packages step entirely.EXEC
@tanstack/history@1.161.12 etc. Six minutes between the two publish waves. Workflow status: failure (tests broke; publish still happened).BLAST
DETECTION
COMPLETE
npm package vulnerability scanner
As an affiliate, we earn on qualifying purchases.
As an affiliate, we earn on qualifying purchases.
160+ packages. One worm. Same threat actor.
The TanStack compromise is one node in the broader Mini Shai-Hulud campaign by threat group TeamPCP — the same actor behind LiteLLM PyPI (March 2026), Bitwarden CLI npm, SAP CAP npm, and Lightning PyPI (April 30, 2026). Self-propagating worm pattern. First documented npm worm with valid SLSA Build Level 3 attestations.
May 2026 wave
weekly downloads
compromised May 12
fork → detection
registry.npmjs.org/-/v1/search?text=maintainer: → republish with same injection. Active operational campaign as of May 12, 2026.
Python Cybersecurity Automation Tips – Efficient security monitoring and penetration testing automation using scripts and tools – (Japanese Edition)
As an affiliate, we earn on qualifying purchases.
As an affiliate, we earn on qualifying purchases.
IOCs · copy-pasteable for hunting queries.
The TanStack postmortem published comprehensive IOCs. Defenders should hunt for these across their environments. The attacker forged a “claude” identity using claude@users.noreply.github.com — not the real Anthropic Claude Code GitHub App. This identity-confusion tactic deserves specific attention in git-log audits.
bun run tanstack_runner.js && exit 1 on install — payload runs, then optional dep “fails” gracefully.router_init.js (~2.3 MB, package root, not in files array). Also: tanstack_runner.js per Socket analysis.https://litter.catbox.moe/h8nc9u.js, https://litter.catbox.moe/7rrc6l.mjs. Secondary exfil via legitimate-looking GitHub GraphQL API traffic.git log --all --author=claude@users.noreply.github.com across all repos. Force-push revert if found.zblgg (id 127806521) · voicproducoes (id 269549300 · account created 2026-03-19 — fresh account, public repos named “A Mini Shai-Hulud has Appeared”). Attacker fork: github.com/zblgg/configuration (renamed). Workflow runs: 25613093674 · 25691781302.code integrity verification software
As an affiliate, we earn on qualifying purchases.
As an affiliate, we earn on qualifying purchases.
Installed it? Rotate. Maintain packages? Audit.
Three response tracks. If you installed an affected version on May 11: treat your host as compromised. If you maintain OSS with similar workflow patterns: audit pull_request_target immediately. If you consume the npm ecosystem at enterprise scale: deploy install-time monitoring and lockfile pinning.
- Rotate AWS, GCP, Azure, Kubernetes service-account tokens, Vault tokens, npm
~/.npmrc, GitHub tokens, SSH private keys - Review GitHub Actions runs after 2026-05-11T19:20Z for unexpected npm publish events
- Check outbound connections to
filev2.getsession.org·seed*.getsession.org - Check downstream propagation — if your packages were published during a CI run that installed compromised version, those may also be compromised
- Audit
~/.claude/+.vscode/tasks.json· removerouter_runtime.js,setup.mjs git log --all --author=claude@users.noreply.github.com· revert if found- Run
npm token list· revoke unrecognized tokens
- Audit pull_request_target workflows immediately · never check out fork-submitted code without explicit approval gates
- Pin third-party action refs to commit SHAs ·
actions/checkout@8e5e7e5ab8...not@v6 - Separate cache scopes for trusted vs untrusted contexts · explicit
restore-keysandkeypatterns - Consider moving from OIDC trusted publisher to short-lived classic tokens with manual review
- Add internal alerting on npm publishes · fire on any publish that doesn’t originate from expected workflow step
- Audit other repos for the same bundle-size.yml-style pattern
- Restrict
id-token: writeto only the publish step that needs it
- Deploy npm package monitoring at install time · Socket / StepSecurity / Snyk · Socket flagged TanStack in 6 minutes
- Lockfile-pinned dependencies don’t auto-pull new versions · only consumers installing during the publish window were affected
- Audit lockfiles for
github:URLoptionalDependencies· unusual for production deps, exact pattern used here - CI/CD secret rotation automation · 30-90 day schedule regardless of incident status
- Treat provenance attestations as one layer, not sole verification · Mini Shai-Hulud produces valid Build L3 attestations on malicious packages
- Establish IR playbooks for OSS supply-chain compromise scenarios
Three pieces of public security research. Twelve months between the latest and the attack. Zero novel attacker tradecraft. A competent maintainer team with 2FA and OIDC trusted publishing — compromised through a chain that no individual vulnerability in their stack would have enabled. The composition is the attack surface.
Implications for Supply-Chain Security in Open Source
This incident demonstrates that publicly documented security flaws can be weaponized rapidly, especially when chained together. It highlights the challenge for defenders to keep pace with attacker tradecraft, which now heavily relies on repurposing existing research rather than discovering novel vulnerabilities. The attack underscores the importance of revisiting security practices around trust boundaries, code review, and automation in open-source ecosystems, as well as the need for faster mitigation deployment. It also signals that supply-chain attacks are increasingly sophisticated, leveraging known vulnerabilities in a coordinated manner to bypass defenses and cause widespread impact.Public Research and the Attack Chain in 2026
Throughout 2024 and early 2025, security researchers documented vulnerabilities related to GitHub Actions trust boundaries, cache poisoning, and token extraction. These findings were publicly available but not widely integrated into defensive tools or workflows. On May 10, 2026, the attacker created a fork of TanStack/router, injected malicious code, and prepared for exploitation. The same day, the attacker initiated a pull request, triggering workflows that allowed them to exfiltrate credentials. This chain of known vulnerabilities was exploited within hours, reflecting a broader pattern where public research becomes an attack surface when defenses do not adapt quickly. The incident is part of the ongoing Mini Shai-Hulud campaign, which has compromised over 160 packages, including TanStack, Mistral AI, and UiPath.
“The TanStack attack exemplifies how publicly documented vulnerabilities can be combined into a chain that bypasses defenses, especially when response times lag behind attacker tradecraft.”
— Thorsten Meyer, security researcher
Unclear Aspects of the Attack Chain and Defense Gaps
While the attack chain has been reconstructed based on forensic analysis, some details remain unconfirmed, such as the exact mechanisms used for exfiltration and whether additional undisclosed vulnerabilities contributed. The full scope of affected packages beyond TanStack is still being assessed, and the speed at which defenders can deploy mitigations remains uncertain. It is also unclear how widespread the adoption of mitigations based on these research findings has been across the ecosystem.
Next Steps for Mitigation and Ecosystem Resilience
Security teams and open-source maintainers are expected to review and reinforce trust boundaries, implement stricter code review processes, and adopt faster deployment of mitigations. GitHub and npm are likely to update their security protocols, and researchers will continue monitoring for new attack patterns. The incident underscores the need for proactive defense strategies that incorporate known vulnerabilities into automated detection and response workflows. Additionally, ongoing investigations will determine the full scope of impact and whether further vulnerabilities are being exploited in real-time.
Key Questions
How did the attacker exploit known vulnerabilities so quickly?
The attacker chained publicly documented vulnerabilities—such as trust boundary bypass, cache poisoning, and token extraction—and used automation to execute the attack within hours of the research being published.
Were any tokens or credentials stolen during the attack?
No npm tokens were stolen; the attacker minted an OIDC token in memory and exfiltrated credentials via an encrypted messenger network, avoiding direct theft of stored tokens.
What can open-source projects do to prevent similar attacks?
Projects should review trust boundaries, restrict access points, implement faster security updates, and monitor for suspicious activity, especially when known vulnerabilities are publicly documented.
Is this attack part of a larger campaign?
Yes, it is linked to the ongoing Mini Shai-Hulud supply-chain campaign, which has compromised over 160 packages across multiple organizations.
What is the significance of this incident for the broader software ecosystem?
This incident demonstrates how public research can be weaponized swiftly, emphasizing the need for faster defensive responses and better integration of security findings into automated protections.
Source: ThorstenMeyerAI.com