# Mass Supply Chain Attack Hits TanStack, Mistral AI npm and PyPI Packages

> Source: <https://safedep.io/mass-npm-supply-chain-attack-tanstack-mistral>
> Published: 2026-05-12 06:00:00+00:00

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