Mass Supply Chain Attack Hits TanStack, Mistral AI npm and PyPI Packages On May 11, 2026, a coordinated supply chain attack compromised over 170 npm packages and 2 PyPI packages, totaling 404 malicious versions, targeting major projects including the entire TanStack router ecosystem, Mistral AI's SDK suite, UiPath's automation tooling, OpenSearch, and Guardrails AI. The attack, one of the largest registry poisoning events of 2026, spanned both npm and PyPI in a single campaign, using payloads delivered from the attacker-controlled domain git-tanstack[.]com. PyPI has since quarantined the affected projects, and Cloudflare has flagged the domain as a suspected phishing site. Mass Supply Chain Attack Hits TanStack, Mistral AI npm and PyPI Packages Table of Contents TL;DR A coordinated supply chain attack on May 11, 2026 compromised over 170 npm packages and 2 PyPI packages, totaling 404 malicious versions. The attacker hit the entire TanStack router ecosystem 42 packages , Mistral AI’s SDK suite on both npm and PyPI , UiPath’s automation tooling 65 packages , OpenSearch 1.3M weekly npm downloads , and Guardrails AI PyPI . This is one of the largest coordinated registry poisoning events observed in 2026, and the first to span both npm and PyPI in a single campaign. Package Manager Guard https://github.com/safedep/pmg PMG helps protect developers from open source software supply chain attacks using threat intelligence, install-time policy enforcement, and OS-native sandboxing. Its dependency cooldown policy can block newly released packages from being installed immediately, reducing exposure to fast-moving attacks. When installs are allowed, sandboxing helps limit the blast radius of suspicious or compromised packages. Affected packages include full list in appendix appendix-list-of-compromised-packages : @tanstack/react-router : Routing library for React with 3M+ weekly npm downloads @mistralai/mistralai : Official Mistral AI JavaScript/TypeScript SDK @opensearch-project/opensearch : Official OpenSearch JavaScript client @uipath/robot : UiPath’s RPA automation runtime for enterprise workflows @tanstack/vue-router : TanStack’s routing library for Vue applications StepSecurity https://www.stepsecurity.io/blog/mini-shai-hulud-is-back-a-self-spreading-supply-chain-attack-hits-the-npm-ecosystem and Socket Security https://socket.dev/blog/tanstack-npm-packages-compromised-mini-shai-hulud-supply-chain-attack are tracking this attack as “mini-shai-hulud.” Update 2026-05-12, ~03:05 UTC : The campaign expanded beyond npm. The attacker compromised two PyPI packages as part of the same attack: mistralai==2.4.6 : Malicious version of the official Mistral AI Python SDK. The legitimate latest version before the attack was 2.4.5 published May 7 . No v2.4.6 tag exists in mistralai/client-python https://github.com/mistralai/client-python . PyPI has quarantined the entire mistralai project. guardrails-ai==0.10.1 : Malicious version of the Guardrails AI validation framework. PyPI has quarantined the entire guardrails-ai project. The PyPI packages use a different payload delivery mechanism from the npm packages: on import, a Python dropper downloads transformers.pyz from the attacker-controlled domain hxxps://git-tanstack . com/transformers.pyz and executes it with python3 . This is the same git-tanstack . com domain named in the npm campaign’s payload. Cloudflare now marks the domain as a suspected phishing site. What Happened SafeDep’s malware detection pipeline flagged a burst of suspicious npm package publications on the night of May 11. The scope is unusual: the attacker published malicious versions across 170 distinct packages in a single coordinated campaign, unlike the axios compromise /axios-npm-supply-chain-compromise in March that targeted one high-value package. The attacker went after entire organizational scopes, compromising every package under @tanstack , @squawk , @uipath , @tallyui , and several others in bulk. Indicators of Compromise IoC npm packages C2/Exfiltration : hxxp://filev2 . getsession . org/file/ Session file server AWS metadata probe : hxxp://169 . 254 . 169 . 254/latest/meta-data/iam/security-credentials/ Vault probe : hxxp://127 . 0 . 0 . 1:8200 Bun runtime download : hxxps://github . com/oven-sh/bun/releases/download/bun-v1.3.13/ Package SHA-256 : ce7e4199506959fd7a71b64209b2c07b9c82e53a946aa7d78298dc9249230d01 @mistralai/ email protected /cdn-cgi/l/email-protection Malicious GitHub commit : tanstack/router 79ac49eedf774dd4b0cfa308722bc463cfe5885c payload host for @tanstack/setup Dropped files : .claude/settings.json , .claude/setup.mjs , .vscode/tasks.json , .vscode/setup.mjs , .claude/router runtime.js GitHub API abuse : createCommitOnBranch GraphQL mutation to push poisoned configs Token patterns scanned : ghp , gho , ghs , npm PyPI secondary C2 : hxxps://git-tanstack . com/transformers . pyz Cloudflare-proxied, registered May 9, 2026 PyPI payload staging : /tmp/transformers.pyz PyPI packages Update 2026-05-12 Malicious packages : mistralai==2.4.6 , guardrails-ai==0.10.1 PyPI project status : both projects quarantined; no files accessible Payload download domain : hxxps://git-tanstack . com/transformers.pyz Cloudflare-flagged as phishing Payload written to disk : /tmp/transformers.pyz Execution command : python3 /tmp/transformers.pyz no integrity verification Trigger : on import , not on pip install sandboxed install environments will not catch this High-Profile Targets TanStack 42 packages, 84 versions The TanStack ecosystem took the largest hit by package count among well-known projects. The attacker published malicious versions of every router-related package: @tanstack/react-router , @tanstack/vue-router , @tanstack/solid-router , along with their devtools, SSR query plugins, start frameworks, and build tooling. Two versions per package. TanStack Router powers applications across React, Vue, and Solid. Any project that pulled these versions during the attack window ran the malicious preinstall hook. Mistral AI 3 packages, 9 versions The attacker compromised all three Mistral AI SDK packages: @mistralai/mistralai core SDK @mistralai/mistralai-azure Azure integration @mistralai/mistralai-gcp GCP integration Three malicious versions per package. UiPath 65 packages, 65 versions The entire @uipath npm scope was hit with a single compromised version per package. The affected packages span UiPath’s automation platform: agent SDKs, orchestrator tools, RPA tooling, solution packagers, and integration services. Other Notable Targets OpenSearch @opensearch-project/opensearch : The official OpenSearch JavaScript client with 1.3M weekly downloads, hit across 4 versions 3.5.3, 3.6.2, 3.7.0, 3.8.0 Guardrails AI on PyPI : Python AI guardrails framework. Uses a different loader: downloads email protected /cdn-cgi/l/email-protection transformers.pyz from hxxps://git-tanstack . com and runs it with python3 . The domain displayed a taunting message signed “TeamPCP” Attack Pattern Several patterns stand out across the compromised packages: Bulk scope targeting. The attacker published across entire npm scopes rather than cherry-picking individual packages. The @squawk scope had 5 malicious versions per package across all 20 packages. @tallyui had 3 versions each across 10 packages. Version count variation. TanStack packages received 2 versions each. @beproduct/nestjs-auth received 18 versions 0.1.2 through 0.1.19 . @uipath packages received exactly 1 version each. This variation suggests the attacker may have used different strategies per target, or adjusted based on access constraints. Concentrated timeline. The attacker published all 401 versions within a five-hour window on May 11, suggesting automated tooling rather than manual work. Two trigger mechanisms. The Mistral AI packages use a preinstall hook: the attacker stripped legitimate build scripts and replaced them with node setup.mjs , which downloads Bun and runs the payload. The TanStack packages use a stealthier approach: an optionalDependency pointing to a malicious commit in the real tanstack/router GitHub repository, whose prepare script runs the payload via Bun. Both paths deliver the same obfuscated credential-stealing payload. Multi-target credential harvesting. The payload carries a modular credential stealing framework with dedicated providers for AWS IAM, HashiCorp Vault, GitHub tokens ghp , gho , ghs , npm publish tokens, and GitHub Actions OIDC tokens. The breadth of credential targets suggests the attacker is optimizing for lateral movement across cloud and CI/CD infrastructure. Exfiltration over Session protocol. The payload sends stolen credentials through the Session onion-routed messenger network instead of a traditional C2 domain. Defenders cannot take down a decentralized swarm the way they can seize a domain. IDE and AI agent poisoning for propagation. The payload uses stolen GitHub tokens to commit poisoned configuration files .claude/settings.json , .vscode/tasks.json into victim repositories via GitHub’s GraphQL API. Other developers who clone or pull these repositories inherit the malicious configurations. The attacker designed this as a self-spreading vector that targets Claude Code and VS Code users. Shared payload template. The Mistral AI package references its payload as tanstack runner.js , a naming artifact from the TanStack packages. The tanstack prefix in a Mistral AI package points to a single payload template reused across the campaign, with incomplete per-target customization. Technical Analysis We examined two compromised packages from different scopes to verify that the campaign uses a shared payload. The Mistral AI and TanStack packages use different trigger mechanisms but drop the same credential-stealing, C2-capable payload. Mistral AI: @mistralai/ email protected /cdn-cgi/l/email-protection Package Diff: 2.2.1 vs 2.2.2 The compromised tarball is more than double the size of the legitimate release 1.9MB vs 873KB . Diffing the file trees reveals two new files and a rewritten scripts block in package.json : The attacker replaced all legitimate build scripts with a single preinstall hook and added two files: setup.mjs : A downloader/loader that bootstraps the attack router init.js : A 2.2MB heavily obfuscated payload single line, hex variable obfuscation The attacker did not modify any existing SDK source files. The attack is additive only. Execution Trigger: setup.mjs The preinstall hook runs setup.mjs , which downloads a platform-specific Bun https://bun.sh runtime binary from GitHub releases bun-v1.3.13 and uses it to execute the obfuscated payload: The loader supports Linux x64, arm64, musl , macOS x64, arm64 , and Windows x64, arm64 . It detects musl-based systems Alpine for correct binary selection. If Bun is already installed on the system, it skips the download and uses the local copy. The setup.mjs references the payload as tanstack runner.js , but the actual file in the package is router init.js . This naming mismatch means the Mistral preinstall hook fails at runtime. The tanstack prefix in a Mistral AI package confirms the attacker reused a template built for the TanStack packages without updating the filename constant. TanStack: @tanstack/ email protected /cdn-cgi/l/email-protection The TanStack variant uses a different, more subtle trigger mechanism. Diffing @tanstack/ legitimate against email protected /cdn-cgi/l/email-protection 1.169.5 compromised shows the attacker left the scripts block untouched and instead injected a single entry into optionalDependencies : No setup.mjs exists in the TanStack tarball. The attack does not modify scripts at all. Instead, @tanstack/setup resolves to a malicious commit in the tanstack/router GitHub repository. Note: GitHub has since removed this commit. The commands above will return 404. Our analysis was performed before the cleanup. That commit contained two files: The package.json at that commit: npm resolves the GitHub dependency by cloning the commit and running the prepare script, which executes the payload via Bun. The && exit 1 forces the prepare step to fail after execution, suppressing any further post-install output that might alert the developer. This trigger is harder to spot than the Mistral variant. A reviewer scanning package.json sees no modified scripts block. The malicious entry hides in optionalDependencies and points to a real GitHub repository tanstack/router , not a suspicious external URL. The attacker had write access to the TanStack GitHub repository to push this commit, indicating compromised GitHub credentials in addition to npm publish tokens. The npm tarball also contains router init.js 2,341,681 bytes , a slightly larger copy of the same obfuscated payload. Both the GitHub-hosted tanstack runner.js and the tarball’s router init.js contain identical malicious functionality: 396 beautify encrypted string calls, the same AES decryption layer, the same credential provider class hierarchy, the same Session C2 implementation including the mlYTXvk... seed node certificate fingerprint , and the same IDE poisoning file map .claude/settings.json , .vscode/tasks.json . The hex variable names differ between the two, indicating each got a separate obfuscation pass from the same tool. Obfuscated Payload: router init.js The payload is a 2.2MB single-line JavaScript file using hex variable obfuscation 0x12ada1 , 0x3782 , 0x360f . It uses a shuffled string array with a rotation function, making static analysis difficult. Critical strings are double-encrypted: first through the hex obfuscator’s lookup table, then through AES decryption via a w8 function that uses createDecipheriv and Bun’s gunzipSync . The payload contains a modular credential stealing framework with dedicated provider classes, all extending a base class gQ : | Class | Target | Credentials Harvested | |---|---|---| NK | AWS | AWS ACCESS KEY ID , AWS SECRET ACCESS KEY , IAM instance credentials via 169.254.169.254 | ZK | HashiCorp Vault | VAULT TOKEN , VAULT AUTH TOKEN default: http://127.0.0.1:8200 | MK | GitHub Actions Runner | ghp , gho , ghs tokens, ACTIONS ID TOKEN | JK | GitHub Actions CI | ghp , gho tokens, npm tokens | FK | Secrets Manager | ghp , gho , npm tokens | UK | Secrets Manager | npm tokens | DK / OK | Miscellaneous | ghp , gho , npm tokens | Token patterns matched by the credential scanner: Exfiltration via Session Protocol The payload exfiltrates stolen credentials through the Session https://getsession.org messaging protocol, an onion-routed encrypted messenger built on the Oxen network. It embeds a full Session client implementation, not a simple HTTP call to a C2 domain. The payload bootstraps by connecting to Session’s seed nodes with pinned TLS certificates issued by the Oxen Privacy Tech Foundation: After retrieving the snode list, the payload resolves the target swarm for the attacker’s Session ID and routes encrypted messages through selected snodes: Larger data blobs file uploads go through Session’s centralized file server at hxxp://filev2 . getsession . org/file/ : The payload uses ed25519 and x25519 key pairs for Session’s end-to-end encryption. There are no fixed C2 URLs to block: message routing happens through the Session swarm network, where snode addresses are resolved at runtime. The only static infrastructure is the seed node bootstrap and the file upload server. IDE and AI Agent Poisoning The payload contains a self-replicating mechanism that commits malicious configuration files into victim repositories. This section traces the full chain from file map to GitHub commit. File Map The payload defines a map of files to drop into target repositories: FO , DO , and h9 are double-encrypted strings decoded at runtime through w8 beautify ... , key , the same AES + gunzip pipeline used throughout the payload. The .claude/setup.mjs and .vscode/setup.mjs share the same encrypted blob h9 . The .claude/router runtime.js entry does not use an encrypted string. Instead, { sourcePath: Bun.main } tells the file processor yO function to read the currently executing script, base64-encode it, and include it in the commit. Bun.main resolves to the absolute path of router init.js . The attacker commits the full 2.2MB obfuscated payload into the victim’s repository, ensuring the next stage of the chain has the complete malware available locally. Target Repository and Branch Selection The payload reads process.env.GITHUB REPOSITORY set by GitHub Actions and splits it into owner/repo: The branch lister p6 class queries up to 50 branches via GitHub’s GraphQL API, then filters out branches matching an exclusion list s3 . The exclusion list contains four encrypted patterns, likely main , master , develop , and release . The payload targets feature and topic branches, where a new commit is less likely to trigger review and more likely to be merged into the main branch. Commit Execution The payload commits poisoned files using GitHub’s createCommitOnBranch GraphQL mutation, batching two branch commits per API call: For multiple branches, xO generates a batched mutation with indexed inputs $input0 , $input1 , etc. , processing two branches per request KS = 0x2 . Each commit includes an encrypted headline GS and a Co-authored-by trailer generated from the qS author list encrypted name and email . The co-author line makes the commit appear collaborative rather than anomalous. Propagation Chain The dropped files create a self-sustaining infection loop: .claude/settings.json and .vscode/tasks.json configure the IDE or AI agent to execute .claude/setup.mjs or .vscode/setup.mjs on project load setup.mjs h9 runs router runtime.js , which is the full payload- The payload harvests credentials from the new victim environment and repeats the cycle Any developer who clones or pulls a poisoned branch gets the malicious IDE configuration. Opening the project in VS Code or running Claude Code triggers the payload without any explicit action from the developer. Secondary GitHub Channels The payload also uses GitHub’s REST API for two additional purposes: Commit search as C2 : The MM function queries api.github.com/search/commits for a specific marker b9 , encrypted . When matching commits are found, the payload extracts base64-encoded data from the commit messages, decodes it, and acts on the instructions. This turns GitHub’s commit history into a command-and-control channel. Data exfiltration via repository : The payload uploads stolen credentials to a GitHub repository under contents/results/ using the REST API, with retry logic up to 5 attempts with exponential backoff . This provides an exfiltration channel that operates entirely within GitHub’s infrastructure, alongside the Session messenger channel. PyPI Packages: mistralai 2.4.6 and guardrails-ai 0.10.1 Update 2026-05-12 The attacker crossed from npm into PyPI and compromised two packages. The exact publication timestamps are unavailable because PyPI quarantined both projects before we could query the metadata. Cross-Ecosystem Attack Chain The attacker published mistralai==2.4.6 and guardrails-ai==0.10.1 to PyPI without committing to or triggering either package’s GitHub Actions release workflow. The credential source for the PyPI publishes is unknown. The npm payload steals npm tokens and GitHub tokens but does not target ~/.pypirc or PyPI credentials. The attacker may have obtained PyPI credentials through a separate channel or through environment variables on compromised CI runners. No commits landed in mistralai/client-python https://github.com/mistralai/client-python on May 11, and no v2.4.6 tag exists in the repository. The legitimate latest version before the attack was 2.4.5 , published May 7. Mistral AI never released version 2.4.6 . PyPI Payload Delivery: transformers.pyz The PyPI packages use a different delivery mechanism from the npm packages. Instead of the preinstall hook and bundled router init.js , the malicious Python packages inject code into the package’s init .py that runs on every import . We recovered guardrails-ai==0.10.1 from a PyPI mirror before the quarantine propagated. Diffing init .py against the legitimate 0.10.0 shows 15 lines appended after the all export list, with no other files modified across the entire wheel: No obfuscation. The C2 URL, staging path, and execution command are all plaintext. The sys.platform check gates execution to Linux, so macOS and Windows installs carry the trojanized code but the dropper does not fire. PyPI and all mirrors removed the mistralai==2.4.6 sdist before we could recover it. Based on the shared git-tanstack . com infrastructure, it uses the same init .py injection. The .pyz extension indicates a Python zipapp, a self-contained Python archive the interpreter can execute. We did not recover the contents of transformers.pyz before git-tanstack.com blocked access. The domain is the same attacker-controlled infrastructure referenced in the npm payload’s deobfuscated strings. Cloudflare has flagged git-tanstack.com as a suspected phishing site. Why import-time Triggering Matters PyPI’s sandboxed install environment pip download , pip wheel does not execute package code, unlike npm’s preinstall / postinstall hooks. The init .py trigger fires only when a developer or running application calls import mistralai or import guardrails . This means: - Static analysis of the sdist or wheel may show the dropper code, but automated sandbox installs that don’t exercise the package API will not observe the payload’s network activity - Any application that imported mistralai or guardrails during the attack window should be treated as potentially compromised, regardless of whether pip install ran in a sandboxed environment Broader Context Supply chain campaigns in 2026 keep escalating. The axios compromise /axios-npm-supply-chain-compromise in March targeted a single high-value package. This campaign cast a wide net across hundreds of packages at once, and crossed from npm into PyPI within hours. Different tactics, same root cause: a compromised publishing credential grants unrestricted access to publish new versions. The inclusion of AI/ML packages Mistral AI SDK on both npm and PyPI, guardrails-ai alongside web framework packages TanStack and enterprise automation tooling UiPath suggests the attacker is targeting the broadest possible developer population rather than a specific technology vertical. We will continue to update this post as more details emerge from the ongoing investigation. What To Do npm If your project depends on any of the packages listed in the appendix below, check your lockfile for the specific compromised versions: Pin your dependencies to known-good versions and regenerate lockfiles after confirming the compromised versions have been removed from the registries. PyPI Check whether mistralai==2.4.6 or guardrails-ai==0.10.1 appear in any lockfile or installed environment: If either shows version 2.4.6 mistralai or 0.10.1 guardrails-ai , treat the environment as compromised. The safe version of mistralai is 2.4.5 or earlier. For guardrails-ai , use 0.10.0 or earlier. Also check for the payload artifact on disk: If this file exists, the payload ran. Rotate any credentials that were present in the environment at the time of import . If Any CI/CD Runner Was Exposed If a CI/CD runner installed or ran any of the compromised npm packages and had PyPI publishing credentials available via ~/.pypirc , PYPI TOKEN , or PYPI PASSWORD , rotate those credentials now. Treat any PyPI token that was present in an environment that ran one of the compromised npm packages as stolen. SafeDep vet https://github.com/safedep/vet can scan your dependency tree against known malicious package databases: Appendix: List of Compromised Packages PyPI packages Update 2026-05-12 | Package | Compromised Version | Legitimate Latest | PyPI Status | | |---|---|---|---|---| | 1 | mistralai | 2.4.6 | 2.4.5 | Quarantined | | 2 | guardrails-ai | 0.10.1 | 0.10.0 | Quarantined | | No matching rows | 172 packages across npm and PyPI, 404 compromised versions, grouped by scope and package name. @tanstack npm | Package | Compromised Versions | | |---|---|---| | 1 | @tanstack/arktype-adapter | 1.166.12, 1.166.15 | | 2 | @tanstack/eslint-plugin-router | 1.161.9, 1.161.12 | | 3 | @tanstack/eslint-plugin-start | 0.0.4, 0.0.7 | | 4 | @tanstack/history | 1.161.9, 1.161.12 | | 5 | @tanstack/nitro-v2-vite-plugin | 1.154.12, 1.154.15 | | 6 | @tanstack/react-router | 1.169.5, 1.169.8 | | 7 | @tanstack/react-router-devtools | 1.166.16, 1.166.19 | | 8 | @tanstack/react-router-ssr-query | 1.166.15, 1.166.18 | | 9 | @tanstack/react-start | 1.167.68, 1.167.71 | | 10 | @tanstack/react-start-client | 1.166.51, 1.166.54 | | 11 | @tanstack/react-start-rsc | 0.0.47, 0.0.50 | | 12 | @tanstack/react-start-server | 1.166.55, 1.166.58 | | 13 | @tanstack/router-cli | 1.166.46, 1.166.49 | | 14 | @tanstack/router-core | 1.169.5, 1.169.8 | | 15 | @tanstack/router-devtools | 1.166.16, 1.166.19 | | 16 | @tanstack/router-devtools-core | 1.167.6, 1.167.9 | | 17 | @tanstack/router-generator | 1.166.45, 1.166.48 | | 18 | @tanstack/router-plugin | 1.167.38, 1.167.41 | | 19 | @tanstack/router-ssr-query-core | 1.168.3, 1.168.6 | | 20 | @tanstack/router-utils | 1.161.11, 1.161.14 | | 21 | @tanstack/router-vite-plugin | 1.166.53, 1.166.56 | | 22 | @tanstack/solid-router | 1.169.5, 1.169.8 | | 23 | @tanstack/solid-router-devtools | 1.166.16, 1.166.19 | | 24 | @tanstack/solid-router-ssr-query | 1.166.15, 1.166.18 | | 25 | @tanstack/solid-start | 1.167.65, 1.167.68 | | 26 | @tanstack/solid-start-client | 1.166.50, 1.166.53 | | 27 | @tanstack/solid-start-server | 1.166.54, 1.166.57 | | 28 | @tanstack/start-client-core | 1.168.5, 1.168.8 | | 29 | @tanstack/start-fn-stubs | 1.161.9, 1.161.12 | | 30 | @tanstack/start-plugin-core | 1.169.23, 1.169.26 | | 31 | @tanstack/start-server-core | 1.167.33, 1.167.36 | | 32 | @tanstack/start-static-server-functions | 1.166.44, 1.166.47 | | 33 | @tanstack/start-storage-context | 1.166.38, 1.166.41 | | 34 | @tanstack/valibot-adapter | 1.166.12, 1.166.15 | | 35 | @tanstack/virtual-file-routes | 1.161.10, 1.161.13 | | 36 | @tanstack/vue-router | 1.169.5, 1.169.8 | | 37 | @tanstack/vue-router-devtools | 1.166.16, 1.166.19 | | 38 | @tanstack/vue-router-ssr-query | 1.166.15, 1.166.18 | | 39 | @tanstack/vue-start | 1.167.61, 1.167.64 | | 40 | @tanstack/vue-start-client | 1.166.46, 1.166.49 | | 41 | @tanstack/vue-start-server | 1.166.50, 1.166.53 | | 42 | @tanstack/zod-adapter | 1.166.12, 1.166.15 | | No matching rows | @mistralai npm | Package | Compromised Versions | | |---|---|---| | 1 | @mistralai/mistralai | 2.2.2, 2.2.3, 2.2.4 | | 2 | @mistralai/mistralai-azure | 1.7.1, 1.7.2, 1.7.3 | | 3 | @mistralai/mistralai-gcp | 1.7.1, 1.7.2, 1.7.3 | | No matching rows | @uipath npm | Package | Compromised Version | | |---|---|---| | 1 | @uipath/access-policy-sdk | 0.3.1 | | 2 | @uipath/access-policy-tool | 0.3.1 | | 3 | @uipath/admin-tool | 0.1.1 | | 4 | @uipath/agent-sdk | 1.0.2 | | 5 | @uipath/agent-tool | 1.0.1 | | 6 | @uipath/agent.sdk | 0.0.18 | | 7 | @uipath/aops-policy-tool | 0.3.1 | | 8 | @uipath/ap-chat | 1.5.7 | | 9 | @uipath/api-workflow-tool | 1.0.1 | | 10 | @uipath/apollo-core | 5.9.2 | | 11 | @uipath/apollo-react | 4.24.5 | | 12 | @uipath/apollo-wind | 2.16.2 | | 13 | @uipath/auth | 1.0.1 | | 14 | @uipath/case-tool | 1.0.1 | | 15 | @uipath/cli | 1.0.1 | | 16 | @uipath/codedagent-tool | 1.0.1 | | 17 | @uipath/codedagents-tool | 0.1.12 | | 18 | @uipath/codedapp-tool | 1.0.1 | | 19 | @uipath/common | 1.0.1 | | 20 | @uipath/context-grounding-tool | 0.1.1 | | 21 | @uipath/data-fabric-tool | 1.0.2 | | 22 | @uipath/docsai-tool | 1.0.1 | | 23 | @uipath/filesystem | 1.0.1 | | 24 | @uipath/flow-tool | 1.0.2 | | 25 | @uipath/functions-tool | 1.0.1 | | 26 | @uipath/gov-tool | 0.3.1 | | 27 | @uipath/identity-tool | 0.1.1 | | 28 | @uipath/insights-sdk | 1.0.1 | | 29 | @uipath/insights-tool | 1.0.1 | | 30 | @uipath/integrationservice-sdk | 1.0.2 | | 31 | @uipath/integrationservice-tool | 1.0.2 | | 32 | @uipath/llmgw-tool | 1.0.1 | | 33 | @uipath/maestro-sdk | 1.0.1 | | 34 | @uipath/maestro-tool | 1.0.1 | | 35 | @uipath/orchestrator-tool | 1.0.1 | | 36 | @uipath/packager-tool-apiworkflow | 0.0.19 | | 37 | @uipath/packager-tool-bpmn | 0.0.9 | | 38 | @uipath/packager-tool-case | 0.0.9 | | 39 | @uipath/packager-tool-connector | 0.0.19 | | 40 | @uipath/packager-tool-flow | 0.0.19 | | 41 | @uipath/packager-tool-functions | 0.1.1 | | 42 | @uipath/packager-tool-webapp | 1.0.6 | | 43 | @uipath/packager-tool-workflowcompiler | 0.0.16 | | 44 | @uipath/packager-tool-workflowcompiler-browser | 0.0.34 | | 45 | @uipath/platform-tool | 1.0.1 | | 46 | @uipath/project-packager | 1.1.16 | | 47 | @uipath/resource-tool | 1.0.1 | | 48 | @uipath/resourcecatalog-tool | 0.1.1 | | 49 | @uipath/resources-tool | 0.1.11 | | 50 | @uipath/robot | 1.3.4 | | 51 | @uipath/rpa-legacy-tool | 1.0.1 | | 52 | @uipath/rpa-tool | 0.9.5 | | 53 | @uipath/solution-packager | 0.0.35 | | 54 | @uipath/solution-tool | 1.0.1 | | 55 | @uipath/solutionpackager-sdk | 1.0.11 | | 56 | @uipath/solutionpackager-tool-core | 0.0.34 | | 57 | @uipath/tasks-tool | 1.0.1 | | 58 | @uipath/telemetry | 0.0.7 | | 59 | @uipath/test-manager-tool | 1.0.2 | | 60 | @uipath/tool-workflowcompiler | 0.0.12 | | 61 | @uipath/traces-tool | 1.0.1 | | 62 | @uipath/ui-widgets-multi-file-upload | 1.0.1 | | 63 | @uipath/uipath-python-bridge | 1.0.1 | | 64 | @uipath/vertical-solutions-tool | 1.0.1 | | 65 | @uipath/vss | 0.1.6 | | 66 | @uipath/widget.sdk | 1.2.3 | | No matching rows | @squawk npm | Package | Compromised Versions | | |---|---|---| | 1 | @squawk/airport-data | 0.7.4, 0.7.5, 0.7.6, 0.7.7, 0.7.8 | | 2 | @squawk/airports | 0.6.2, 0.6.3, 0.6.4, 0.6.5, 0.6.6 | | 3 | @squawk/airspace | 0.8.1, 0.8.2, 0.8.3, 0.8.4, 0.8.5 | | 4 | @squawk/airspace-data | 0.5.3, 0.5.4, 0.5.5, 0.5.6, 0.5.7 | | 5 | @squawk/airway-data | 0.5.4, 0.5.5, 0.5.6, 0.5.7, 0.5.8 | | 6 | @squawk/airways | 0.4.2, 0.4.3, 0.4.4, 0.4.5, 0.4.6 | | 7 | @squawk/fix-data | 0.6.4, 0.6.5, 0.6.6, 0.6.7, 0.6.8 | | 8 | @squawk/fixes | 0.3.2, 0.3.3, 0.3.4, 0.3.5, 0.3.6 | | 9 | @squawk/flight-math | 0.5.4, 0.5.5, 0.5.6, 0.5.7, 0.5.8 | | 10 | @squawk/flightplan | 0.5.2, 0.5.3, 0.5.4, 0.5.5, 0.5.6 | | 11 | @squawk/geo | 0.4.4, 0.4.5, 0.4.6, 0.4.7, 0.4.8 | | 12 | @squawk/icao-registry | 0.5.2, 0.5.3, 0.5.4, 0.5.5, 0.5.6 | | 13 | @squawk/icao-registry-data | 0.8.4, 0.8.5, 0.8.6, 0.8.7, 0.8.8 | | 14 | @squawk/mcp | 0.9.1, 0.9.2, 0.9.3, 0.9.4, 0.9.5 | | 15 | @squawk/navaid-data | 0.6.4, 0.6.5, 0.6.6, 0.6.7, 0.6.8 | | 16 | @squawk/navaids | 0.4.2, 0.4.3, 0.4.4, 0.4.5, 0.4.6 | | 17 | @squawk/notams | 0.3.6, 0.3.7, 0.3.8, 0.3.9, 0.3.10 | | 18 | @squawk/procedure-data | 0.7.3, 0.7.4, 0.7.5, 0.7.6, 0.7.7 | | 19 | @squawk/procedures | 0.5.2, 0.5.3, 0.5.4, 0.5.5, 0.5.6 | | 20 | @squawk/types | 0.8.1, 0.8.2, 0.8.3, 0.8.4, 0.8.5 | | 21 | @squawk/units | 0.4.3, 0.4.4, 0.4.5, 0.4.6, 0.4.7 | | 22 | @squawk/weather | 0.5.6, 0.5.7, 0.5.8, 0.5.9, 0.5.10 | | No matching rows | @tallyui npm | Package | Compromised Versions | | |---|---|---| | 1 | @tallyui/components | 1.0.1, 1.0.2, 1.0.3 | | 2 | @tallyui/connector-medusa | 1.0.1, 1.0.2, 1.0.3 | | 3 | @tallyui/connector-shopify | 1.0.1, 1.0.2, 1.0.3 | | 4 | @tallyui/connector-vendure | 1.0.1, 1.0.2, 1.0.3 | | 5 | @tallyui/connector-woocommerce | 1.0.1, 1.0.2, 1.0.3 | | 6 | @tallyui/core | 0.2.1, 0.2.2, 0.2.3 | | 7 | @tallyui/database | 1.0.1, 1.0.2, 1.0.3 | | 8 | @tallyui/pos | 0.1.1, 0.1.2, 0.1.3 | | 9 | @tallyui/storage-sqlite | 0.2.1, 0.2.2, 0.2.3 | | 10 | @tallyui/theme | 0.2.1, 0.2.2, 0.2.3 | | No matching rows | @beproduct npm | Package | Compromised Versions | | |---|---|---| | 1 | @beproduct/nestjs-auth | 0.1.2, 0.1.3, 0.1.4, 0.1.5, 0.1.6, 0.1.7, 0.1.8, 0.1.9, 0.1.10, 0.1.11, 0.1.12, 0.1.13, 0.1.14, 0.1.15, 0.1.16, 0.1.17, 0.1.18, 0.1.19 | | No matching rows | @draftauth / @draftlab npm | Package | Compromised Versions | | |---|---|---| | 1 | @draftauth/client | 0.2.1, 0.2.2 | | 2 | @draftauth/core | 0.13.1, 0.13.2 | | 3 | @draftlab/auth | 0.24.1, 0.24.2 | | 4 | @draftlab/auth-router | 0.5.1, 0.5.2 | | 5 | @draftlab/db | 0.16.1, 0.16.2 | | No matching rows | @supersurkhet npm | Package | Compromised Versions | | |---|---|---| | 1 | @supersurkhet/cli | 0.0.2, 0.0.3, 0.0.4, 0.0.5, 0.0.6, 0.0.7 | | 2 | @supersurkhet/sdk | 0.0.2, 0.0.3, 0.0.4, 0.0.5, 0.0.6, 0.0.7 | | No matching rows | @taskflow-corp npm | Package | Compromised Versions | | |---|---|---| | 1 | @taskflow-corp/cli | 0.1.24, 0.1.25, 0.1.26, 0.1.27, 0.1.28, 0.1.29 | | No matching rows | @tolka npm | Package | Compromised Versions | | |---|---|---| | 1 | @tolka/cli | 1.0.2, 1.0.3, 1.0.4, 1.0.5, 1.0.6 | | No matching rows | @mesadev npm | Package | Compromised Version | | |---|---|---| | 1 | @mesadev/rest | 0.28.3 | | 2 | @mesadev/saguaro | 0.4.22 | | 3 | @mesadev/sdk | 0.28.3 | | No matching rows | @ml-toolkit-ts npm | Package | Compromised Versions | | |---|---|---| | 1 | @ml-toolkit-ts/preprocessing | 1.0.2, 1.0.3 | | 2 | @ml-toolkit-ts/xgboost | 1.0.3, 1.0.4 | | No matching rows | @dirigible-ai npm | Package | Compromised Versions | | |---|---|---| | 1 | @dirigible-ai/sdk | 0.6.2, 0.6.3 | | No matching rows | @opensearch-project npm | Package | Compromised Versions | | |---|---|---| | 1 | @opensearch-project/opensearch | 3.5.3, 3.6.2, 3.7.0, 3.8.0 | | No matching rows | Unscoped npm Packages | Package | Compromised Versions | | |---|---|---| | 1 | agentwork-cli | 0.1.4, 0.1.5 | | 2 | cmux-agent-mcp | 0.1.3, 0.1.4, 0.1.5, 0.1.6, 0.1.7, 0.1.8 | | 3 | cross-stitch | 1.1.3, 1.1.4, 1.1.5, 1.1.6, 1.1.7 | | 4 | git-branch-selector | 1.3.3, 1.3.4, 1.3.5, 1.3.6, 1.3.7 | | 5 | git-git-git | 1.0.8, 1.0.9, 1.0.10, 1.0.11, 1.0.12 | | 6 | ml-toolkit-ts | 1.0.4, 1.0.5 | | 7 | nextmove-mcp | 0.1.3, 0.1.4, 0.1.5, 0.1.6, 0.1.7 | | 8 | safe-action | 0.8.3, 0.8.4 | | 9 | ts-dna | 3.0.1, 3.0.2, 3.0.3, 3.0.4, 3.0.5 | | 10 | wot-api | 0.8.1, 0.8.2, 0.8.3, 0.8.4 | | No matching rows | PyPI Packages The attack expanded beyond npm into the Python Package Index PyPI , hitting two high-profile packages. The guardrails-ai payload uses a different delivery mechanism: it downloads a secondary-stage payload from hxxps://git-tanstack . com/transformers . pyz and executes it with python3 . The git-tanstack . com domain displayed a message signed “With Love TeamPCP,” connecting this campaign to the group behind the March 2026 Trivy supply chain compromise /trivy-teampcp-supply-chain-compromise . | Package | Compromised Version | Ecosystem | | |---|---|---|---| | 1 | guardrails-ai | 0.10.1 | PyPI | | 2 | mistralai | 2.4.6 | PyPI | | No matching rows | - npm - pypi - oss - malware - supply-chain Author SafeDep Team safedep.io Share The Latest from SafeDep blogs Follow for the latest updates and insights on open source security & engineering Megalodon: Mass GitHub Repo Backdooring via CI Workflows /megalodon-mass-github-repo-backdooring-ci-workflows Over 5,700 malicious commits were pushed to GitHub repositories on May 18, 2026, replacing GitHub Actions workflows with base64-encoded secret exfiltration payloads. The "megalodon" campaign targeted... art-template npm Hijack Delivers iOS Browser Exploit Kit /art-template-npm-supply-chain-compromise art-template versions 4.13.3 through 4.13.6 were compromised via maintainer account takeover. The browser bundle injects scripts that deliver a full iOS exploit kit: WebAssembly type confusion, JIT... Polymarket npm Packages Steal Crypto Wallet Keys /malicious-polymarket-npm-crypto-wallet-drainer Nine coordinated npm packages target Polymarket traders with a social-engineered postinstall prompt that exfiltrates raw private keys to a Cloudflare Worker. The attacker published all packages... Malicious durabletask on PyPI: Multi-Cloud Credential Stealer with Worm Capabilities /malicious-durabletask-pypi-supply-chain-attack Three compromised versions of the Microsoft durabletask Python SDK 1.4.1, 1.4.2, 1.4.3 were published to PyPI, each downloading a stage-2 payload that steals credentials from AWS, Azure, GCP,... Ship Code. Not Malware. Start free with open source tools on your machine. Scale to a unified platform for your organization.