Skip to main content
ESLint Interlace
Plugin: lambda-securityRules

no-overly-permissive-iam-policy

Security rule for lambda-security. This rule is part of eslint-plugin-lambda-security and provides LLM-optimized error messages.

Keywords: lambda-security, security, ESLint rule, LLM-optimized

This rule is part of eslint-plugin-lambda-security.

Quick Summary

AspectDetails
SeverityWarning (security)
Auto-Fix❌ No auto-fix
CategorySecurity
ESLint MCP✅ Optimized for ESLint MCP integration

Value & investment case

Why this rule pays for itself. Framework: cicd-impact/philosophy.md.

DimensionValue
CWECWE-732 — Incorrect Permission Assignment for Critical Resource (over-permissioned IAM policies)
Feedback-loop tierEditor / pre-commit (sub-second) — cheapest layer per the feedback-loop hierarchy
Defensive-layer leverage~10× cheaper than unit-test · ~1,000× cheaper than production rollback · 10,000+× cheaper than customer disclosure (cost-ratio anchors)
Niche relevanceCritical: infra/devtools, fintech (cloud-resource isolation), cybersecurity, healthtech (HIPAA cloud controls) · High: B2B SaaS · Medium: B2C
Investor-frame impactWildcard or over-broad IAM policies (Action: "*", Resource: "*") → privilege escalation if any single function compromised → blast radius extends across the entire AWS account. Lint-time enforcement of least-privilege is AWS Well-Architected Framework Pillar 1 (Security) evidence and a SOC2/HIPAA cloud-control finding-prevention.

Read also: philosophy.md §investor-frame · niche-presets.json · analyzer-evaluation-framework.md

Rule Details

This rule helps enforce secure coding practices for lambda-security applications.

Examples

❌ Incorrect

// Wildcard Resource grants access to every resource in the account
const policy = {
  Effect: 'Allow',
  Action: 's3:GetObject',
  Resource: '*',
};

✅ Correct

// Scope Resource to the specific bucket and key prefix required
const policy = {
  Effect: 'Allow',
  Action: 's3:GetObject',
  Resource: 'arn:aws:s3:::my-bucket/uploads/*',
};

Configuration

{
  rules: {
    'lambda-security/no-overly-permissive-iam-policy': 'warn'
  }
}