New Research: Supply Chain Attack on Axios Pulls Malicious Dependency from npm.Details →
Socket
Book a DemoSign in
Socket

@framework-doctor/angular

Package Overview
Dependencies
Maintainers
1
Versions
3
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@framework-doctor/angular

Diagnose Angular codebase health

latest
Source
npmnpm
Version
1.1.1
Version published
Maintainers
1
Created
Source

Angular Doctor

version downloads

Diagnose and improve your Angular codebase health.

One command scans your codebase for security, performance, correctness, and dead code issues, then outputs a 0–100 score with actionable diagnostics.

Install

Run at your project root:

npx -y @framework-doctor/angular .

Or use the unified CLI (auto-detects Angular):

npx -y @framework-doctor/cli .

Options

Usage: angular-doctor [directory] [options]

Options:
  -v, --version       display the version number
  --no-lint           skip linting
  --no-dead-code      skip dead code detection
  --no-audit          skip dependency vulnerability audit
  --format <format>   output format: text or json
  --verbose           show file details per rule
  --score             output only the score (CI-friendly)
  -y, --yes           skip prompts, scan all workspace projects
  --no-analytics      disable anonymous analytics
  --project <name>    select workspace project (comma-separated for multiple)
  --diff [base]       scan only files changed vs base branch
  --offline           skip remote scoring (local score only)
  -h, --help          display help for command

Configuration

Create angular-doctor.config.json:

{
  "ignore": {
    "rules": ["angular-doctor/no-eval", "angular-doctor/no-inner-html-binding"],
    "files": ["src/generated/**"]
  },
  "lint": true,
  "deadCode": true,
  "audit": true,
  "verbose": false,
  "diff": false,
  "analytics": true
}

Or use the angularDoctor key in package.json:

{
  "angularDoctor": {
    "deadCode": true,
    "ignore": { "rules": ["angular-doctor/no-eval"] }
  }
}

Angular Doctor also supports unified config via framework-doctor.config.json with an angularDoctor section. Framework-specific config overrides unified options.

Checks

Angular Doctor runs:

  • ESLint — angular-eslint with recommended rules
  • Knip — Dead code detection
  • Security — eval, new Function, implied eval, innerHTML, bypassSecurityTrust*
  • checkReducedMotion — Accessibility (WCAG 2.3.3) when motion libraries are used
  • Dependency audit — High/critical vulnerabilities via pnpm audit (use --no-audit to skip)

Security checks

Angular Doctor flags:

  • eval() — Code injection risk
  • new Function() — Code injection risk
  • setTimeout("string") / setInterval("string") — Implied eval
  • innerHTML binding — Raw HTML can lead to XSS if content is unsanitized
  • bypassSecurityTrust* — Bypassing Angular’s sanitizer can lead to XSS

Analytics

Angular Doctor optionally sends anonymous usage data when you opt in. Data is sent to your Supabase Edge Function (see supabase/README.md) when FRAMEWORK_DOCTOR_TELEMETRY_URL is configured. If your function enforces TELEMETRY_KEY, set FRAMEWORK_DOCTOR_TELEMETRY_KEY in the client environment. Limited to framework type, score range, diagnostic count. No code or paths are collected.

  • Opt-in: On first run (when analytics is configured), you’ll be prompted. Your choice is stored in ~/.framework-doctor/config.json.
  • Disable: Use --no-analytics, set "analytics": false in config, or DO_NOT_TRACK=1.
  • Skipped automatically: CI and other non-interactive environments (e.g. Cursor Agent, Claude Code).

Contributing

git clone https://github.com/pitis/framework-doctor
cd framework-doctor
pnpm install
pnpm build

Run locally:

pnpm exec angular-doctor /path/to/your/angular-project
# or directly:
node packages/angular-doctor/dist/cli.js /path/to/your/angular-project

Keywords

diagnostics

FAQs

Package last updated on 05 Mar 2026

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts