Install
openclaw skills install cachelintCaching anti-pattern analyzer -- detects Redis/Memcached misuse, TTL problems, cache invalidation failures, stampedes, architecture issues, and security hygiene gaps in application-level caching
openclaw skills install cachelintCacheLint 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.
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:
Example usage scenarios:
cachelint scan .cachelint scan src/cache-service.tscachelint scan src/cachelint scan .cachelint scan .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:
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
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:
cachelint scan --verbose [directory]Verbose output showing every matched line and pattern details.
bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [directory] --verbose
cachelint statusShow license and configuration information.
bash "<SKILL_DIR>/scripts/dispatcher.sh" status
CacheLint detects 90 caching anti-patterns across 6 categories:
| Category | Code | Patterns | Description | Severity Range |
|---|---|---|---|---|
| Cache Invalidation | CI | 15 | Missing invalidation after writes, stale data, wrong write ordering | medium -- critical |
| TTL & Expiry | TE | 15 | Missing TTL, infinite cache, no jitter, hardcoded magic numbers | low -- high |
| Cache Stampede | CS | 15 | No lock on miss, thundering herd, missing singleflight, no stale-while-revalidate | low -- critical |
| Redis/Store Misuse | RM | 15 | KEYS *, FLUSHALL, no pipeline, missing pooling, synchronous calls | low -- critical |
| Cache Architecture | CA | 15 | N+1 gets, no abstraction, mixed strategies, no error fallback | low -- high |
| Security & Hygiene | SH | 15 | PII in keys, no TLS, missing encryption, no monitoring, key injection | low -- critical |
| Tier | Patterns | Categories |
|---|---|---|
| Free | 30 | CI, TE |
| Pro | 60 | CI, TE, CS, RM |
| Team | 90 | CI, TE, CS, RM, CA, SH |
| Enterprise | 90 | CI, TE, CS, RM, CA, SH + priority support |
CacheLint uses a deductive scoring system starting at 100 (perfect):
| Severity | Point Deduction | Description |
|---|---|---|
| Critical | -25 per finding | Severe risk (stampede, KEYS *, FLUSHALL, wrong write order) |
| High | -15 per finding | Significant problem (missing invalidation, no TTL, N+1 gets) |
| Medium | -8 per finding | Moderate concern (no jitter, missing pooling, mixed strategies) |
| Low | -3 per finding | Informational / best practice suggestion |
| Grade | Score Range | Meaning |
|---|---|---|
| A | 90-100 | Excellent caching quality |
| B | 80-89 | Good caching with minor issues |
| C | 70-79 | Acceptable but needs improvement |
| D | 60-69 | Poor caching quality |
| F | Below 60 | Critical caching problems |
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"
}
}
}
}
}
The user might say things like: