@elizaos/skills 2.0.0-alpha.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +126 -0
- package/dist/formatter.d.ts +44 -0
- package/dist/formatter.d.ts.map +1 -0
- package/dist/formatter.js +182 -0
- package/dist/frontmatter.d.ts +39 -0
- package/dist/frontmatter.d.ts.map +1 -0
- package/dist/frontmatter.js +105 -0
- package/dist/index.d.ts +29 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +31 -0
- package/dist/loader.d.ts +33 -0
- package/dist/loader.d.ts.map +1 -0
- package/dist/loader.js +362 -0
- package/dist/resolver.d.ts +18 -0
- package/dist/resolver.d.ts.map +1 -0
- package/dist/resolver.js +90 -0
- package/dist/types.d.ts +201 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +1 -0
- package/package.json +57 -0
- package/skills/1password/SKILL.md +70 -0
- package/skills/1password/references/cli-examples.md +29 -0
- package/skills/1password/references/get-started.md +17 -0
- package/skills/apple-notes/SKILL.md +77 -0
- package/skills/apple-reminders/SKILL.md +96 -0
- package/skills/bear-notes/SKILL.md +107 -0
- package/skills/bird/SKILL.md +224 -0
- package/skills/blogwatcher/SKILL.md +69 -0
- package/skills/blucli/SKILL.md +47 -0
- package/skills/bluebubbles/SKILL.md +131 -0
- package/skills/camsnap/SKILL.md +45 -0
- package/skills/canvas/SKILL.md +203 -0
- package/skills/clawhub/SKILL.md +77 -0
- package/skills/coding-agent/SKILL.md +284 -0
- package/skills/discord/SKILL.md +578 -0
- package/skills/eightctl/SKILL.md +50 -0
- package/skills/food-order/SKILL.md +48 -0
- package/skills/gemini/SKILL.md +43 -0
- package/skills/gifgrep/SKILL.md +79 -0
- package/skills/github/SKILL.md +77 -0
- package/skills/gog/SKILL.md +116 -0
- package/skills/goplaces/SKILL.md +52 -0
- package/skills/healthcheck/SKILL.md +245 -0
- package/skills/himalaya/SKILL.md +257 -0
- package/skills/himalaya/references/configuration.md +184 -0
- package/skills/himalaya/references/message-composition.md +199 -0
- package/skills/imsg/SKILL.md +74 -0
- package/skills/local-places/SERVER_README.md +101 -0
- package/skills/local-places/SKILL.md +102 -0
- package/skills/local-places/pyproject.toml +21 -0
- package/skills/local-places/src/local_places/__init__.py +2 -0
- package/skills/local-places/src/local_places/google_places.py +314 -0
- package/skills/local-places/src/local_places/main.py +65 -0
- package/skills/local-places/src/local_places/schemas.py +107 -0
- package/skills/mcporter/SKILL.md +61 -0
- package/skills/model-usage/SKILL.md +69 -0
- package/skills/model-usage/references/codexbar-cli.md +33 -0
- package/skills/model-usage/scripts/model_usage.py +310 -0
- package/skills/nano-banana-pro/SKILL.md +58 -0
- package/skills/nano-banana-pro/scripts/generate_image.py +184 -0
- package/skills/nano-pdf/SKILL.md +38 -0
- package/skills/notion/SKILL.md +172 -0
- package/skills/obsidian/SKILL.md +81 -0
- package/skills/openai-image-gen/SKILL.md +89 -0
- package/skills/openai-image-gen/scripts/gen.py +240 -0
- package/skills/openai-whisper/SKILL.md +38 -0
- package/skills/openai-whisper-api/SKILL.md +52 -0
- package/skills/openai-whisper-api/scripts/transcribe.sh +85 -0
- package/skills/openhue/SKILL.md +51 -0
- package/skills/oracle/SKILL.md +125 -0
- package/skills/ordercli/SKILL.md +78 -0
- package/skills/peekaboo/SKILL.md +190 -0
- package/skills/sag/SKILL.md +87 -0
- package/skills/security-ask-questions-if-underspecified/.claude-plugin/plugin.json +10 -0
- package/skills/security-ask-questions-if-underspecified/README.md +24 -0
- package/skills/security-ask-questions-if-underspecified/SKILL.md +85 -0
- package/skills/security-ask-questions-if-underspecified/skills/ask-questions-if-underspecified/SKILL.md +85 -0
- package/skills/security-audit-context-building/.claude-plugin/plugin.json +10 -0
- package/skills/security-audit-context-building/README.md +58 -0
- package/skills/security-audit-context-building/SKILL.md +297 -0
- package/skills/security-audit-context-building/commands/audit-context.md +21 -0
- package/skills/security-audit-context-building/skills/audit-context-building/SKILL.md +297 -0
- package/skills/security-audit-context-building/skills/audit-context-building/resources/COMPLETENESS_CHECKLIST.md +47 -0
- package/skills/security-audit-context-building/skills/audit-context-building/resources/FUNCTION_MICRO_ANALYSIS_EXAMPLE.md +355 -0
- package/skills/security-audit-context-building/skills/audit-context-building/resources/OUTPUT_REQUIREMENTS.md +71 -0
- package/skills/security-building-secure-contracts/.claude-plugin/plugin.json +10 -0
- package/skills/security-building-secure-contracts/README.md +241 -0
- package/skills/security-building-secure-contracts/SKILL.md +67 -0
- package/skills/security-building-secure-contracts/skills/algorand-vulnerability-scanner/SKILL.md +284 -0
- package/skills/security-building-secure-contracts/skills/algorand-vulnerability-scanner/resources/VULNERABILITY_PATTERNS.md +405 -0
- package/skills/security-building-secure-contracts/skills/audit-prep-assistant/SKILL.md +409 -0
- package/skills/security-building-secure-contracts/skills/cairo-vulnerability-scanner/SKILL.md +329 -0
- package/skills/security-building-secure-contracts/skills/cairo-vulnerability-scanner/resources/VULNERABILITY_PATTERNS.md +722 -0
- package/skills/security-building-secure-contracts/skills/code-maturity-assessor/SKILL.md +218 -0
- package/skills/security-building-secure-contracts/skills/code-maturity-assessor/resources/ASSESSMENT_CRITERIA.md +355 -0
- package/skills/security-building-secure-contracts/skills/code-maturity-assessor/resources/EXAMPLE_REPORT.md +248 -0
- package/skills/security-building-secure-contracts/skills/code-maturity-assessor/resources/REPORT_FORMAT.md +33 -0
- package/skills/security-building-secure-contracts/skills/cosmos-vulnerability-scanner/SKILL.md +334 -0
- package/skills/security-building-secure-contracts/skills/cosmos-vulnerability-scanner/resources/VULNERABILITY_PATTERNS.md +740 -0
- package/skills/security-building-secure-contracts/skills/guidelines-advisor/SKILL.md +252 -0
- package/skills/security-building-secure-contracts/skills/guidelines-advisor/resources/ASSESSMENT_AREAS.md +329 -0
- package/skills/security-building-secure-contracts/skills/guidelines-advisor/resources/DELIVERABLES.md +118 -0
- package/skills/security-building-secure-contracts/skills/guidelines-advisor/resources/EXAMPLE_REPORT.md +298 -0
- package/skills/security-building-secure-contracts/skills/secure-workflow-guide/SKILL.md +161 -0
- package/skills/security-building-secure-contracts/skills/secure-workflow-guide/resources/EXAMPLE_REPORT.md +279 -0
- package/skills/security-building-secure-contracts/skills/secure-workflow-guide/resources/WORKFLOW_STEPS.md +132 -0
- package/skills/security-building-secure-contracts/skills/solana-vulnerability-scanner/SKILL.md +389 -0
- package/skills/security-building-secure-contracts/skills/solana-vulnerability-scanner/resources/VULNERABILITY_PATTERNS.md +669 -0
- package/skills/security-building-secure-contracts/skills/substrate-vulnerability-scanner/SKILL.md +298 -0
- package/skills/security-building-secure-contracts/skills/substrate-vulnerability-scanner/resources/VULNERABILITY_PATTERNS.md +791 -0
- package/skills/security-building-secure-contracts/skills/token-integration-analyzer/SKILL.md +362 -0
- package/skills/security-building-secure-contracts/skills/token-integration-analyzer/resources/ASSESSMENT_CATEGORIES.md +571 -0
- package/skills/security-building-secure-contracts/skills/token-integration-analyzer/resources/REPORT_TEMPLATES.md +141 -0
- package/skills/security-building-secure-contracts/skills/ton-vulnerability-scanner/SKILL.md +388 -0
- package/skills/security-building-secure-contracts/skills/ton-vulnerability-scanner/resources/VULNERABILITY_PATTERNS.md +595 -0
- package/skills/security-differential-review/.claude-plugin/plugin.json +10 -0
- package/skills/security-differential-review/README.md +109 -0
- package/skills/security-differential-review/SKILL.md +220 -0
- package/skills/security-differential-review/commands/diff-review.md +21 -0
- package/skills/security-differential-review/skills/differential-review/SKILL.md +220 -0
- package/skills/security-differential-review/skills/differential-review/adversarial.md +203 -0
- package/skills/security-differential-review/skills/differential-review/methodology.md +234 -0
- package/skills/security-differential-review/skills/differential-review/patterns.md +300 -0
- package/skills/security-differential-review/skills/differential-review/reporting.md +369 -0
- package/skills/security-entry-point-analyzer/.claude-plugin/plugin.json +10 -0
- package/skills/security-entry-point-analyzer/README.md +74 -0
- package/skills/security-entry-point-analyzer/SKILL.md +251 -0
- package/skills/security-entry-point-analyzer/commands/entry-points.md +18 -0
- package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/SKILL.md +251 -0
- package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/cosmwasm.md +182 -0
- package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/move-aptos.md +107 -0
- package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/move-sui.md +87 -0
- package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/solana.md +155 -0
- package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/solidity.md +135 -0
- package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/ton.md +185 -0
- package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/vyper.md +141 -0
- package/skills/security-fix-review/.claude-plugin/plugin.json +13 -0
- package/skills/security-fix-review/README.md +118 -0
- package/skills/security-fix-review/SKILL.md +264 -0
- package/skills/security-fix-review/commands/fix-review.md +24 -0
- package/skills/security-fix-review/skills/fix-review/SKILL.md +264 -0
- package/skills/security-fix-review/skills/fix-review/references/bug-detection.md +408 -0
- package/skills/security-fix-review/skills/fix-review/references/finding-matching.md +298 -0
- package/skills/security-fix-review/skills/fix-review/references/report-parsing.md +398 -0
- package/skills/security-insecure-defaults/.claude-plugin/plugin.json +10 -0
- package/skills/security-insecure-defaults/README.md +45 -0
- package/skills/security-insecure-defaults/SKILL.md +117 -0
- package/skills/security-insecure-defaults/skills/insecure-defaults/SKILL.md +117 -0
- package/skills/security-insecure-defaults/skills/insecure-defaults/references/examples.md +409 -0
- package/skills/security-modern-python/.claude-plugin/plugin.json +10 -0
- package/skills/security-modern-python/README.md +58 -0
- package/skills/security-modern-python/SKILL.md +333 -0
- package/skills/security-modern-python/hooks/hooks.json +16 -0
- package/skills/security-modern-python/hooks/intercept-legacy-python.bats +388 -0
- package/skills/security-modern-python/hooks/intercept-legacy-python.sh +109 -0
- package/skills/security-modern-python/hooks/test_helper.bash +75 -0
- package/skills/security-modern-python/skills/modern-python/SKILL.md +333 -0
- package/skills/security-modern-python/skills/modern-python/references/dependabot.md +43 -0
- package/skills/security-modern-python/skills/modern-python/references/migration-checklist.md +141 -0
- package/skills/security-modern-python/skills/modern-python/references/pep723-scripts.md +259 -0
- package/skills/security-modern-python/skills/modern-python/references/prek.md +211 -0
- package/skills/security-modern-python/skills/modern-python/references/pyproject.md +254 -0
- package/skills/security-modern-python/skills/modern-python/references/ruff-config.md +240 -0
- package/skills/security-modern-python/skills/modern-python/references/security-setup.md +255 -0
- package/skills/security-modern-python/skills/modern-python/references/testing.md +284 -0
- package/skills/security-modern-python/skills/modern-python/references/uv-commands.md +200 -0
- package/skills/security-modern-python/skills/modern-python/templates/dependabot.yml +36 -0
- package/skills/security-modern-python/skills/modern-python/templates/pre-commit-config.yaml +66 -0
- package/skills/security-property-based-testing/.claude-plugin/plugin.json +9 -0
- package/skills/security-property-based-testing/README.md +47 -0
- package/skills/security-property-based-testing/SKILL.md +109 -0
- package/skills/security-property-based-testing/skills/property-based-testing/README.md +88 -0
- package/skills/security-property-based-testing/skills/property-based-testing/SKILL.md +109 -0
- package/skills/security-property-based-testing/skills/property-based-testing/references/design.md +191 -0
- package/skills/security-property-based-testing/skills/property-based-testing/references/generating.md +200 -0
- package/skills/security-property-based-testing/skills/property-based-testing/references/libraries.md +130 -0
- package/skills/security-property-based-testing/skills/property-based-testing/references/refactoring.md +181 -0
- package/skills/security-property-based-testing/skills/property-based-testing/references/reviewing.md +209 -0
- package/skills/security-property-based-testing/skills/property-based-testing/references/strategies.md +124 -0
- package/skills/semgrep-rule-creator/.claude-plugin/plugin.json +8 -0
- package/skills/semgrep-rule-creator/README.md +43 -0
- package/skills/semgrep-rule-creator/SKILL.md +168 -0
- package/skills/semgrep-rule-creator/commands/semgrep-rule.md +26 -0
- package/skills/semgrep-rule-creator/skills/semgrep-rule-creator/SKILL.md +168 -0
- package/skills/semgrep-rule-creator/skills/semgrep-rule-creator/references/quick-reference.md +203 -0
- package/skills/semgrep-rule-creator/skills/semgrep-rule-creator/references/workflow.md +240 -0
- package/skills/session-logs/SKILL.md +115 -0
- package/skills/sharp-edges/.claude-plugin/plugin.json +10 -0
- package/skills/sharp-edges/README.md +48 -0
- package/skills/sharp-edges/SKILL.md +292 -0
- package/skills/sharp-edges/skills/sharp-edges/SKILL.md +292 -0
- package/skills/sharp-edges/skills/sharp-edges/references/auth-patterns.md +252 -0
- package/skills/sharp-edges/skills/sharp-edges/references/case-studies.md +274 -0
- package/skills/sharp-edges/skills/sharp-edges/references/config-patterns.md +333 -0
- package/skills/sharp-edges/skills/sharp-edges/references/crypto-apis.md +190 -0
- package/skills/sharp-edges/skills/sharp-edges/references/lang-c.md +205 -0
- package/skills/sharp-edges/skills/sharp-edges/references/lang-csharp.md +285 -0
- package/skills/sharp-edges/skills/sharp-edges/references/lang-go.md +270 -0
- package/skills/sharp-edges/skills/sharp-edges/references/lang-java.md +263 -0
- package/skills/sharp-edges/skills/sharp-edges/references/lang-javascript.md +269 -0
- package/skills/sharp-edges/skills/sharp-edges/references/lang-kotlin.md +265 -0
- package/skills/sharp-edges/skills/sharp-edges/references/lang-php.md +245 -0
- package/skills/sharp-edges/skills/sharp-edges/references/lang-python.md +274 -0
- package/skills/sharp-edges/skills/sharp-edges/references/lang-ruby.md +273 -0
- package/skills/sharp-edges/skills/sharp-edges/references/lang-rust.md +272 -0
- package/skills/sharp-edges/skills/sharp-edges/references/lang-swift.md +287 -0
- package/skills/sharp-edges/skills/sharp-edges/references/language-specific.md +588 -0
- package/skills/sherpa-onnx-tts/SKILL.md +103 -0
- package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
- package/skills/skill-creator/SKILL.md +370 -0
- package/skills/skill-creator/license.txt +202 -0
- package/skills/skill-creator/scripts/init_skill.py +378 -0
- package/skills/skill-creator/scripts/package_skill.py +111 -0
- package/skills/skill-creator/scripts/quick_validate.py +101 -0
- package/skills/slack/SKILL.md +144 -0
- package/skills/songsee/SKILL.md +49 -0
- package/skills/sonoscli/SKILL.md +46 -0
- package/skills/spec-to-code-compliance/.claude-plugin/plugin.json +10 -0
- package/skills/spec-to-code-compliance/README.md +67 -0
- package/skills/spec-to-code-compliance/SKILL.md +349 -0
- package/skills/spec-to-code-compliance/commands/spec-compliance.md +22 -0
- package/skills/spec-to-code-compliance/skills/spec-to-code-compliance/SKILL.md +349 -0
- package/skills/spec-to-code-compliance/skills/spec-to-code-compliance/resources/COMPLETENESS_CHECKLIST.md +69 -0
- package/skills/spec-to-code-compliance/skills/spec-to-code-compliance/resources/IR_EXAMPLES.md +417 -0
- package/skills/spec-to-code-compliance/skills/spec-to-code-compliance/resources/OUTPUT_REQUIREMENTS.md +105 -0
- package/skills/spotify-player/SKILL.md +64 -0
- package/skills/static-analysis/.claude-plugin/plugin.json +8 -0
- package/skills/static-analysis/README.md +59 -0
- package/skills/static-analysis/SKILL.md +91 -0
- package/skills/static-analysis/skills/codeql/SKILL.md +315 -0
- package/skills/static-analysis/skills/sarif-parsing/SKILL.md +479 -0
- package/skills/static-analysis/skills/sarif-parsing/resources/jq-queries.md +162 -0
- package/skills/static-analysis/skills/sarif-parsing/resources/sarif_helpers.py +331 -0
- package/skills/static-analysis/skills/semgrep/SKILL.md +337 -0
- package/skills/summarize/SKILL.md +87 -0
- package/skills/testing-handbook-skills/.claude-plugin/plugin.json +8 -0
- package/skills/testing-handbook-skills/README.md +241 -0
- package/skills/testing-handbook-skills/SKILL.md +104 -0
- package/skills/testing-handbook-skills/scripts/pyproject.toml +8 -0
- package/skills/testing-handbook-skills/scripts/validate-skills.py +657 -0
- package/skills/testing-handbook-skills/skills/address-sanitizer/SKILL.md +341 -0
- package/skills/testing-handbook-skills/skills/aflpp/SKILL.md +640 -0
- package/skills/testing-handbook-skills/skills/atheris/SKILL.md +515 -0
- package/skills/testing-handbook-skills/skills/cargo-fuzz/SKILL.md +454 -0
- package/skills/testing-handbook-skills/skills/codeql/SKILL.md +549 -0
- package/skills/testing-handbook-skills/skills/constant-time-testing/SKILL.md +507 -0
- package/skills/testing-handbook-skills/skills/coverage-analysis/SKILL.md +607 -0
- package/skills/testing-handbook-skills/skills/fuzzing-dictionary/SKILL.md +297 -0
- package/skills/testing-handbook-skills/skills/fuzzing-obstacles/SKILL.md +426 -0
- package/skills/testing-handbook-skills/skills/harness-writing/SKILL.md +614 -0
- package/skills/testing-handbook-skills/skills/libafl/SKILL.md +625 -0
- package/skills/testing-handbook-skills/skills/libfuzzer/SKILL.md +795 -0
- package/skills/testing-handbook-skills/skills/ossfuzz/SKILL.md +426 -0
- package/skills/testing-handbook-skills/skills/ruzzy/SKILL.md +443 -0
- package/skills/testing-handbook-skills/skills/semgrep/SKILL.md +601 -0
- package/skills/testing-handbook-skills/skills/testing-handbook-generator/SKILL.md +372 -0
- package/skills/testing-handbook-skills/skills/testing-handbook-generator/agent-prompt.md +280 -0
- package/skills/testing-handbook-skills/skills/testing-handbook-generator/discovery.md +452 -0
- package/skills/testing-handbook-skills/skills/testing-handbook-generator/templates/domain-skill.md +504 -0
- package/skills/testing-handbook-skills/skills/testing-handbook-generator/templates/fuzzer-skill.md +454 -0
- package/skills/testing-handbook-skills/skills/testing-handbook-generator/templates/technique-skill.md +527 -0
- package/skills/testing-handbook-skills/skills/testing-handbook-generator/templates/tool-skill.md +366 -0
- package/skills/testing-handbook-skills/skills/testing-handbook-generator/testing.md +482 -0
- package/skills/testing-handbook-skills/skills/wycheproof/SKILL.md +533 -0
- package/skills/things-mac/SKILL.md +86 -0
- package/skills/tmux/SKILL.md +135 -0
- package/skills/tmux/scripts/find-sessions.sh +112 -0
- package/skills/tmux/scripts/wait-for-text.sh +83 -0
- package/skills/trello/SKILL.md +95 -0
- package/skills/variant-analysis/.claude-plugin/plugin.json +8 -0
- package/skills/variant-analysis/README.md +41 -0
- package/skills/variant-analysis/SKILL.md +142 -0
- package/skills/variant-analysis/commands/variants.md +23 -0
- package/skills/variant-analysis/skills/variant-analysis/METHODOLOGY.md +327 -0
- package/skills/variant-analysis/skills/variant-analysis/SKILL.md +142 -0
- package/skills/variant-analysis/skills/variant-analysis/resources/codeql/cpp.ql +119 -0
- package/skills/variant-analysis/skills/variant-analysis/resources/codeql/go.ql +69 -0
- package/skills/variant-analysis/skills/variant-analysis/resources/codeql/java.ql +71 -0
- package/skills/variant-analysis/skills/variant-analysis/resources/codeql/javascript.ql +63 -0
- package/skills/variant-analysis/skills/variant-analysis/resources/codeql/python.ql +80 -0
- package/skills/variant-analysis/skills/variant-analysis/resources/semgrep/cpp.yaml +98 -0
- package/skills/variant-analysis/skills/variant-analysis/resources/semgrep/go.yaml +63 -0
- package/skills/variant-analysis/skills/variant-analysis/resources/semgrep/java.yaml +61 -0
- package/skills/variant-analysis/skills/variant-analysis/resources/semgrep/javascript.yaml +60 -0
- package/skills/variant-analysis/skills/variant-analysis/resources/semgrep/python.yaml +72 -0
- package/skills/variant-analysis/skills/variant-analysis/resources/variant-report-template.md +75 -0
- package/skills/video-frames/SKILL.md +46 -0
- package/skills/video-frames/scripts/frame.sh +81 -0
- package/skills/voice-call/SKILL.md +45 -0
- package/skills/wacli/SKILL.md +72 -0
- package/skills/weather/SKILL.md +54 -0
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: security-building-secure-contracts
|
|
3
|
+
description: "Smart contract security toolkit based on Trail of Bits' Building Secure Contracts framework. Includes vulnerability scanners for 6 blockchain platforms and 5 development guidelines assistants for audit preparation, code maturity assessment, and secure workflows."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Building Secure Contracts
|
|
7
|
+
|
|
8
|
+
A comprehensive security toolkit for smart contract development and auditing, based on Trail of Bits' [Building Secure Contracts](https://github.com/crytic/building-secure-contracts) framework.
|
|
9
|
+
|
|
10
|
+
## When to Use
|
|
11
|
+
|
|
12
|
+
- Auditing smart contracts on any supported blockchain platform
|
|
13
|
+
- Preparing a codebase for a security review
|
|
14
|
+
- Assessing code maturity and development practices
|
|
15
|
+
- Scanning for platform-specific vulnerability patterns
|
|
16
|
+
- Analyzing token integration risks (ERC20/ERC721 edge cases)
|
|
17
|
+
|
|
18
|
+
## When NOT to Use
|
|
19
|
+
|
|
20
|
+
- Non-blockchain codebases (use general security skills instead)
|
|
21
|
+
- Vulnerability discovery without a specific platform target (use audit-context-building)
|
|
22
|
+
- Writing exploit PoCs (use solidity-poc-builder)
|
|
23
|
+
|
|
24
|
+
## Sub-Skills
|
|
25
|
+
|
|
26
|
+
This skill contains 11 specialized sub-skills organized into two categories:
|
|
27
|
+
|
|
28
|
+
### Vulnerability Scanners (6 platforms)
|
|
29
|
+
|
|
30
|
+
| Scanner | Platform | Patterns | Skill Path |
|
|
31
|
+
|---------|----------|----------|------------|
|
|
32
|
+
| **Algorand** | TEAL / PyTeal | 11 patterns (rekeying, unchecked fees, field validation) | [skills/algorand-vulnerability-scanner/SKILL.md](skills/algorand-vulnerability-scanner/SKILL.md) |
|
|
33
|
+
| **Cairo** | StarkNet | 6 patterns (unchecked arithmetic, storage collision, access control) | [skills/cairo-vulnerability-scanner/SKILL.md](skills/cairo-vulnerability-scanner/SKILL.md) |
|
|
34
|
+
| **Cosmos** | CosmWasm | 9 patterns (denom validation, authorization, IBC packets) | [skills/cosmos-vulnerability-scanner/SKILL.md](skills/cosmos-vulnerability-scanner/SKILL.md) |
|
|
35
|
+
| **Solana** | Anchor / Rust | 6 patterns (arbitrary CPI, PDA validation, signer checks) | [skills/solana-vulnerability-scanner/SKILL.md](skills/solana-vulnerability-scanner/SKILL.md) |
|
|
36
|
+
| **Substrate** | Polkadot | 7 patterns (arithmetic overflow, weights/fees, bad randomness) | [skills/substrate-vulnerability-scanner/SKILL.md](skills/substrate-vulnerability-scanner/SKILL.md) |
|
|
37
|
+
| **TON** | FunC / Tact | 3 patterns (missing sender check, integer overflow, gas handling) | [skills/ton-vulnerability-scanner/SKILL.md](skills/ton-vulnerability-scanner/SKILL.md) |
|
|
38
|
+
|
|
39
|
+
### Development Guidelines Assistants (5 tools)
|
|
40
|
+
|
|
41
|
+
| Assistant | Purpose | Skill Path |
|
|
42
|
+
|-----------|---------|------------|
|
|
43
|
+
| **Audit Prep** | Prepare codebase for security review using Trail of Bits' checklist | [skills/audit-prep-assistant/SKILL.md](skills/audit-prep-assistant/SKILL.md) |
|
|
44
|
+
| **Code Maturity** | Assess code maturity across 9 categories (arithmetic, auth, complexity, etc.) | [skills/code-maturity-assessor/SKILL.md](skills/code-maturity-assessor/SKILL.md) |
|
|
45
|
+
| **Guidelines Advisor** | Development advisor based on Trail of Bits' best practices | [skills/guidelines-advisor/SKILL.md](skills/guidelines-advisor/SKILL.md) |
|
|
46
|
+
| **Secure Workflow** | 5-step secure development workflow guide | [skills/secure-workflow-guide/SKILL.md](skills/secure-workflow-guide/SKILL.md) |
|
|
47
|
+
| **Token Integration** | Analyze 20+ weird ERC20/ERC721 token patterns | [skills/token-integration-analyzer/SKILL.md](skills/token-integration-analyzer/SKILL.md) |
|
|
48
|
+
|
|
49
|
+
## Usage
|
|
50
|
+
|
|
51
|
+
Select the appropriate sub-skill based on your task:
|
|
52
|
+
|
|
53
|
+
1. **Starting an audit?** Begin with the platform-specific vulnerability scanner
|
|
54
|
+
2. **Preparing for audit?** Use the Audit Prep Assistant
|
|
55
|
+
3. **Reviewing development practices?** Use Code Maturity Assessor or Guidelines Advisor
|
|
56
|
+
4. **Integrating tokens?** Use Token Integration Analyzer
|
|
57
|
+
5. **Setting up workflows?** Use Secure Workflow Guide
|
|
58
|
+
|
|
59
|
+
## Tool Integration
|
|
60
|
+
|
|
61
|
+
- **Slither** (Solidity): `slither . --detect all`
|
|
62
|
+
- **Tealer** (Algorand): `tealer contract.teal --detect all`
|
|
63
|
+
- **cargo-audit** (Rust/Substrate): `cargo audit`
|
|
64
|
+
|
|
65
|
+
## Source Material
|
|
66
|
+
|
|
67
|
+
Based on Trail of Bits' [Building Secure Contracts](https://github.com/crytic/building-secure-contracts) and [Not So Smart Contracts](https://github.com/crytic/not-so-smart-contracts) repositories.
|
package/skills/security-building-secure-contracts/skills/algorand-vulnerability-scanner/SKILL.md
ADDED
|
@@ -0,0 +1,284 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: algorand-vulnerability-scanner
|
|
3
|
+
description: Scans Algorand smart contracts for 11 common vulnerabilities including rekeying attacks, unchecked transaction fees, missing field validations, and access control issues. Use when auditing Algorand projects (TEAL/PyTeal).
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Algorand Vulnerability Scanner
|
|
7
|
+
|
|
8
|
+
## 1. Purpose
|
|
9
|
+
|
|
10
|
+
Systematically scan Algorand smart contracts (TEAL and PyTeal) for platform-specific security vulnerabilities documented in Trail of Bits' "Not So Smart Contracts" database. This skill encodes 11 critical vulnerability patterns unique to Algorand's transaction model.
|
|
11
|
+
|
|
12
|
+
## 2. When to Use This Skill
|
|
13
|
+
|
|
14
|
+
- Auditing Algorand smart contracts (stateful applications or smart signatures)
|
|
15
|
+
- Reviewing TEAL assembly or PyTeal code
|
|
16
|
+
- Pre-audit security assessment of Algorand projects
|
|
17
|
+
- Validating fixes for reported Algorand vulnerabilities
|
|
18
|
+
- Training team on Algorand-specific security patterns
|
|
19
|
+
|
|
20
|
+
## 3. Platform Detection
|
|
21
|
+
|
|
22
|
+
### File Extensions & Indicators
|
|
23
|
+
- **TEAL files**: `.teal`
|
|
24
|
+
- **PyTeal files**: `.py` with PyTeal imports
|
|
25
|
+
|
|
26
|
+
### Language/Framework Markers
|
|
27
|
+
```python
|
|
28
|
+
# PyTeal indicators
|
|
29
|
+
from pyteal import *
|
|
30
|
+
from algosdk import *
|
|
31
|
+
|
|
32
|
+
# Common patterns
|
|
33
|
+
Txn, Gtxn, Global, InnerTxnBuilder
|
|
34
|
+
OnComplete, ApplicationCall, TxnType
|
|
35
|
+
@router.method, @Subroutine
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
### Project Structure
|
|
39
|
+
- `approval_program.py` / `clear_program.py`
|
|
40
|
+
- `contract.teal` / `signature.teal`
|
|
41
|
+
- References to Algorand SDK or Beaker framework
|
|
42
|
+
|
|
43
|
+
### Tool Support
|
|
44
|
+
- **Tealer**: Trail of Bits static analyzer for Algorand
|
|
45
|
+
- Installation: `pip3 install tealer`
|
|
46
|
+
- Usage: `tealer contract.teal --detect all`
|
|
47
|
+
|
|
48
|
+
---
|
|
49
|
+
|
|
50
|
+
## 4. How This Skill Works
|
|
51
|
+
|
|
52
|
+
When invoked, I will:
|
|
53
|
+
|
|
54
|
+
1. **Search your codebase** for TEAL/PyTeal files
|
|
55
|
+
2. **Analyze each file** for the 11 vulnerability patterns
|
|
56
|
+
3. **Report findings** with file references and severity
|
|
57
|
+
4. **Provide fixes** for each identified issue
|
|
58
|
+
5. **Run Tealer** (if installed) for automated detection
|
|
59
|
+
|
|
60
|
+
---
|
|
61
|
+
|
|
62
|
+
## 5. Example Output
|
|
63
|
+
|
|
64
|
+
When vulnerabilities are found, you'll get a report like this:
|
|
65
|
+
|
|
66
|
+
```
|
|
67
|
+
=== ALGORAND VULNERABILITY SCAN RESULTS ===
|
|
68
|
+
|
|
69
|
+
Project: my-algorand-dapp
|
|
70
|
+
Files Scanned: 3 (.teal, .py)
|
|
71
|
+
Vulnerabilities Found: 2
|
|
72
|
+
|
|
73
|
+
---
|
|
74
|
+
|
|
75
|
+
[CRITICAL] Rekeying Attack
|
|
76
|
+
File: contracts/approval.py:45
|
|
77
|
+
Pattern: Missing RekeyTo validation
|
|
78
|
+
|
|
79
|
+
Code:
|
|
80
|
+
If(Txn.type_enum() == TxnType.Payment,
|
|
81
|
+
Seq([
|
|
82
|
+
# Missing: Assert(Txn.rekey_to() == Global.zero_address())
|
|
83
|
+
App.globalPut(Bytes("balance"), balance + Txn.amount()),
|
|
84
|
+
Approve()
|
|
85
|
+
])
|
|
86
|
+
)
|
|
87
|
+
|
|
88
|
+
Issue: The contract doesn't validate the RekeyTo field, allowing attackers
|
|
89
|
+
to change account authorization and bypass restrictions.
|
|
90
|
+
|
|
91
|
+
|
|
92
|
+
---
|
|
93
|
+
|
|
94
|
+
## 5. Vulnerability Patterns (11 Patterns)
|
|
95
|
+
|
|
96
|
+
I check for 11 critical vulnerability patterns unique to Algorand. For detailed detection patterns, code examples, mitigations, and testing strategies, see [VULNERABILITY_PATTERNS.md](resources/VULNERABILITY_PATTERNS.md).
|
|
97
|
+
|
|
98
|
+
### Pattern Summary:
|
|
99
|
+
|
|
100
|
+
1. **Rekeying Vulnerability** ⚠️ CRITICAL - Unchecked RekeyTo field
|
|
101
|
+
2. **Missing Transaction Verification** ⚠️ CRITICAL - No GroupSize/GroupIndex checks
|
|
102
|
+
3. **Group Transaction Manipulation** ⚠️ HIGH - Unsafe group transaction handling
|
|
103
|
+
4. **Asset Clawback Risk** ⚠️ HIGH - Missing clawback address checks
|
|
104
|
+
5. **Application State Manipulation** ⚠️ MEDIUM - Unsafe global/local state updates
|
|
105
|
+
6. **Asset Opt-In Missing** ⚠️ HIGH - No asset opt-in validation
|
|
106
|
+
7. **Minimum Balance Violation** ⚠️ MEDIUM - Account below minimum balance
|
|
107
|
+
8. **Close Remainder To Check** ⚠️ HIGH - Unchecked CloseRemainderTo field
|
|
108
|
+
9. **Application Clear State** ⚠️ MEDIUM - Unsafe clear state program
|
|
109
|
+
10. **Atomic Transaction Ordering** ⚠️ HIGH - Assuming transaction order
|
|
110
|
+
11. **Logic Signature Reuse** ⚠️ HIGH - Logic sigs without uniqueness constraints
|
|
111
|
+
|
|
112
|
+
For complete vulnerability patterns with code examples, see [VULNERABILITY_PATTERNS.md](resources/VULNERABILITY_PATTERNS.md).
|
|
113
|
+
## 5. Scanning Workflow
|
|
114
|
+
|
|
115
|
+
### Step 1: Platform Identification
|
|
116
|
+
1. Confirm file extensions (`.teal`, `.py`)
|
|
117
|
+
2. Identify framework (PyTeal, Beaker, pure TEAL)
|
|
118
|
+
3. Determine contract type (stateful application vs smart signature)
|
|
119
|
+
4. Locate approval and clear state programs
|
|
120
|
+
|
|
121
|
+
### Step 2: Static Analysis with Tealer
|
|
122
|
+
```bash
|
|
123
|
+
# Run Tealer on contract
|
|
124
|
+
tealer contract.teal --detect all
|
|
125
|
+
|
|
126
|
+
# Or specific detectors
|
|
127
|
+
tealer contract.teal --detect unprotected-rekey,group-size-check,update-application-check
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
### Step 3: Manual Vulnerability Sweep
|
|
131
|
+
For each of the 11 vulnerabilities above:
|
|
132
|
+
1. Search for relevant transaction field usage
|
|
133
|
+
2. Verify validation logic exists
|
|
134
|
+
3. Check for bypass conditions
|
|
135
|
+
4. Validate inner transaction handling
|
|
136
|
+
|
|
137
|
+
### Step 4: Transaction Field Validation Matrix
|
|
138
|
+
Create checklist for all transaction types used:
|
|
139
|
+
|
|
140
|
+
**Payment Transactions**:
|
|
141
|
+
- [ ] RekeyTo validated
|
|
142
|
+
- [ ] CloseRemainderTo validated
|
|
143
|
+
- [ ] Fee validated (if smart signature)
|
|
144
|
+
|
|
145
|
+
**Asset Transfers**:
|
|
146
|
+
- [ ] Asset ID validated
|
|
147
|
+
- [ ] AssetCloseTo validated
|
|
148
|
+
- [ ] RekeyTo validated
|
|
149
|
+
|
|
150
|
+
**Application Calls**:
|
|
151
|
+
- [ ] OnComplete validated
|
|
152
|
+
- [ ] Access controls enforced
|
|
153
|
+
- [ ] Group size validated
|
|
154
|
+
|
|
155
|
+
**Inner Transactions**:
|
|
156
|
+
- [ ] Fee explicitly set to 0
|
|
157
|
+
- [ ] RekeyTo not user-controlled (Teal v6+)
|
|
158
|
+
- [ ] All fields validated
|
|
159
|
+
|
|
160
|
+
### Step 5: Group Transaction Analysis
|
|
161
|
+
For atomic transaction groups:
|
|
162
|
+
1. Validate `Global.group_size()` checks
|
|
163
|
+
2. Review absolute vs relative indexing
|
|
164
|
+
3. Check for replay protection (Lease field)
|
|
165
|
+
4. Verify OnComplete fields for ApplicationCalls in group
|
|
166
|
+
|
|
167
|
+
### Step 6: Access Control Review
|
|
168
|
+
- [ ] Creator/admin privileges properly enforced
|
|
169
|
+
- [ ] Update/delete operations protected
|
|
170
|
+
- [ ] Sensitive functions have authorization checks
|
|
171
|
+
|
|
172
|
+
---
|
|
173
|
+
|
|
174
|
+
## 6. Reporting Format
|
|
175
|
+
|
|
176
|
+
### Finding Template
|
|
177
|
+
```markdown
|
|
178
|
+
## [SEVERITY] Vulnerability Name (e.g., Missing RekeyTo Validation)
|
|
179
|
+
|
|
180
|
+
**Location**: `contract.teal:45-50` or `approval_program.py:withdraw()`
|
|
181
|
+
|
|
182
|
+
**Description**:
|
|
183
|
+
The contract approves payment transactions without validating the RekeyTo field, allowing an attacker to rekey the account and bypass future authorization checks.
|
|
184
|
+
|
|
185
|
+
**Vulnerable Code**:
|
|
186
|
+
```python
|
|
187
|
+
# approval_program.py, line 45
|
|
188
|
+
If(Txn.type_enum() == TxnType.Payment,
|
|
189
|
+
Approve() # Missing RekeyTo check
|
|
190
|
+
)
|
|
191
|
+
```
|
|
192
|
+
|
|
193
|
+
**Attack Scenario**:
|
|
194
|
+
1. Attacker submits payment transaction with RekeyTo set to attacker's address
|
|
195
|
+
2. Contract approves transaction without checking RekeyTo
|
|
196
|
+
3. Account authorization is rekeyed to attacker
|
|
197
|
+
4. Attacker gains full control of account
|
|
198
|
+
|
|
199
|
+
**Recommendation**:
|
|
200
|
+
Add explicit validation of the RekeyTo field:
|
|
201
|
+
```python
|
|
202
|
+
If(And(
|
|
203
|
+
Txn.type_enum() == TxnType.Payment,
|
|
204
|
+
Txn.rekey_to() == Global.zero_address()
|
|
205
|
+
), Approve(), Reject())
|
|
206
|
+
```
|
|
207
|
+
|
|
208
|
+
**References**:
|
|
209
|
+
- building-secure-contracts/not-so-smart-contracts/algorand/rekeying
|
|
210
|
+
- Tealer detector: `unprotected-rekey`
|
|
211
|
+
```
|
|
212
|
+
|
|
213
|
+
---
|
|
214
|
+
|
|
215
|
+
## 7. Priority Guidelines
|
|
216
|
+
|
|
217
|
+
### Critical (Immediate Fix Required)
|
|
218
|
+
- Rekeying attacks
|
|
219
|
+
- CloseRemainderTo / AssetCloseTo issues
|
|
220
|
+
- Access control bypasses
|
|
221
|
+
|
|
222
|
+
### High (Fix Before Deployment)
|
|
223
|
+
- Unchecked transaction fees
|
|
224
|
+
- Asset ID validation issues
|
|
225
|
+
- Group size validation
|
|
226
|
+
- Clear state transaction checks
|
|
227
|
+
|
|
228
|
+
### Medium (Address in Audit)
|
|
229
|
+
- Inner transaction fee issues
|
|
230
|
+
- Time-based replay attacks
|
|
231
|
+
- DoS via asset opt-in
|
|
232
|
+
|
|
233
|
+
---
|
|
234
|
+
|
|
235
|
+
## 8. Testing Recommendations
|
|
236
|
+
|
|
237
|
+
### Unit Tests Required
|
|
238
|
+
- Test each vulnerability scenario with PoC exploit
|
|
239
|
+
- Verify fixes prevent exploitation
|
|
240
|
+
- Test edge cases (group size = 0, empty addresses, etc.)
|
|
241
|
+
|
|
242
|
+
### Tealer Integration
|
|
243
|
+
```bash
|
|
244
|
+
# Add to CI/CD pipeline
|
|
245
|
+
tealer approval.teal --detect all --json > tealer-report.json
|
|
246
|
+
|
|
247
|
+
# Fail build on critical findings
|
|
248
|
+
tealer approval.teal --detect all --fail-on critical,high
|
|
249
|
+
```
|
|
250
|
+
|
|
251
|
+
### Scenario Testing
|
|
252
|
+
- Submit transactions with all critical fields manipulated
|
|
253
|
+
- Test atomic groups with unexpected sizes
|
|
254
|
+
- Attempt access control bypasses
|
|
255
|
+
- Verify inner transaction fee handling
|
|
256
|
+
|
|
257
|
+
---
|
|
258
|
+
|
|
259
|
+
## 9. Additional Resources
|
|
260
|
+
|
|
261
|
+
- **Building Secure Contracts**: `building-secure-contracts/not-so-smart-contracts/algorand/`
|
|
262
|
+
- **Tealer Documentation**: https://github.com/crytic/tealer
|
|
263
|
+
- **Algorand Developer Docs**: https://developer.algorand.org/docs/
|
|
264
|
+
- **PyTeal Documentation**: https://pyteal.readthedocs.io/
|
|
265
|
+
|
|
266
|
+
---
|
|
267
|
+
|
|
268
|
+
## 10. Quick Reference Checklist
|
|
269
|
+
|
|
270
|
+
Before completing Algorand audit, verify ALL items checked:
|
|
271
|
+
|
|
272
|
+
- [ ] RekeyTo validated in all transaction types
|
|
273
|
+
- [ ] CloseRemainderTo validated in payment transactions
|
|
274
|
+
- [ ] AssetCloseTo validated in asset transfers
|
|
275
|
+
- [ ] Transaction fees validated (smart signatures)
|
|
276
|
+
- [ ] Group size validated for atomic transactions
|
|
277
|
+
- [ ] Lease field used for replay protection (where applicable)
|
|
278
|
+
- [ ] Access controls on Update/Delete operations
|
|
279
|
+
- [ ] Asset ID validated in all asset operations
|
|
280
|
+
- [ ] Asset transfers use pull pattern to avoid DoS
|
|
281
|
+
- [ ] Inner transaction fees explicitly set to 0
|
|
282
|
+
- [ ] OnComplete field validated for ApplicationCall transactions
|
|
283
|
+
- [ ] Tealer scan completed with no critical/high findings
|
|
284
|
+
- [ ] Unit tests cover all vulnerability scenarios
|