Install
openclaw skills install cryptolintCryptography misuse & weak algorithm detector -- detects deprecated algorithms, hardcoded keys/IVs, ECB mode, weak random number generation, timing-vulnerable comparisons, and insecure TLS configuration
openclaw skills install cryptolintCryptoLint scans codebases for cryptographic anti-patterns, deprecated algorithms (MD5, SHA-1, DES, RC4), hardcoded keys and IVs, insecure encryption modes (ECB), weak random number generation, timing-vulnerable comparisons, and insecure TLS/SSL configuration. It uses regex-based pattern matching against 90 cryptography-specific patterns across 6 categories, lefthook for git hook integration, and produces markdown reports with actionable remediation guidance. 100% local. Zero telemetry.
cryptolint scan [file|directory]One-shot cryptography quality scan of files or directories.
How to execute:
bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [target]
What it does:
Example usage scenarios:
cryptolint scan .cryptolint scan src/crypto.tscryptolint scan src/cryptolint scan .cryptolint scan .cryptolint scan --tier pro [file|directory]Extended scan with 60 patterns covering weak algorithms, key management, encryption modes, and random number generation.
How to execute:
bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [target] --tier pro
What it does:
cryptolint scan --format json [directory]Generate JSON output for CI/CD integration.
bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [directory] --format json
cryptolint scan --format html [directory]Generate HTML report for browser viewing.
bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [directory] --format html
cryptolint scan --category WA [directory]Filter scan to a specific check category (WA, KM, EM, RN, TC, CP).
bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [directory] --category WA
cryptolint scan --tier team [directory]Full scan with all 90 patterns across all 6 categories including timing attacks and certificate/protocol checks.
How to execute:
bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [directory] --tier team
What it does:
cryptolint scan --verbose [directory]Verbose output showing every matched line and pattern details.
bash "<SKILL_DIR>/scripts/dispatcher.sh" --path [directory] --verbose
cryptolint statusShow license and configuration information.
bash "<SKILL_DIR>/scripts/dispatcher.sh" status
CryptoLint detects 90 cryptographic anti-patterns across 6 categories:
| Category | Code | Patterns | Description | Severity Range |
|---|---|---|---|---|
| Weak Algorithms | WA | 15 | MD5, SHA-1, DES, 3DES, RC4, Blowfish, weak PBKDF2 iterations, deprecated TLS versions | high -- critical |
| Key Management | KM | 15 | Hardcoded encryption keys, static IVs/salts, short keys, keys in source code, zero IVs | high -- critical |
| Encryption Modes | EM | 15 | ECB mode, CBC without authentication, raw RSA without padding, deprecated createCipher | medium -- critical |
| Random Number Generation | RN | 15 | Math.random() for security, java.util.Random for crypto, time-seeded RNG, predictable seeds | high -- critical |
| Timing & Comparison | TC | 15 | String equality for hashes, == for HMAC, non-constant-time comparisons, early-return timing leaks | medium -- high |
| Certificate & Protocol | CP | 15 | SSL/TLS verification disabled, hostname check bypassed, insecure protocol versions, HTTP in auth | high -- critical |
| Tier | Patterns | Categories |
|---|---|---|
| Free | 30 | WA, KM |
| Pro | 60 | WA, KM, EM, RN |
| Team | 90 | WA, KM, EM, RN, TC, CP |
| Enterprise | 90 | WA, KM, EM, RN, TC, CP + priority support |
CryptoLint uses a deductive scoring system starting at 100 (perfect):
| Severity | Point Deduction | Description |
|---|---|---|
| Critical | -25 per finding | Broken algorithm or direct cryptographic vulnerability |
| High | -15 per finding | Significant cryptographic weakness (deprecated algo, weak key) |
| Medium | -8 per finding | Suboptimal practice (CBC without auth, weak mode choice) |
| Low | -3 per finding | Informational / best practice suggestion |
| Grade | Score Range | Meaning |
|---|---|---|
| A | 90-100 | Excellent cryptography practices |
| B | 80-89 | Good crypto with minor issues |
| C | 70-79 | Acceptable but needs improvement |
| D | 60-69 | Poor cryptography quality |
| F | Below 60 | Critical cryptography problems |
Users can configure CryptoLint in ~/.openclaw/openclaw.json:
{
"skills": {
"entries": {
"cryptolint": {
"enabled": true,
"apiKey": "YOUR_LICENSE_KEY_HERE",
"config": {
"severityThreshold": "medium",
"ignorePatterns": ["**/test/**", "**/fixtures/**", "**/*.test.*"],
"ignoreChecks": [],
"reportFormat": "text"
}
}
}
}
}
The user might say things like: