CacheLint

Caching anti-pattern analyzer -- detects Redis/Memcached misuse, TTL problems, cache invalidation failures, stampedes, architecture issues, and security hygiene gaps in application-level caching

Safety Notice

This listing is from the official public ClawHub registry. Review SKILL.md and referenced scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "CacheLint" with this command: npx skills add suhteevah/cachelint

CacheLint -- Caching Anti-Pattern Analyzer

CacheLint scans codebases for application-level caching anti-patterns: Redis/Memcached misuse, missing cache invalidation after writes, TTL problems, cache stampede risks, architecture issues, and security hygiene gaps. It uses regex-based pattern matching against 90 caching-specific patterns across 6 categories, lefthook for git hook integration, and produces markdown reports with actionable remediation guidance. 100% local. Zero telemetry.

Note: CacheLint focuses on application-level caching (Redis calls, Memcached operations, local cache usage, invalidation logic, TTL management). It does NOT analyze HTTP cache headers.

Commands

Free Tier (No license required)

cachelint scan [file|directory]

One-shot caching quality scan of files or directories.

How to execute:

bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [target]

What it does:

  1. Accepts a file path or directory (defaults to current directory)
  2. Discovers all source files (skips .git, node_modules, binaries, images, .min.js)
  3. Runs 30 caching patterns against each file (free tier limit)
  4. Calculates a caching quality score (0-100) per file and overall
  5. Grades: A (90-100), B (80-89), C (70-79), D (60-69), F (<60)
  6. Outputs findings with: file, line number, check ID, severity, description, recommendation
  7. Exit code 0 if score >= 70, exit code 1 if caching quality is poor
  8. Free tier limited to first 30 patterns (CI + TE categories)

Example usage scenarios:

  • "Scan my code for caching issues" -> runs cachelint scan .
  • "Check this file for cache anti-patterns" -> runs cachelint scan src/cache-service.ts
  • "Find missing cache invalidation" -> runs cachelint scan src/
  • "Audit cache TTL settings" -> runs cachelint scan .
  • "Check for Redis misuse" -> runs cachelint scan .

Pro Tier ($19/user/month -- requires CACHELINT_LICENSE_KEY)

cachelint scan --tier pro [file|directory]

Extended scan with 60 patterns covering invalidation, TTL, stampede, and Redis misuse.

How to execute:

bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [target] --tier pro

What it does:

  1. Validates Pro+ license
  2. Runs 60 caching patterns (CI, TE, CS, RM categories)
  3. Detects cache stampede risks and Redis anti-patterns
  4. Identifies KEYS * usage, missing pipelines, unbounded lists
  5. Full category breakdown reporting

cachelint scan --format json [directory]

Generate JSON output for CI/CD integration.

bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [directory] --format json

cachelint scan --format html [directory]

Generate HTML report for browser viewing.

bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [directory] --format html

cachelint scan --category CS [directory]

Filter scan to a specific check category (CI, TE, CS, RM, CA, SH).

bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [directory] --category CS

Team Tier ($39/user/month -- requires CACHELINT_LICENSE_KEY with team tier)

cachelint scan --tier team [directory]

Full scan with all 90 patterns across all 6 categories including architecture and security.

How to execute:

bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [directory] --tier team

What it does:

  1. Validates Team+ license
  2. Runs all 90 patterns across 6 categories
  3. Includes cache architecture checks (N+1 gets, mixed strategies, no abstraction)
  4. Includes security & hygiene (PII in keys, missing TLS, no encryption)
  5. Full category breakdown with per-file results

cachelint scan --verbose [directory]

Verbose output showing every matched line and pattern details.

bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [directory] --verbose

cachelint status

Show license and configuration information.

bash "<SKILL_DIR>/scripts/dispatcher.sh" status

Check Categories

CacheLint detects 90 caching anti-patterns across 6 categories:

