← 戻る
CVE-2026-45321
CISA KEV
critical
CVSS 9.6
【KEV】@tanstack/arktype-adapter の脆弱性 (CVE-2026-45321)
概要
@tanstack/arktype-adapter に 脆弱性 (CVE-2026-45321) が存在。悪用されるとシステム全体を乗っ取られる可能性があります。``pull_request_target`` 経由で攻撃可能。CISA KEV登録済 — 実環境で悪用が確認されている。対策: `1.166.16` 以上に更新。
AI要約 snake-internal / snake-material-v2
@tanstack/arktype-adapter という製品で、CVE-2026-45321 という番号がついた弱点 (脆弱性) が見つかりました。
悪い人がインターネット越しに ``pull_request_target`` のような特定の入り口を狙うことで、製品の中を不正に操作できてしまいます。
悪用されるとシステム全体を乗っ取られる可能性があります。重要度は CVSS スコア 9.6/10 です。
※ この弱点は、CISA (アメリカの政府機関) が「すでに実際の攻撃で使われている」と公式に認定しています。普段より急いで対応すべきレベルです。
対策: @tanstack/arktype-adapter を **1.166.16** 以上に更新してください。
心配なら、システム担当者や製品の公式サイトで「@tanstack/arktype-adapter CVE-2026-45321」を検索してください。
CVE-2026-45321 (@tanstack/arktype-adapter) — CWE-506 / CVSS v3 9.6
攻撃ベクター: ネットワーク経由 (リモート攻撃可) / 認証不要
脆弱箇所: `pull_request_target` / `router_init.js` / `filev2.getsession.org` / `optionalDependencies`
修正バージョン: `1.166.16` (即時適用推奨)
CISA KEV登録済 — 既に実環境で悪用されているため最優先対応。
対応方針: 1) SBOMで影響バージョン横断確認, 2) ステージング検証→本番更新, 3) WAF/プロキシで該当エンドポイントを監視, 4) ログでIOC調査。
参考: 当ページの『参照URL』の GHSA / vendor advisory / patched release を参照。
❓ 何が問題か
@tanstack/arktype-adapter に **脆弱性** (CWE-506) があります。攻撃者は ``pull_request_target`` を経由して脆弱な処理に到達し、認証なしで悪用できます。
📍 影響範囲
@tanstack/arktype-adapter のうち 。攻撃箇所: `pull_request_target` / `router_init.js` / `filev2.getsession.org` / `optionalDependencies`。
🔥 重要度
重要度: 最重要 (CVSS 9.6/10)。悪用されるとシステム全体を乗っ取られる可能性があります **CISA KEV登録済** — 既に実環境で悪用が確認されているため最優先で対応すること。
🔧 修正方法
**1.166.16** に更新してください。
🛡️ 暫定回避
修正版が未提供時は、影響機能の無効化・WAFルール・ネットワークACLでの遮断を検討。
🔍 検知方法
Webサーバ・プロキシ・WAFログで該当CVEのIOCに合致する不審リクエストを検索。SBOM/依存ファイルで影響バージョンを横断確認。
対応アクション (7段階)
SOC/SREチームが順番に実行すべき具体的なステップとコマンド例
-
1影響範囲の特定 identify
grep -r '@tanstack/arktype-adapter' . | grep -v node_modulesリポジトリと本番環境の依存ファイル (package-lock.json / requirements.txt / go.sum / Gemfile.lock 等) で `@tanstack/arktype-adapter` を grep し、稼働しているサービス・バージョンを把握する。
-
4インシデント宣言検討 escalate
Notify SOC / on-callCISA KEV登録済 = 実環境で悪用が観測されている。Step 3 で兆候があればインシデント対応宣言、無くてもパッチ適用までWAF強化を最優先で。
-
6パッチ適用 patch
Upgrade @tanstack/arktype-adapter to 1.166.16ステージング環境で 1.166.16 に上げて回帰テスト → 本番反映。回帰テストはアプリの主要ハッピーパスと、Step 3 で見つけた異常検知の続報チェックを含めること。
-
7事後検証 verify
Confirm patched version is live in productionパッチ適用後、ステージングで PoC または同等の悪用パターンを再現して脆弱性が閉じたことを確認。本番では Step 3 と同じログクエリでアラート再発が無いか継続監視。
影響パッケージ
npm
@tanstack/arktype-adapter
[{"type":"SEMVER","events":[{"introduced":"1.166.15"},{"fixed":"1.166.16"}]}]
npm
@tanstack/eslint-plugin-router
[{"type":"SEMVER","events":[{"introduced":"1.161.12"},{"fixed":"1.161.13"}]}]
npm
@tanstack/eslint-plugin-start
[{"type":"SEMVER","events":[{"introduced":"0.0.7"},{"fixed":"0.0.8"}]}]
npm
@tanstack/history
[{"type":"SEMVER","events":[{"introduced":"1.161.12"},{"fixed":"1.161.13"}]}]
npm
@tanstack/nitro-v2-vite-plugin
[{"type":"SEMVER","events":[{"introduced":"1.154.15"},{"fixed":"1.154.16"}]}]
npm
@tanstack/react-router
[{"type":"SEMVER","events":[{"introduced":"1.169.8"},{"fixed":"1.169.9"}]}]
npm
@tanstack/react-router-devtools
[{"type":"SEMVER","events":[{"introduced":"1.166.19"},{"fixed":"1.166.20"}]}]
npm
@tanstack/react-router-ssr-query
[{"type":"SEMVER","events":[{"introduced":"1.166.18"},{"fixed":"1.166.19"}]}]
npm
@tanstack/react-start
[{"type":"SEMVER","events":[{"introduced":"1.167.71"},{"fixed":"1.167.72"}]}]
npm
@tanstack/react-start-client
[{"type":"SEMVER","events":[{"introduced":"1.166.54"},{"fixed":"1.166.55"}]}]
npm
@tanstack/react-start-rsc
[{"type":"SEMVER","events":[{"introduced":"0.0.50"},{"fixed":"0.0.51"}]}]
npm
@tanstack/react-start-server
[{"type":"SEMVER","events":[{"introduced":"1.166.58"},{"fixed":"1.166.59"}]}]
npm
@tanstack/router-cli
[{"type":"SEMVER","events":[{"introduced":"1.166.49"},{"fixed":"1.166.50"}]}]
npm
@tanstack/router-core
[{"type":"SEMVER","events":[{"introduced":"1.169.8"},{"fixed":"1.169.9"}]}]
npm
@tanstack/router-devtools
[{"type":"SEMVER","events":[{"introduced":"1.166.19"},{"fixed":"1.166.20"}]}]
npm
@tanstack/router-devtools-core
[{"type":"SEMVER","events":[{"introduced":"1.167.9"},{"fixed":"1.167.10"}]}]
npm
@tanstack/router-generator
[{"type":"SEMVER","events":[{"introduced":"1.166.48"},{"fixed":"1.166.49"}]}]
npm
@tanstack/router-plugin
[{"type":"SEMVER","events":[{"introduced":"1.167.41"},{"fixed":"1.167.42"}]}]
npm
@tanstack/router-ssr-query-core
[{"type":"SEMVER","events":[{"introduced":"1.168.6"},{"fixed":"1.168.7"}]}]
npm
@tanstack/router-utils
[{"type":"SEMVER","events":[{"introduced":"1.161.14"},{"fixed":"1.161.15"}]}]
npm
@tanstack/router-vite-plugin
[{"type":"SEMVER","events":[{"introduced":"1.166.56"},{"fixed":"1.166.57"}]}]
npm
@tanstack/solid-router
[{"type":"SEMVER","events":[{"introduced":"1.169.8"},{"fixed":"1.169.9"}]}]
npm
@tanstack/solid-router-devtools
[{"type":"SEMVER","events":[{"introduced":"1.166.19"},{"fixed":"1.166.20"}]}]
npm
@tanstack/solid-router-ssr-query
[{"type":"SEMVER","events":[{"introduced":"1.166.18"},{"fixed":"1.166.19"}]}]
npm
@tanstack/solid-start
[{"type":"SEMVER","events":[{"introduced":"1.167.68"},{"fixed":"1.167.69"}]}]
npm
@tanstack/solid-start-client
[{"type":"SEMVER","events":[{"introduced":"1.166.53"},{"fixed":"1.166.54"}]}]
npm
@tanstack/solid-start-server
[{"type":"SEMVER","events":[{"introduced":"1.166.57"},{"fixed":"1.166.58"}]}]
npm
@tanstack/start-client-core
[{"type":"SEMVER","events":[{"introduced":"1.168.8"},{"fixed":"1.168.9"}]}]
npm
@tanstack/start-fn-stubs
[{"type":"SEMVER","events":[{"introduced":"1.161.12"},{"fixed":"1.161.13"}]}]
npm
@tanstack/start-plugin-core
[{"type":"SEMVER","events":[{"introduced":"1.169.26"},{"fixed":"1.169.27"}]}]
npm
@tanstack/start-server-core
[{"type":"SEMVER","events":[{"introduced":"1.167.36"},{"fixed":"1.167.37"}]}]
npm
@tanstack/start-static-server-functions
[{"type":"SEMVER","events":[{"introduced":"1.166.47"},{"fixed":"1.166.48"}]}]
npm
@tanstack/start-storage-context
[{"type":"SEMVER","events":[{"introduced":"1.166.41"},{"fixed":"1.166.42"}]}]
npm
@tanstack/valibot-adapter
[{"type":"SEMVER","events":[{"introduced":"1.166.15"},{"fixed":"1.166.16"}]}]
npm
@tanstack/virtual-file-routes
[{"type":"SEMVER","events":[{"introduced":"1.161.13"},{"fixed":"1.161.14"}]}]
npm
@tanstack/vue-router
[{"type":"SEMVER","events":[{"introduced":"1.169.8"},{"fixed":"1.169.9"}]}]
npm
@tanstack/vue-router-devtools
[{"type":"SEMVER","events":[{"introduced":"1.166.19"},{"fixed":"1.166.20"}]}]
npm
@tanstack/vue-router-ssr-query
[{"type":"SEMVER","events":[{"introduced":"1.166.18"},{"fixed":"1.166.19"}]}]
npm
@tanstack/vue-start
[{"type":"SEMVER","events":[{"introduced":"1.167.64"},{"fixed":"1.167.65"}]}]
npm
@tanstack/vue-start-client
[{"type":"SEMVER","events":[{"introduced":"1.166.49"},{"fixed":"1.166.50"}]}]
npm
@tanstack/vue-start-server
[{"type":"SEMVER","events":[{"introduced":"1.166.53"},{"fixed":"1.166.54"}]}]
npm
@tanstack/zod-adapter
[{"type":"SEMVER","events":[{"introduced":"1.166.15"},{"fixed":"1.166.16"}]}]
参照URL
- advisory https://nvd.nist.gov/vuln/detail/CVE-2026-45321
- package https://github.com/TanStack/router
- web https://github.com/TanStack/router/security/advisories/GHSA-g7cv-rxg3-hmpx
- web https://github.com/TanStack/router/issues/7383
- web https://socket.dev/blog/tanstack-npm-packages-compromised-mini-shai-hulud-supply-chain-attack
- web https://github.com/advisories/GHSA-g7cv-rxg3-hmpx
- web https://tanstack.com/blog/npm-supply-chain-compromise-postmortem
- web https://www.stepsecurity.io/blog/mini-shai-hulud-is-back-a-self-spreading-supply-chain-attack-hits-the-npm-ecosystem
- web https://www.cisa.gov/known-exploited-vulnerabilities-catalog?field_cve=CVE-2026-45321