registry  /  peaks-loop  /  3.1.2

peaks-loop@3.1.2

Loop Engineering CLI — workflow primitive / loop guards / evaluators / slice orchestration

AI Security Review

scanned 4h ago · by lpm-firewall-ai

The package performs install-time mutation of broad AI-agent control surfaces in the user's home directory. This is lifecycle-triggered and not limited to a first-party app-owned namespace.

Static reason
High-risk behavior combination matched malicious policy.; source matched previously finalized malicious package; routed for review
Trigger
npm install/postinstall of peaks-loop@3.1.2
Impact
AI agents such as Claude, Codex, Cursor, Trae, Qoder, Tongyi Lingma, Hermes, and OpenClaw may load package-supplied prompts/skills after install without an explicit per-agent user action.
Mechanism
unconsented lifecycle installation of bundled AI skills, output styles, and agent prompts into foreign IDE/agent directories
Attack narrative
On npm postinstall, scripts/install-skills.mjs executes automatically. It creates or updates home-directory agent/IDE extension locations and plants bundled skills, output styles, and a Claude agent prompt, then may run a peaks auto-upgrade against detected projects. The behavior is product-aligned but mutates broad third-party AI-agent control surfaces during lifecycle install.
Rationale
Direct source inspection confirms unconsented lifecycle mutation of multiple foreign/broad AI-agent control surfaces, which the policy treats as blockable AI-agent control hijack even when the content is product-aligned. No exfiltration was found, but the install-time agent-surface write is sufficient for a malicious firewall verdict.
Evidence
package.jsonscripts/install-skills.mjsagents/karpathy-reviewer.mdoutput-styles/peaks-skill-swarm.mdskills/*/SKILL.md~/.claude/skills/*~/.claude/output-styles/*~/.claude/agents/karpathy-reviewer.md~/.codex/skills/*~/.codex/output-styles/*~/.cursor/skills/*~/.cursor/output-styles/*~/.trae/skills/*~/.trae/output-styles/*~/.qoder/skills/*~/.tongyi-lingma/skills/*~/.hermes/skills/*~/.openclaw/skills/*~/.peaks/config.json

Decision evidence

public snapshot
AI called this Malicious at 96.0% confidence as Dangerous Capability with low false-positive risk.
Evidence for block
  • package.json defines postinstall: node ./scripts/install-skills.mjs.
  • scripts/install-skills.mjs runs on lifecycle and iterates all IDE profiles, not only an explicit user-selected one.
  • installBundledSkillsForAllPlatforms symlinks bundled skills into ~/.claude, ~/.trae, ~/.codex, ~/.cursor, ~/.qoder, ~/.tongyi-lingma, ~/.hermes, and ~/.openclaw skills dirs.
  • installBundledAgentsForAllPlatforms copies package agent prompt agents/karpathy-reviewer.md into ~/.claude/agents by default.
  • Lifecycle also creates ~/.peaks/config.json with default provider/token structure and can spawn peaks upgrade --to 2.0 --auto for detected 1.x projects.
Evidence against
  • Installer has PEAKS_SKIP_* opt-out env vars and symlink/hardlink safety checks.
  • No credential harvesting or exfiltration endpoints found in inspected lifecycle path.
  • Bundled content is product-aligned workflow/agent instructions rather than an obfuscated payload.
  • Existing non-managed local skill/agent/output-style files are skipped rather than overwritten.
Behavioral surface
Source
ChildProcessCryptoDynamicRequireEnvironmentVarsFilesystemShell
Supply chain
HighEntropyStringsUrlStrings
ManifestNo manifest risk signals triggered.
scanned 457 file(s), 2.97 MB of source, external domains: api.anthropic.com, api.example.com, api.openai.com, github.com, gitlab.com, reactbits.dev, www.google.com, www.pulsemcp.com

Source & flagged code

12 flagged · loading source
package.jsonView file
scripts.postinstall = node ./scripts/install-skills.mjs
High
Install Time Lifecycle Scripts

Package defines install-time lifecycle scripts.

package.jsonView on unpkg
dist/src/shared/process.jsView file
1import { execFile } from 'node:child_process'; L2: export async function execCommand(command, args, options) {
High
Child Process

Package source references child process execution.

dist/src/shared/process.jsView on unpkg · L1
dist/src/services/upgrade/upgrade-service.jsView file
151// npm install postinstall creates `peaks` → `peaks.sh` on L152: // Windows). cmd.exe (the default Windows shell) cannot run L153: // `.sh` scripts directly, so the shim fails with "unknown
High
Shell

Package source references shell execution.

dist/src/services/upgrade/upgrade-service.jsView on unpkg · L151
dist/src/cli/commands/loop-eval-commands.jsView file
478// eslint-disable-next-line @typescript-eslint/no-var-requires L479: const fs = require('node:fs'); L480: let entries;
Medium
Dynamic Require

Package source references dynamic require/import behavior.

dist/src/cli/commands/loop-eval-commands.jsView on unpkg · L478
dist/src/services/solo/job-shape-decision.jsView file
92try { L93: parsed = JSON.parse(raw); L94: }
Low
Weak Crypto

Package source references weak cryptographic algorithms.

dist/src/services/solo/job-shape-decision.jsView on unpkg · L92
scripts/install-skills.mjsView file
1Install-time AI-agent control hijack evidence: L1: #!/usr/bin/env node L2: import { closeSync, constants, existsSync, fchmodSync, fstatSync, lstatSync, mkdirSync, openSync, readFileSync, readlinkSync, realpathSync, readdirSync, renameSync, symlinkSync, un... L3: import { spawnSync } from 'node:child_process'; ... L291: fchmodSync(fd, 0o600); L292: writeFileSync(fd, content, 'utf8'); L293: const writeFd = fd; ... L320: fchmodSync(fd, 0o600); L321: writeFileSync(fd, content, 'utf8'); L322: const writeFd = fd; ... L372: * cannot import the TS service at runtime. The dispatch: L373: * - Look for `.claude`, `.trae`, `.codex`, `.cursor`, `.qoder`, L374: * `.tongyi-lingma` in the project root in that insertion order Payload evidence from schemas/mcp-install-spec.schema.json: L1: { L2: "$schema": "https://json-schema.org/draft/2020-12/schema", L3: "title": "Peaks MCP Install Spec", ... L25: "items": { "type": "string" }, L26: "description": "Required env var names. Values are sourced from process.env at runtime and written as ${VAR} placeholders into settings.json." L27: }
Critical
Ai Agent Control Hijack

Install-time source drops package-supplied AI-agent/MCP control files or instructions.

scripts/install-skills.mjsView on unpkg · L1
dist/src/cli/commands/playwright-commands.jsView file
27* The CLI does NOT bundle `playwright-mcp`; it shells out to L28: * `npx playwright-mcp@latest` (G22 / NG3). peaks-loop is the lifecycle L29: * orchestrator, not the install medium. ... L31: import { createHash } from 'node:crypto'; L32: import { spawn } from 'node:child_process'; L33: import { existsSync, mkdirSync, readFileSync, writeFileSync, readdirSync, unlinkSync } from 'node:fs';
High
Runtime Package Install

Package source invokes a package manager install command at runtime.

dist/src/cli/commands/playwright-commands.jsView on unpkg · L27
matchType = normalized_sha256 matchedPackage = peaks-loop@3.1.1 matchedPath = [redacted]-commands.js matchedIdentity = npm:cGVha3MtbG9vcA:3.1.1 similarity = 1.000 summary = normalized source hash matched finalized malicious source
High
Known Malware Source Similarity

Source file is highly similar to a previously finalized malicious package; route for source-aware review.

dist/src/cli/commands/playwright-commands.jsView on unpkg
dist/src/services/code-review/ocr-service.jsView file
matchType = normalized_sha256 matchedPackage = peaks-loop@3.1.1 matchedPath = dist/src/services/code-review/ocr-service.js matchedIdentity = npm:cGVha3MtbG9vcA:3.1.1 similarity = 1.000 summary = normalized source hash matched finalized malicious source
High
Known Malware Source Similarity

Source file is highly similar to a previously finalized malicious package; route for source-aware review.

dist/src/services/code-review/ocr-service.jsView on unpkg
dist/src/services/artifacts/artifact-service.jsView file
matchType = normalized_sha256 matchedPackage = peaks-loop@3.1.1 matchedPath = [redacted]-service.js matchedIdentity = npm:cGVha3MtbG9vcA:3.1.1 similarity = 1.000 summary = normalized source hash matched finalized malicious source
High
Known Malware Source Similarity

Source file is highly similar to a previously finalized malicious package; route for source-aware review.

dist/src/services/artifacts/artifact-service.jsView on unpkg
dist/src/services/workspace/migrate-service.jsView file
matchType = normalized_sha256 matchedPackage = peaks-loop@3.1.1 matchedPath = [redacted]-service.js matchedIdentity = npm:cGVha3MtbG9vcA:3.1.1 similarity = 1.000 summary = normalized source hash matched finalized malicious source
High
Known Malware Source Similarity

Source file is highly similar to a previously finalized malicious package; route for source-aware review.

dist/src/services/workspace/migrate-service.jsView on unpkg
dist/src/cli/commands/session-auto-compact-hook-command.jsView file
matchType = normalized_sha256 matchedPackage = peaks-loop@3.1.1 matchedPath = dist/src/cli/commands/session-auto-compact-hook-command.js matchedIdentity = npm:cGVha3MtbG9vcA:3.1.1 similarity = 1.000 summary = normalized source hash matched finalized malicious source
High
Known Malware Source Similarity

Source file is highly similar to a previously finalized malicious package; route for source-aware review.

dist/src/cli/commands/session-auto-compact-hook-command.jsView on unpkg

Findings

1 Critical9 High3 Medium6 Low
CriticalAi Agent Control Hijackscripts/install-skills.mjs
HighInstall Time Lifecycle Scriptspackage.json
HighChild Processdist/src/shared/process.js
HighShelldist/src/services/upgrade/upgrade-service.js
HighRuntime Package Installdist/src/cli/commands/playwright-commands.js
HighKnown Malware Source Similaritydist/src/cli/commands/playwright-commands.js
HighKnown Malware Source Similaritydist/src/services/code-review/ocr-service.js
HighKnown Malware Source Similaritydist/src/services/artifacts/artifact-service.js
HighKnown Malware Source Similaritydist/src/services/workspace/migrate-service.js
HighKnown Malware Source Similaritydist/src/cli/commands/session-auto-compact-hook-command.js
MediumDynamic Requiredist/src/cli/commands/loop-eval-commands.js
MediumEnvironment Vars
MediumStructural Risk Force Deep Review
LowNon Install Lifecycle Scripts
LowScripts Present
LowWeak Cryptodist/src/services/solo/job-shape-decision.js
LowFilesystem
LowHigh Entropy Strings
LowUrl Strings