CategoryCodePatternsDescriptionSeverity Range
Cache InvalidationCI15Missing invalidation after writes, stale data, wrong write orderingmedium -- critical
TTL & ExpiryTE15Missing TTL, infinite cache, no jitter, hardcoded magic numberslow -- high
Cache StampedeCS15No lock on miss, thundering herd, missing singleflight, no stale-while-revalidatelow -- critical
Redis/Store MisuseRM15KEYS *, FLUSHALL, no pipeline, missing pooling, synchronous callslow -- critical
Cache ArchitectureCA15N+1 gets, no abstraction, mixed strategies, no error fallbacklow -- high
Security & HygieneSH15PII in keys, no TLS, missing encryption, no monitoring, key injectionlow -- critical

Tier-Based Pattern Access

TierPatternsCategories
Free30CI, TE
Pro60CI, TE, CS, RM
Team90CI, TE, CS, RM, CA, SH
Enterprise90CI, TE, CS, RM, CA, SH + priority support

Scoring

CacheLint uses a deductive scoring system starting at 100 (perfect):

SeverityPoint DeductionDescription
Critical-25 per findingSevere risk (stampede, KEYS *, FLUSHALL, wrong write order)
High-15 per findingSignificant problem (missing invalidation, no TTL, N+1 gets)
Medium-8 per findingModerate concern (no jitter, missing pooling, mixed strategies)
Low-3 per findingInformational / best practice suggestion

Grading Scale

GradeScore RangeMeaning
A90-100Excellent caching quality
B80-89Good caching with minor issues
C70-79Acceptable but needs improvement
D60-69Poor caching quality
FBelow 60Critical caching problems
  • Pass threshold: 70 (Grade C or better)
  • Exit code 0 = pass (score >= 70)
  • Exit code 1 = fail (score < 70)

Configuration

Users can configure CacheLint in ~/.openclaw/openclaw.json:

{
  "skills": {
    "entries": {
      "cachelint": {
        "enabled": true,
        "apiKey": "YOUR_LICENSE_KEY_HERE",
        "config": {
          "severityThreshold": "medium",
          "ignorePatterns": ["**/test/**", "**/fixtures/**", "**/*.test.*"],
          "ignoreChecks": [],
          "reportFormat": "text"
        }
      }
    }
  }
}

Important Notes

  • Free tier works immediately with no configuration
  • All scanning happens locally -- no code is sent to external servers
  • License validation is offline -- no phone-home or network calls
  • Pattern matching only -- no AST parsing, no external dependencies beyond bash
  • Supports scanning all file types in a single pass
  • Git hooks use lefthook which must be installed (see install metadata above)
  • Exit codes: 0 = pass (score >= 70), 1 = fail (for CI/CD integration)
  • Output formats: text (default), json, html

Error Handling

  • If lefthook is not installed and user tries hooks, prompt to install it
  • If license key is invalid or expired, show clear message with link to https://cachelint.pages.dev/renew
  • If a file is binary, skip it automatically with no warning
  • If no scannable files found in target, report clean scan with info message
  • If an invalid category is specified with --category, show available categories

When to Use CacheLint

The user might say things like:

  • "Scan my code for caching issues"
  • "Check my cache invalidation logic"
  • "Find missing TTL on cache entries"
  • "Detect cache stampede risks"
  • "Are there any Redis anti-patterns?"
  • "Check for KEYS * usage in production code"
  • "Audit my caching architecture"
  • "Find security issues in cache usage"
  • "Check for PII in cache keys"
  • "Scan for missing cache invalidation"
  • "Run a caching quality audit"
  • "Generate a cache health report"
  • "Check if my Redis calls use pipelines"
  • "Find N+1 cache get patterns"
  • "Check my code for cache stampede vulnerabilities"

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Security

Component Library Audit

Audit React, Vue, or Svelte component libraries — find unused components, inconsistent props, missing documentation, accessibility issues, missing tests, and...

Registry SourceRecently Updated
Security

Repository Health Score

Score a repository's health across 8 dimensions — code quality, testing, documentation, CI/CD, security, dependencies, community, and maintainability. Produc...

Registry SourceRecently Updated
270Profile unavailable
Security

个人数字安全体检

检查邮箱泄露和密码强度,生成安全评分报告。

Registry SourceRecently Updated
1760Profile unavailable
Security

agent-bom registry

MCP server security registry and trust assessment — look up servers in the 427+ server security metadata registry, run pre-install marketplace checks, batch...

Registry SourceRecently Updated
7180Profile unavailable