@elizaos/skills 2.0.0-alpha.3

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.
Files changed (371) hide show
  1. package/README.md +126 -0
  2. package/package.json +53 -0
  3. package/skills/1password/SKILL.md +70 -0
  4. package/skills/1password/references/cli-examples.md +29 -0
  5. package/skills/1password/references/get-started.md +17 -0
  6. package/skills/apple-notes/SKILL.md +77 -0
  7. package/skills/apple-reminders/SKILL.md +96 -0
  8. package/skills/bear-notes/SKILL.md +107 -0
  9. package/skills/bird/SKILL.md +224 -0
  10. package/skills/blogwatcher/SKILL.md +69 -0
  11. package/skills/blucli/SKILL.md +47 -0
  12. package/skills/bluebubbles/SKILL.md +131 -0
  13. package/skills/camsnap/SKILL.md +45 -0
  14. package/skills/canvas/SKILL.md +203 -0
  15. package/skills/clawhub/SKILL.md +77 -0
  16. package/skills/coding-agent/SKILL.md +284 -0
  17. package/skills/discord/SKILL.md +578 -0
  18. package/skills/eightctl/SKILL.md +50 -0
  19. package/skills/food-order/SKILL.md +48 -0
  20. package/skills/gemini/SKILL.md +43 -0
  21. package/skills/gifgrep/SKILL.md +79 -0
  22. package/skills/github/SKILL.md +77 -0
  23. package/skills/gog/SKILL.md +116 -0
  24. package/skills/goplaces/SKILL.md +52 -0
  25. package/skills/healthcheck/SKILL.md +245 -0
  26. package/skills/himalaya/SKILL.md +257 -0
  27. package/skills/himalaya/references/configuration.md +184 -0
  28. package/skills/himalaya/references/message-composition.md +199 -0
  29. package/skills/imsg/SKILL.md +74 -0
  30. package/skills/local-places/SERVER_README.md +101 -0
  31. package/skills/local-places/SKILL.md +102 -0
  32. package/skills/local-places/pyproject.toml +21 -0
  33. package/skills/local-places/src/local_places/__init__.py +2 -0
  34. package/skills/local-places/src/local_places/google_places.py +314 -0
  35. package/skills/local-places/src/local_places/main.py +65 -0
  36. package/skills/local-places/src/local_places/schemas.py +107 -0
  37. package/skills/mcporter/SKILL.md +61 -0
  38. package/skills/model-usage/SKILL.md +69 -0
  39. package/skills/model-usage/references/codexbar-cli.md +33 -0
  40. package/skills/model-usage/scripts/model_usage.py +310 -0
  41. package/skills/nano-banana-pro/SKILL.md +58 -0
  42. package/skills/nano-banana-pro/scripts/generate_image.py +184 -0
  43. package/skills/nano-pdf/SKILL.md +38 -0
  44. package/skills/notion/SKILL.md +172 -0
  45. package/skills/obsidian/SKILL.md +81 -0
  46. package/skills/openai-image-gen/SKILL.md +89 -0
  47. package/skills/openai-image-gen/scripts/gen.py +240 -0
  48. package/skills/openai-whisper/SKILL.md +38 -0
  49. package/skills/openai-whisper-api/SKILL.md +52 -0
  50. package/skills/openai-whisper-api/scripts/transcribe.sh +85 -0
  51. package/skills/openhue/SKILL.md +51 -0
  52. package/skills/oracle/SKILL.md +125 -0
  53. package/skills/ordercli/SKILL.md +78 -0
  54. package/skills/peekaboo/SKILL.md +190 -0
  55. package/skills/sag/SKILL.md +87 -0
  56. package/skills/security-ask-questions-if-underspecified/.claude-plugin/plugin.json +10 -0
  57. package/skills/security-ask-questions-if-underspecified/README.md +24 -0
  58. package/skills/security-ask-questions-if-underspecified/skills/ask-questions-if-underspecified/SKILL.md +85 -0
  59. package/skills/security-audit-context-building/.claude-plugin/plugin.json +10 -0
  60. package/skills/security-audit-context-building/README.md +58 -0
  61. package/skills/security-audit-context-building/commands/audit-context.md +21 -0
  62. package/skills/security-audit-context-building/skills/audit-context-building/SKILL.md +297 -0
  63. package/skills/security-audit-context-building/skills/audit-context-building/resources/COMPLETENESS_CHECKLIST.md +47 -0
  64. package/skills/security-audit-context-building/skills/audit-context-building/resources/FUNCTION_MICRO_ANALYSIS_EXAMPLE.md +355 -0
  65. package/skills/security-audit-context-building/skills/audit-context-building/resources/OUTPUT_REQUIREMENTS.md +71 -0
  66. package/skills/security-building-secure-contracts/.claude-plugin/plugin.json +10 -0
  67. package/skills/security-building-secure-contracts/README.md +241 -0
  68. package/skills/security-building-secure-contracts/skills/algorand-vulnerability-scanner/SKILL.md +284 -0
  69. package/skills/security-building-secure-contracts/skills/algorand-vulnerability-scanner/resources/VULNERABILITY_PATTERNS.md +405 -0
  70. package/skills/security-building-secure-contracts/skills/audit-prep-assistant/SKILL.md +409 -0
  71. package/skills/security-building-secure-contracts/skills/cairo-vulnerability-scanner/SKILL.md +329 -0
  72. package/skills/security-building-secure-contracts/skills/cairo-vulnerability-scanner/resources/VULNERABILITY_PATTERNS.md +722 -0
  73. package/skills/security-building-secure-contracts/skills/code-maturity-assessor/SKILL.md +218 -0
  74. package/skills/security-building-secure-contracts/skills/code-maturity-assessor/resources/ASSESSMENT_CRITERIA.md +355 -0
  75. package/skills/security-building-secure-contracts/skills/code-maturity-assessor/resources/EXAMPLE_REPORT.md +248 -0
  76. package/skills/security-building-secure-contracts/skills/code-maturity-assessor/resources/REPORT_FORMAT.md +33 -0
  77. package/skills/security-building-secure-contracts/skills/cosmos-vulnerability-scanner/SKILL.md +334 -0
  78. package/skills/security-building-secure-contracts/skills/cosmos-vulnerability-scanner/resources/VULNERABILITY_PATTERNS.md +740 -0
  79. package/skills/security-building-secure-contracts/skills/guidelines-advisor/SKILL.md +252 -0
  80. package/skills/security-building-secure-contracts/skills/guidelines-advisor/resources/ASSESSMENT_AREAS.md +329 -0
  81. package/skills/security-building-secure-contracts/skills/guidelines-advisor/resources/DELIVERABLES.md +118 -0
  82. package/skills/security-building-secure-contracts/skills/guidelines-advisor/resources/EXAMPLE_REPORT.md +298 -0
  83. package/skills/security-building-secure-contracts/skills/secure-workflow-guide/SKILL.md +161 -0
  84. package/skills/security-building-secure-contracts/skills/secure-workflow-guide/resources/EXAMPLE_REPORT.md +279 -0
  85. package/skills/security-building-secure-contracts/skills/secure-workflow-guide/resources/WORKFLOW_STEPS.md +132 -0
  86. package/skills/security-building-secure-contracts/skills/solana-vulnerability-scanner/SKILL.md +389 -0
  87. package/skills/security-building-secure-contracts/skills/solana-vulnerability-scanner/resources/VULNERABILITY_PATTERNS.md +669 -0
  88. package/skills/security-building-secure-contracts/skills/substrate-vulnerability-scanner/SKILL.md +298 -0
  89. package/skills/security-building-secure-contracts/skills/substrate-vulnerability-scanner/resources/VULNERABILITY_PATTERNS.md +791 -0
  90. package/skills/security-building-secure-contracts/skills/token-integration-analyzer/SKILL.md +362 -0
  91. package/skills/security-building-secure-contracts/skills/token-integration-analyzer/resources/ASSESSMENT_CATEGORIES.md +571 -0
  92. package/skills/security-building-secure-contracts/skills/token-integration-analyzer/resources/REPORT_TEMPLATES.md +141 -0
  93. package/skills/security-building-secure-contracts/skills/ton-vulnerability-scanner/SKILL.md +388 -0
  94. package/skills/security-building-secure-contracts/skills/ton-vulnerability-scanner/resources/VULNERABILITY_PATTERNS.md +595 -0
  95. package/skills/security-burpsuite-project-parser/.claude-plugin/plugin.json +10 -0
  96. package/skills/security-burpsuite-project-parser/README.md +103 -0
  97. package/skills/security-burpsuite-project-parser/commands/burp-search.md +18 -0
  98. package/skills/security-burpsuite-project-parser/skills/SKILL.md +358 -0
  99. package/skills/security-burpsuite-project-parser/skills/scripts/burp-search.sh +99 -0
  100. package/skills/security-claude-in-chrome-troubleshooting/.claude-plugin/plugin.json +8 -0
  101. package/skills/security-claude-in-chrome-troubleshooting/README.md +31 -0
  102. package/skills/security-claude-in-chrome-troubleshooting/skills/claude-in-chrome-troubleshooting/SKILL.md +251 -0
  103. package/skills/security-constant-time-analysis/.claude-plugin/plugin.json +9 -0
  104. package/skills/security-constant-time-analysis/README.md +381 -0
  105. package/skills/security-constant-time-analysis/commands/ct-check.md +20 -0
  106. package/skills/security-constant-time-analysis/ct_analyzer/__init__.py +49 -0
  107. package/skills/security-constant-time-analysis/ct_analyzer/analyzer.py +1284 -0
  108. package/skills/security-constant-time-analysis/ct_analyzer/script_analyzers.py +3081 -0
  109. package/skills/security-constant-time-analysis/ct_analyzer/tests/__init__.py +1 -0
  110. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_analyzer.py +1397 -0
  111. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/bn_excerpt.js +205 -0
  112. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/decompose_constant_time.c +181 -0
  113. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/decompose_vulnerable.c +74 -0
  114. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/decompose_vulnerable.go +78 -0
  115. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/decompose_vulnerable.rs +92 -0
  116. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/vulnerable.cs +174 -0
  117. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/vulnerable.java +161 -0
  118. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/vulnerable.kt +181 -0
  119. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/vulnerable.php +140 -0
  120. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/vulnerable.py +252 -0
  121. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/vulnerable.rb +188 -0
  122. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/vulnerable.swift +199 -0
  123. package/skills/security-constant-time-analysis/ct_analyzer/tests/test_samples/vulnerable.ts +154 -0
  124. package/skills/security-constant-time-analysis/pyproject.toml +52 -0
  125. package/skills/security-constant-time-analysis/skills/constant-time-analysis/README.md +90 -0
  126. package/skills/security-constant-time-analysis/skills/constant-time-analysis/SKILL.md +219 -0
  127. package/skills/security-constant-time-analysis/skills/constant-time-analysis/references/compiled.md +129 -0
  128. package/skills/security-constant-time-analysis/skills/constant-time-analysis/references/javascript.md +136 -0
  129. package/skills/security-constant-time-analysis/skills/constant-time-analysis/references/kotlin.md +252 -0
  130. package/skills/security-constant-time-analysis/skills/constant-time-analysis/references/php.md +172 -0
  131. package/skills/security-constant-time-analysis/skills/constant-time-analysis/references/python.md +179 -0
  132. package/skills/security-constant-time-analysis/skills/constant-time-analysis/references/ruby.md +198 -0
  133. package/skills/security-constant-time-analysis/skills/constant-time-analysis/references/swift.md +288 -0
  134. package/skills/security-constant-time-analysis/skills/constant-time-analysis/references/vm-compiled.md +354 -0
  135. package/skills/security-constant-time-analysis/uv.lock +8 -0
  136. package/skills/security-culture-index/.claude-plugin/plugin.json +8 -0
  137. package/skills/security-culture-index/README.md +79 -0
  138. package/skills/security-culture-index/skills/interpreting-culture-index/SKILL.md +293 -0
  139. package/skills/security-culture-index/skills/interpreting-culture-index/references/anti-patterns.md +255 -0
  140. package/skills/security-culture-index/skills/interpreting-culture-index/references/conversation-starters.md +408 -0
  141. package/skills/security-culture-index/skills/interpreting-culture-index/references/interview-trait-signals.md +253 -0
  142. package/skills/security-culture-index/skills/interpreting-culture-index/references/motivators.md +158 -0
  143. package/skills/security-culture-index/skills/interpreting-culture-index/references/patterns-archetypes.md +147 -0
  144. package/skills/security-culture-index/skills/interpreting-culture-index/references/primary-traits.md +307 -0
  145. package/skills/security-culture-index/skills/interpreting-culture-index/references/secondary-traits.md +228 -0
  146. package/skills/security-culture-index/skills/interpreting-culture-index/references/team-composition.md +148 -0
  147. package/skills/security-culture-index/skills/interpreting-culture-index/scripts/check_deps.py +108 -0
  148. package/skills/security-culture-index/skills/interpreting-culture-index/scripts/culture_index/__init__.py +20 -0
  149. package/skills/security-culture-index/skills/interpreting-culture-index/scripts/culture_index/constants.py +122 -0
  150. package/skills/security-culture-index/skills/interpreting-culture-index/scripts/culture_index/extract.py +187 -0
  151. package/skills/security-culture-index/skills/interpreting-culture-index/scripts/culture_index/models.py +16 -0
  152. package/skills/security-culture-index/skills/interpreting-culture-index/scripts/culture_index/opencv_extractor.py +520 -0
  153. package/skills/security-culture-index/skills/interpreting-culture-index/scripts/extract_pdf.py +237 -0
  154. package/skills/security-culture-index/skills/interpreting-culture-index/scripts/pyproject.toml +18 -0
  155. package/skills/security-culture-index/skills/interpreting-culture-index/templates/burnout-report.md +113 -0
  156. package/skills/security-culture-index/skills/interpreting-culture-index/templates/comparison-report.md +103 -0
  157. package/skills/security-culture-index/skills/interpreting-culture-index/templates/hiring-profile.md +127 -0
  158. package/skills/security-culture-index/skills/interpreting-culture-index/templates/individual-report.md +85 -0
  159. package/skills/security-culture-index/skills/interpreting-culture-index/templates/predicted-profile.md +165 -0
  160. package/skills/security-culture-index/skills/interpreting-culture-index/templates/team-report.md +109 -0
  161. package/skills/security-culture-index/skills/interpreting-culture-index/workflows/analyze-team.md +188 -0
  162. package/skills/security-culture-index/skills/interpreting-culture-index/workflows/coach-manager.md +267 -0
  163. package/skills/security-culture-index/skills/interpreting-culture-index/workflows/compare-profiles.md +188 -0
  164. package/skills/security-culture-index/skills/interpreting-culture-index/workflows/define-hiring-profile.md +220 -0
  165. package/skills/security-culture-index/skills/interpreting-culture-index/workflows/detect-burnout.md +206 -0
  166. package/skills/security-culture-index/skills/interpreting-culture-index/workflows/extract-from-pdf.md +121 -0
  167. package/skills/security-culture-index/skills/interpreting-culture-index/workflows/interpret-individual.md +183 -0
  168. package/skills/security-culture-index/skills/interpreting-culture-index/workflows/interview-debrief.md +234 -0
  169. package/skills/security-culture-index/skills/interpreting-culture-index/workflows/mediate-conflict.md +306 -0
  170. package/skills/security-culture-index/skills/interpreting-culture-index/workflows/plan-onboarding.md +322 -0
  171. package/skills/security-culture-index/skills/interpreting-culture-index/workflows/predict-from-interview.md +250 -0
  172. package/skills/security-differential-review/.claude-plugin/plugin.json +10 -0
  173. package/skills/security-differential-review/README.md +109 -0
  174. package/skills/security-differential-review/commands/diff-review.md +21 -0
  175. package/skills/security-differential-review/skills/differential-review/SKILL.md +220 -0
  176. package/skills/security-differential-review/skills/differential-review/adversarial.md +203 -0
  177. package/skills/security-differential-review/skills/differential-review/methodology.md +234 -0
  178. package/skills/security-differential-review/skills/differential-review/patterns.md +300 -0
  179. package/skills/security-differential-review/skills/differential-review/reporting.md +369 -0
  180. package/skills/security-dwarf-expert/.claude-plugin/plugin.json +10 -0
  181. package/skills/security-dwarf-expert/README.md +38 -0
  182. package/skills/security-dwarf-expert/skills/dwarf-expert/SKILL.md +93 -0
  183. package/skills/security-dwarf-expert/skills/dwarf-expert/reference/coding.md +31 -0
  184. package/skills/security-dwarf-expert/skills/dwarf-expert/reference/dwarfdump.md +50 -0
  185. package/skills/security-dwarf-expert/skills/dwarf-expert/reference/readelf.md +8 -0
  186. package/skills/security-entry-point-analyzer/.claude-plugin/plugin.json +10 -0
  187. package/skills/security-entry-point-analyzer/README.md +74 -0
  188. package/skills/security-entry-point-analyzer/commands/entry-points.md +18 -0
  189. package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/SKILL.md +251 -0
  190. package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/cosmwasm.md +182 -0
  191. package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/move-aptos.md +107 -0
  192. package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/move-sui.md +87 -0
  193. package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/solana.md +155 -0
  194. package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/solidity.md +135 -0
  195. package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/ton.md +185 -0
  196. package/skills/security-entry-point-analyzer/skills/entry-point-analyzer/references/vyper.md +141 -0
  197. package/skills/security-firebase-apk-scanner/.claude-plugin/plugin.json +10 -0
  198. package/skills/security-firebase-apk-scanner/README.md +85 -0
  199. package/skills/security-firebase-apk-scanner/commands/scan-apk.md +18 -0
  200. package/skills/security-firebase-apk-scanner/scanner.sh +1408 -0
  201. package/skills/security-firebase-apk-scanner/skills/firebase-apk-scanner/SKILL.md +197 -0
  202. package/skills/security-firebase-apk-scanner/skills/firebase-apk-scanner/references/vulnerabilities.md +803 -0
  203. package/skills/security-fix-review/.claude-plugin/plugin.json +13 -0
  204. package/skills/security-fix-review/README.md +118 -0
  205. package/skills/security-fix-review/commands/fix-review.md +24 -0
  206. package/skills/security-fix-review/skills/fix-review/SKILL.md +264 -0
  207. package/skills/security-fix-review/skills/fix-review/references/bug-detection.md +408 -0
  208. package/skills/security-fix-review/skills/fix-review/references/finding-matching.md +298 -0
  209. package/skills/security-fix-review/skills/fix-review/references/report-parsing.md +398 -0
  210. package/skills/security-insecure-defaults/.claude-plugin/plugin.json +10 -0
  211. package/skills/security-insecure-defaults/README.md +45 -0
  212. package/skills/security-insecure-defaults/skills/insecure-defaults/SKILL.md +117 -0
  213. package/skills/security-insecure-defaults/skills/insecure-defaults/references/examples.md +409 -0
  214. package/skills/security-modern-python/.claude-plugin/plugin.json +10 -0
  215. package/skills/security-modern-python/README.md +58 -0
  216. package/skills/security-modern-python/hooks/hooks.json +16 -0
  217. package/skills/security-modern-python/hooks/intercept-legacy-python.bats +388 -0
  218. package/skills/security-modern-python/hooks/intercept-legacy-python.sh +109 -0
  219. package/skills/security-modern-python/hooks/test_helper.bash +75 -0
  220. package/skills/security-modern-python/skills/modern-python/SKILL.md +333 -0
  221. package/skills/security-modern-python/skills/modern-python/references/dependabot.md +43 -0
  222. package/skills/security-modern-python/skills/modern-python/references/migration-checklist.md +141 -0
  223. package/skills/security-modern-python/skills/modern-python/references/pep723-scripts.md +259 -0
  224. package/skills/security-modern-python/skills/modern-python/references/prek.md +211 -0
  225. package/skills/security-modern-python/skills/modern-python/references/pyproject.md +254 -0
  226. package/skills/security-modern-python/skills/modern-python/references/ruff-config.md +240 -0
  227. package/skills/security-modern-python/skills/modern-python/references/security-setup.md +255 -0
  228. package/skills/security-modern-python/skills/modern-python/references/testing.md +284 -0
  229. package/skills/security-modern-python/skills/modern-python/references/uv-commands.md +200 -0
  230. package/skills/security-modern-python/skills/modern-python/templates/dependabot.yml +36 -0
  231. package/skills/security-modern-python/skills/modern-python/templates/pre-commit-config.yaml +66 -0
  232. package/skills/security-property-based-testing/.claude-plugin/plugin.json +9 -0
  233. package/skills/security-property-based-testing/README.md +47 -0
  234. package/skills/security-property-based-testing/skills/property-based-testing/README.md +88 -0
  235. package/skills/security-property-based-testing/skills/property-based-testing/SKILL.md +109 -0
  236. package/skills/security-property-based-testing/skills/property-based-testing/references/design.md +191 -0
  237. package/skills/security-property-based-testing/skills/property-based-testing/references/generating.md +200 -0
  238. package/skills/security-property-based-testing/skills/property-based-testing/references/libraries.md +130 -0
  239. package/skills/security-property-based-testing/skills/property-based-testing/references/refactoring.md +181 -0
  240. package/skills/security-property-based-testing/skills/property-based-testing/references/reviewing.md +209 -0
  241. package/skills/security-property-based-testing/skills/property-based-testing/references/strategies.md +124 -0
  242. package/skills/semgrep-rule-creator/.claude-plugin/plugin.json +8 -0
  243. package/skills/semgrep-rule-creator/README.md +43 -0
  244. package/skills/semgrep-rule-creator/commands/semgrep-rule.md +26 -0
  245. package/skills/semgrep-rule-creator/skills/semgrep-rule-creator/SKILL.md +168 -0
  246. package/skills/semgrep-rule-creator/skills/semgrep-rule-creator/references/quick-reference.md +203 -0
  247. package/skills/semgrep-rule-creator/skills/semgrep-rule-creator/references/workflow.md +240 -0
  248. package/skills/semgrep-rule-variant-creator/.claude-plugin/plugin.json +9 -0
  249. package/skills/semgrep-rule-variant-creator/README.md +86 -0
  250. package/skills/semgrep-rule-variant-creator/skills/semgrep-rule-variant-creator/SKILL.md +205 -0
  251. package/skills/semgrep-rule-variant-creator/skills/semgrep-rule-variant-creator/references/applicability-analysis.md +250 -0
  252. package/skills/semgrep-rule-variant-creator/skills/semgrep-rule-variant-creator/references/language-syntax-guide.md +324 -0
  253. package/skills/semgrep-rule-variant-creator/skills/semgrep-rule-variant-creator/references/workflow.md +518 -0
  254. package/skills/session-logs/SKILL.md +115 -0
  255. package/skills/sharp-edges/.claude-plugin/plugin.json +10 -0
  256. package/skills/sharp-edges/README.md +48 -0
  257. package/skills/sharp-edges/skills/sharp-edges/SKILL.md +292 -0
  258. package/skills/sharp-edges/skills/sharp-edges/references/auth-patterns.md +252 -0
  259. package/skills/sharp-edges/skills/sharp-edges/references/case-studies.md +274 -0
  260. package/skills/sharp-edges/skills/sharp-edges/references/config-patterns.md +333 -0
  261. package/skills/sharp-edges/skills/sharp-edges/references/crypto-apis.md +190 -0
  262. package/skills/sharp-edges/skills/sharp-edges/references/lang-c.md +205 -0
  263. package/skills/sharp-edges/skills/sharp-edges/references/lang-csharp.md +285 -0
  264. package/skills/sharp-edges/skills/sharp-edges/references/lang-go.md +270 -0
  265. package/skills/sharp-edges/skills/sharp-edges/references/lang-java.md +263 -0
  266. package/skills/sharp-edges/skills/sharp-edges/references/lang-javascript.md +269 -0
  267. package/skills/sharp-edges/skills/sharp-edges/references/lang-kotlin.md +265 -0
  268. package/skills/sharp-edges/skills/sharp-edges/references/lang-php.md +245 -0
  269. package/skills/sharp-edges/skills/sharp-edges/references/lang-python.md +274 -0
  270. package/skills/sharp-edges/skills/sharp-edges/references/lang-ruby.md +273 -0
  271. package/skills/sharp-edges/skills/sharp-edges/references/lang-rust.md +272 -0
  272. package/skills/sharp-edges/skills/sharp-edges/references/lang-swift.md +287 -0
  273. package/skills/sharp-edges/skills/sharp-edges/references/language-specific.md +588 -0
  274. package/skills/sherpa-onnx-tts/SKILL.md +103 -0
  275. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  276. package/skills/skill-creator/SKILL.md +370 -0
  277. package/skills/skill-creator/license.txt +202 -0
  278. package/skills/skill-creator/scripts/init_skill.py +378 -0
  279. package/skills/skill-creator/scripts/package_skill.py +111 -0
  280. package/skills/skill-creator/scripts/quick_validate.py +101 -0
  281. package/skills/slack/SKILL.md +144 -0
  282. package/skills/songsee/SKILL.md +49 -0
  283. package/skills/sonoscli/SKILL.md +46 -0
  284. package/skills/spec-to-code-compliance/.claude-plugin/plugin.json +10 -0
  285. package/skills/spec-to-code-compliance/README.md +67 -0
  286. package/skills/spec-to-code-compliance/commands/spec-compliance.md +22 -0
  287. package/skills/spec-to-code-compliance/skills/spec-to-code-compliance/SKILL.md +349 -0
  288. package/skills/spec-to-code-compliance/skills/spec-to-code-compliance/resources/COMPLETENESS_CHECKLIST.md +69 -0
  289. package/skills/spec-to-code-compliance/skills/spec-to-code-compliance/resources/IR_EXAMPLES.md +417 -0
  290. package/skills/spec-to-code-compliance/skills/spec-to-code-compliance/resources/OUTPUT_REQUIREMENTS.md +105 -0
  291. package/skills/spotify-player/SKILL.md +64 -0
  292. package/skills/static-analysis/.claude-plugin/plugin.json +8 -0
  293. package/skills/static-analysis/README.md +59 -0
  294. package/skills/static-analysis/skills/codeql/SKILL.md +315 -0
  295. package/skills/static-analysis/skills/sarif-parsing/SKILL.md +479 -0
  296. package/skills/static-analysis/skills/sarif-parsing/resources/jq-queries.md +162 -0
  297. package/skills/static-analysis/skills/sarif-parsing/resources/sarif_helpers.py +331 -0
  298. package/skills/static-analysis/skills/semgrep/SKILL.md +337 -0
  299. package/skills/summarize/SKILL.md +87 -0
  300. package/skills/testing-handbook-skills/.claude-plugin/plugin.json +8 -0
  301. package/skills/testing-handbook-skills/README.md +241 -0
  302. package/skills/testing-handbook-skills/scripts/pyproject.toml +8 -0
  303. package/skills/testing-handbook-skills/scripts/validate-skills.py +657 -0
  304. package/skills/testing-handbook-skills/skills/address-sanitizer/SKILL.md +341 -0
  305. package/skills/testing-handbook-skills/skills/aflpp/SKILL.md +640 -0
  306. package/skills/testing-handbook-skills/skills/atheris/SKILL.md +515 -0
  307. package/skills/testing-handbook-skills/skills/cargo-fuzz/SKILL.md +454 -0
  308. package/skills/testing-handbook-skills/skills/codeql/SKILL.md +549 -0
  309. package/skills/testing-handbook-skills/skills/constant-time-testing/SKILL.md +507 -0
  310. package/skills/testing-handbook-skills/skills/coverage-analysis/SKILL.md +607 -0
  311. package/skills/testing-handbook-skills/skills/fuzzing-dictionary/SKILL.md +297 -0
  312. package/skills/testing-handbook-skills/skills/fuzzing-obstacles/SKILL.md +426 -0
  313. package/skills/testing-handbook-skills/skills/harness-writing/SKILL.md +614 -0
  314. package/skills/testing-handbook-skills/skills/libafl/SKILL.md +625 -0
  315. package/skills/testing-handbook-skills/skills/libfuzzer/SKILL.md +795 -0
  316. package/skills/testing-handbook-skills/skills/ossfuzz/SKILL.md +426 -0
  317. package/skills/testing-handbook-skills/skills/ruzzy/SKILL.md +443 -0
  318. package/skills/testing-handbook-skills/skills/semgrep/SKILL.md +601 -0
  319. package/skills/testing-handbook-skills/skills/testing-handbook-generator/SKILL.md +372 -0
  320. package/skills/testing-handbook-skills/skills/testing-handbook-generator/agent-prompt.md +280 -0
  321. package/skills/testing-handbook-skills/skills/testing-handbook-generator/discovery.md +452 -0
  322. package/skills/testing-handbook-skills/skills/testing-handbook-generator/templates/domain-skill.md +504 -0
  323. package/skills/testing-handbook-skills/skills/testing-handbook-generator/templates/fuzzer-skill.md +454 -0
  324. package/skills/testing-handbook-skills/skills/testing-handbook-generator/templates/technique-skill.md +527 -0
  325. package/skills/testing-handbook-skills/skills/testing-handbook-generator/templates/tool-skill.md +366 -0
  326. package/skills/testing-handbook-skills/skills/testing-handbook-generator/testing.md +482 -0
  327. package/skills/testing-handbook-skills/skills/wycheproof/SKILL.md +533 -0
  328. package/skills/things-mac/SKILL.md +86 -0
  329. package/skills/tmux/SKILL.md +135 -0
  330. package/skills/tmux/scripts/find-sessions.sh +112 -0
  331. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  332. package/skills/trello/SKILL.md +95 -0
  333. package/skills/variant-analysis/.claude-plugin/plugin.json +8 -0
  334. package/skills/variant-analysis/README.md +41 -0
  335. package/skills/variant-analysis/commands/variants.md +23 -0
  336. package/skills/variant-analysis/skills/variant-analysis/METHODOLOGY.md +327 -0
  337. package/skills/variant-analysis/skills/variant-analysis/SKILL.md +142 -0
  338. package/skills/variant-analysis/skills/variant-analysis/resources/codeql/cpp.ql +119 -0
  339. package/skills/variant-analysis/skills/variant-analysis/resources/codeql/go.ql +69 -0
  340. package/skills/variant-analysis/skills/variant-analysis/resources/codeql/java.ql +71 -0
  341. package/skills/variant-analysis/skills/variant-analysis/resources/codeql/javascript.ql +63 -0
  342. package/skills/variant-analysis/skills/variant-analysis/resources/codeql/python.ql +80 -0
  343. package/skills/variant-analysis/skills/variant-analysis/resources/semgrep/cpp.yaml +98 -0
  344. package/skills/variant-analysis/skills/variant-analysis/resources/semgrep/go.yaml +63 -0
  345. package/skills/variant-analysis/skills/variant-analysis/resources/semgrep/java.yaml +61 -0
  346. package/skills/variant-analysis/skills/variant-analysis/resources/semgrep/javascript.yaml +60 -0
  347. package/skills/variant-analysis/skills/variant-analysis/resources/semgrep/python.yaml +72 -0
  348. package/skills/variant-analysis/skills/variant-analysis/resources/variant-report-template.md +75 -0
  349. package/skills/video-frames/SKILL.md +46 -0
  350. package/skills/video-frames/scripts/frame.sh +81 -0
  351. package/skills/voice-call/SKILL.md +45 -0
  352. package/skills/wacli/SKILL.md +72 -0
  353. package/skills/weather/SKILL.md +54 -0
  354. package/skills/yara-authoring/.claude-plugin/plugin.json +9 -0
  355. package/skills/yara-authoring/README.md +131 -0
  356. package/skills/yara-authoring/skills/yara-rule-authoring/SKILL.md +645 -0
  357. package/skills/yara-authoring/skills/yara-rule-authoring/examples/MAL_Mac_ProtonRAT_Jan25.yar +99 -0
  358. package/skills/yara-authoring/skills/yara-rule-authoring/examples/MAL_NPM_SupplyChain_Jan25.yar +170 -0
  359. package/skills/yara-authoring/skills/yara-rule-authoring/examples/MAL_Win_Remcos_Jan25.yar +103 -0
  360. package/skills/yara-authoring/skills/yara-rule-authoring/examples/SUSP_CRX_SuspiciousPermissions.yar +134 -0
  361. package/skills/yara-authoring/skills/yara-rule-authoring/examples/SUSP_JS_Obfuscation_Jan25.yar +185 -0
  362. package/skills/yara-authoring/skills/yara-rule-authoring/references/crx-module.md +214 -0
  363. package/skills/yara-authoring/skills/yara-rule-authoring/references/dex-module.md +383 -0
  364. package/skills/yara-authoring/skills/yara-rule-authoring/references/performance.md +333 -0
  365. package/skills/yara-authoring/skills/yara-rule-authoring/references/strings.md +433 -0
  366. package/skills/yara-authoring/skills/yara-rule-authoring/references/style-guide.md +257 -0
  367. package/skills/yara-authoring/skills/yara-rule-authoring/references/testing.md +399 -0
  368. package/skills/yara-authoring/skills/yara-rule-authoring/scripts/atom_analyzer.py +526 -0
  369. package/skills/yara-authoring/skills/yara-rule-authoring/scripts/pyproject.toml +25 -0
  370. package/skills/yara-authoring/skills/yara-rule-authoring/scripts/yara_lint.py +631 -0
  371. package/skills/yara-authoring/skills/yara-rule-authoring/workflows/rule-development.md +493 -0
@@ -0,0 +1,533 @@
1
+ ---
2
+ name: wycheproof
3
+ type: domain
4
+ description: >
5
+ Wycheproof provides test vectors for validating cryptographic implementations.
6
+ Use when testing crypto code for known attacks and edge cases.
7
+ ---
8
+
9
+ # Wycheproof
10
+
11
+ Wycheproof is an extensive collection of test vectors designed to verify the correctness of cryptographic implementations and test against known attacks. Originally developed by Google, it is now a community-managed project where contributors can add test vectors for specific cryptographic constructions.
12
+
13
+ ## Background
14
+
15
+ ### Key Concepts
16
+
17
+ | Concept | Description |
18
+ |---------|-------------|
19
+ | Test vector | Input/output pair for validating crypto implementation correctness |
20
+ | Test group | Collection of test vectors sharing attributes (key size, IV size, curve) |
21
+ | Result flag | Indicates if test should pass (valid), fail (invalid), or is acceptable |
22
+ | Edge case testing | Testing for known vulnerabilities and attack patterns |
23
+
24
+ ### Why This Matters
25
+
26
+ Cryptographic implementations are notoriously difficult to get right. Even small bugs can:
27
+ - Expose private keys
28
+ - Allow signature forgery
29
+ - Enable message decryption
30
+ - Create consensus problems when different implementations accept/reject the same inputs
31
+
32
+ Wycheproof has found vulnerabilities in major libraries including OpenJDK's SHA1withDSA, Bouncy Castle's ECDHC, and the elliptic npm package.
33
+
34
+ ## When to Use
35
+
36
+ **Apply Wycheproof when:**
37
+ - Testing cryptographic implementations (AES-GCM, ECDSA, ECDH, RSA, etc.)
38
+ - Validating that crypto code handles edge cases correctly
39
+ - Verifying implementations against known attack vectors
40
+ - Setting up CI/CD for cryptographic libraries
41
+ - Auditing third-party crypto code for correctness
42
+
43
+ **Consider alternatives when:**
44
+ - Testing for timing side-channels (use constant-time testing tools instead)
45
+ - Finding new unknown bugs (use fuzzing instead)
46
+ - Testing custom/experimental cryptographic algorithms (Wycheproof only covers established algorithms)
47
+
48
+ ## Quick Reference
49
+
50
+ | Scenario | Recommended Approach | Notes |
51
+ |----------|---------------------|-------|
52
+ | AES-GCM implementation | Use `aes_gcm_test.json` | 316 test vectors across 44 test groups |
53
+ | ECDSA verification | Use `ecdsa_*_test.json` for specific curves | Tests signature malleability, DER encoding |
54
+ | ECDH key exchange | Use `ecdh_*_test.json` | Tests invalid curve attacks |
55
+ | RSA signatures | Use `rsa_*_test.json` | Tests padding oracle attacks |
56
+ | ChaCha20-Poly1305 | Use `chacha20_poly1305_test.json` | Tests AEAD implementation |
57
+
58
+ ## Testing Workflow
59
+
60
+ ```
61
+ Phase 1: Setup Phase 2: Parse Test Vectors
62
+ ┌─────────────────┐ ┌─────────────────┐
63
+ │ Add Wycheproof │ → │ Load JSON file │
64
+ │ as submodule │ │ Filter by params│
65
+ └─────────────────┘ └─────────────────┘
66
+ ↓ ↓
67
+ Phase 4: CI Integration Phase 3: Write Harness
68
+ ┌─────────────────┐ ┌─────────────────┐
69
+ │ Auto-update │ ← │ Test valid & │
70
+ │ test vectors │ │ invalid cases │
71
+ └─────────────────┘ └─────────────────┘
72
+ ```
73
+
74
+ ## Repository Structure
75
+
76
+ The Wycheproof repository is organized as follows:
77
+
78
+ ```text
79
+ ┣ 📜 README.md : Project overview
80
+ ┣ 📂 doc : Documentation
81
+ ┣ 📂 java : Java JCE interface testing harness
82
+ ┣ 📂 javascript : JavaScript testing harness
83
+ ┣ 📂 schemas : Test vector schemas
84
+ ┣ 📂 testvectors : Test vectors
85
+ ┗ 📂 testvectors_v1 : Updated test vectors (more detailed)
86
+ ```
87
+
88
+ The essential folders are `testvectors` and `testvectors_v1`. While both contain similar files, `testvectors_v1` includes more detailed information and is recommended for new integrations.
89
+
90
+ ## Supported Algorithms
91
+
92
+ Wycheproof provides test vectors for a wide range of cryptographic algorithms:
93
+
94
+ | Category | Algorithms |
95
+ |----------|------------|
96
+ | **Symmetric Encryption** | AES-GCM, AES-EAX, ChaCha20-Poly1305 |
97
+ | **Signatures** | ECDSA, EdDSA, RSA-PSS, RSA-PKCS1 |
98
+ | **Key Exchange** | ECDH, X25519, X448 |
99
+ | **Hashing** | HMAC, HKDF |
100
+ | **Curves** | secp256k1, secp256r1, secp384r1, secp521r1, ed25519, ed448 |
101
+
102
+ ## Test File Structure
103
+
104
+ Each JSON test file tests a specific cryptographic construction. All test files share common attributes:
105
+
106
+ ```json
107
+ "algorithm" : The name of the algorithm tested
108
+ "schema" : The JSON schema (found in schemas folder)
109
+ "generatorVersion" : The version number
110
+ "numberOfTests" : The total number of test vectors in this file
111
+ "header" : Detailed description of test vectors
112
+ "notes" : In-depth explanation of flags in test vectors
113
+ "testGroups" : Array of one or multiple test groups
114
+ ```
115
+
116
+ ### Test Groups
117
+
118
+ Test groups group sets of tests based on shared attributes such as:
119
+ - Key sizes
120
+ - IV sizes
121
+ - Public keys
122
+ - Curves
123
+
124
+ This classification allows extracting tests that meet specific criteria relevant to the construction being tested.
125
+
126
+ ### Test Vector Attributes
127
+
128
+ #### Shared Attributes
129
+
130
+ All test vectors contain four common fields:
131
+
132
+ - **tcId**: Unique identifier for the test vector within a file
133
+ - **comment**: Additional information about the test case
134
+ - **flags**: Descriptions of specific test case types and potential dangers (referenced in `notes` field)
135
+ - **result**: Expected outcome of the test
136
+
137
+ The `result` field can take three values:
138
+
139
+ | Result | Meaning |
140
+ |--------|---------|
141
+ | **valid** | Test case should succeed |
142
+ | **acceptable** | Test case is allowed to succeed but contains non-ideal attributes |
143
+ | **invalid** | Test case should fail |
144
+
145
+ #### Unique Attributes
146
+
147
+ Unique attributes are specific to the algorithm being tested:
148
+
149
+ | Algorithm | Unique Attributes |
150
+ |-----------|-------------------|
151
+ | AES-GCM | `key`, `iv`, `aad`, `msg`, `ct`, `tag` |
152
+ | ECDH secp256k1 | `public`, `private`, `shared` |
153
+ | ECDSA | `msg`, `sig`, `result` |
154
+ | EdDSA | `msg`, `sig`, `pk` |
155
+
156
+ ## Implementation Guide
157
+
158
+ ### Phase 1: Add Wycheproof to Your Project
159
+
160
+ **Option 1: Git Submodule (Recommended)**
161
+
162
+ Adding Wycheproof as a git submodule ensures automatic updates:
163
+
164
+ ```bash
165
+ git submodule add https://github.com/C2SP/wycheproof.git
166
+ ```
167
+
168
+ **Option 2: Fetch Specific Test Vectors**
169
+
170
+ If submodules aren't possible, fetch specific JSON files:
171
+
172
+ ```bash
173
+ #!/bin/bash
174
+
175
+ TMP_WYCHEPROOF_FOLDER=".wycheproof/"
176
+ TEST_VECTORS=('aes_gcm_test.json' 'aes_eax_test.json')
177
+ BASE_URL="https://raw.githubusercontent.com/C2SP/wycheproof/master/testvectors_v1/"
178
+
179
+ # Create wycheproof folder
180
+ mkdir -p $TMP_WYCHEPROOF_FOLDER
181
+
182
+ # Request all test vector files if they don't exist
183
+ for i in "${TEST_VECTORS[@]}"; do
184
+ if [ ! -f "${TMP_WYCHEPROOF_FOLDER}${i}" ]; then
185
+ curl -o "${TMP_WYCHEPROOF_FOLDER}${i}" "${BASE_URL}${i}"
186
+ if [ $? -ne 0 ]; then
187
+ echo "Failed to download ${i}"
188
+ exit 1
189
+ fi
190
+ fi
191
+ done
192
+ ```
193
+
194
+ ### Phase 2: Parse Test Vectors
195
+
196
+ Identify the test file for your algorithm and parse the JSON:
197
+
198
+ **Python Example:**
199
+
200
+ ```python
201
+ import json
202
+
203
+ def load_wycheproof_test_vectors(path: str):
204
+ testVectors = []
205
+ try:
206
+ with open(path, "r") as f:
207
+ wycheproof_json = json.loads(f.read())
208
+ except FileNotFoundError:
209
+ print(f"No Wycheproof file found at: {path}")
210
+ return testVectors
211
+
212
+ # Attributes that need hex-to-bytes conversion
213
+ convert_attr = {"key", "aad", "iv", "msg", "ct", "tag"}
214
+
215
+ for testGroup in wycheproof_json["testGroups"]:
216
+ # Filter test groups based on implementation constraints
217
+ if testGroup["ivSize"] < 64 or testGroup["ivSize"] > 1024:
218
+ continue
219
+
220
+ for tv in testGroup["tests"]:
221
+ # Convert hex strings to bytes
222
+ for attr in convert_attr:
223
+ if attr in tv:
224
+ tv[attr] = bytes.fromhex(tv[attr])
225
+ testVectors.append(tv)
226
+
227
+ return testVectors
228
+ ```
229
+
230
+ **JavaScript Example:**
231
+
232
+ ```javascript
233
+ const fs = require('fs').promises;
234
+
235
+ async function loadWycheproofTestVectors(path) {
236
+ const tests = [];
237
+
238
+ try {
239
+ const fileContent = await fs.readFile(path);
240
+ const data = JSON.parse(fileContent.toString());
241
+
242
+ data.testGroups.forEach(testGroup => {
243
+ testGroup.tests.forEach(test => {
244
+ // Add shared test group properties to each test
245
+ test['pk'] = testGroup.publicKey.pk;
246
+ tests.push(test);
247
+ });
248
+ });
249
+ } catch (err) {
250
+ console.error('Error reading or parsing file:', err);
251
+ throw err;
252
+ }
253
+
254
+ return tests;
255
+ }
256
+ ```
257
+
258
+ ### Phase 3: Write Testing Harness
259
+
260
+ Create test functions that handle both valid and invalid test cases.
261
+
262
+ **Python/pytest Example:**
263
+
264
+ ```python
265
+ import pytest
266
+ from cryptography.hazmat.primitives.ciphers.aead import AESGCM
267
+
268
+ tvs = load_wycheproof_test_vectors("wycheproof/testvectors_v1/aes_gcm_test.json")
269
+
270
+ @pytest.mark.parametrize("tv", tvs, ids=[str(tv['tcId']) for tv in tvs])
271
+ def test_encryption(tv):
272
+ try:
273
+ aesgcm = AESGCM(tv['key'])
274
+ ct = aesgcm.encrypt(tv['iv'], tv['msg'], tv['aad'])
275
+ except ValueError as e:
276
+ # Implementation raised error - verify test was expected to fail
277
+ assert tv['result'] != 'valid', tv['comment']
278
+ return
279
+
280
+ if tv['result'] == 'valid':
281
+ assert ct[:-16] == tv['ct'], f"Ciphertext mismatch: {tv['comment']}"
282
+ assert ct[-16:] == tv['tag'], f"Tag mismatch: {tv['comment']}"
283
+ elif tv['result'] == 'invalid' or tv['result'] == 'acceptable':
284
+ assert ct[:-16] != tv['ct'] or ct[-16:] != tv['tag']
285
+
286
+ @pytest.mark.parametrize("tv", tvs, ids=[str(tv['tcId']) for tv in tvs])
287
+ def test_decryption(tv):
288
+ try:
289
+ aesgcm = AESGCM(tv['key'])
290
+ decrypted_msg = aesgcm.decrypt(tv['iv'], tv['ct'] + tv['tag'], tv['aad'])
291
+ except ValueError:
292
+ assert tv['result'] != 'valid', tv['comment']
293
+ return
294
+ except InvalidTag:
295
+ assert tv['result'] != 'valid', tv['comment']
296
+ assert 'ModifiedTag' in tv['flags'], f"Expected 'ModifiedTag' flag: {tv['comment']}"
297
+ return
298
+
299
+ assert tv['result'] == 'valid', f"No invalid test case should pass: {tv['comment']}"
300
+ assert decrypted_msg == tv['msg'], f"Decryption mismatch: {tv['comment']}"
301
+ ```
302
+
303
+ **JavaScript/Mocha Example:**
304
+
305
+ ```javascript
306
+ const assert = require('assert');
307
+
308
+ function testFactory(tcId, tests) {
309
+ it(`[${tcId + 1}] ${tests[tcId].comment}`, function () {
310
+ const test = tests[tcId];
311
+ const ed25519 = new eddsa('ed25519');
312
+ const key = ed25519.keyFromPublic(toArray(test.pk, 'hex'));
313
+
314
+ let sig;
315
+ if (test.result === 'valid') {
316
+ sig = key.verify(test.msg, test.sig);
317
+ assert.equal(sig, true, `[${test.tcId}] ${test.comment}`);
318
+ } else if (test.result === 'invalid') {
319
+ try {
320
+ sig = key.verify(test.msg, test.sig);
321
+ } catch (err) {
322
+ // Point could not be decoded
323
+ sig = false;
324
+ }
325
+ assert.equal(sig, false, `[${test.tcId}] ${test.comment}`);
326
+ }
327
+ });
328
+ }
329
+
330
+ // Generate tests for all test vectors
331
+ for (var tcId = 0; tcId < tests.length; tcId++) {
332
+ testFactory(tcId, tests);
333
+ }
334
+ ```
335
+
336
+ ### Phase 4: CI Integration
337
+
338
+ Ensure test vectors stay up to date by:
339
+
340
+ 1. **Using git submodules**: Update submodule in CI before running tests
341
+ 2. **Fetching latest vectors**: Run fetch script before test execution
342
+ 3. **Scheduled updates**: Set up weekly/monthly updates to catch new test vectors
343
+
344
+ ## Common Vulnerabilities Detected
345
+
346
+ Wycheproof test vectors are designed to catch specific vulnerability patterns:
347
+
348
+ | Vulnerability | Description | Affected Algorithms | Example CVE |
349
+ |---------------|-------------|---------------------|-------------|
350
+ | Signature malleability | Multiple valid signatures for same message | ECDSA, EdDSA | CVE-2024-42459 |
351
+ | Invalid DER encoding | Accepting non-canonical DER signatures | ECDSA | CVE-2024-42460, CVE-2024-42461 |
352
+ | Invalid curve attacks | ECDH with invalid curve points | ECDH | Common in many libraries |
353
+ | Padding oracle | Timing leaks in padding validation | RSA-PKCS1 | Historical OpenSSL issues |
354
+ | Tag forgery | Accepting modified authentication tags | AES-GCM, ChaCha20-Poly1305 | Various implementations |
355
+
356
+ ### Signature Malleability: Deep Dive
357
+
358
+ **Problem:** Implementations that don't validate signature encoding can accept multiple valid signatures for the same message.
359
+
360
+ **Example (EdDSA):** Appending or removing zeros from signature:
361
+ ```text
362
+ Valid signature: ...6a5c51eb6f946b30d
363
+ Invalid signature: ...6a5c51eb6f946b30d0000 (should be rejected)
364
+ ```
365
+
366
+ **How to detect:**
367
+ ```python
368
+ # Add signature length check
369
+ if len(sig) != 128: # EdDSA signatures must be exactly 64 bytes (128 hex chars)
370
+ return False
371
+ ```
372
+
373
+ **Impact:** Can lead to consensus problems when different implementations accept/reject the same signatures.
374
+
375
+ **Related Wycheproof tests:**
376
+ - EdDSA: tcId 37 - "removing 0 byte from signature"
377
+ - ECDSA: tcId 06 - "Legacy: ASN encoding of r misses leading 0"
378
+
379
+ ## Case Study: Elliptic npm Package
380
+
381
+ This case study demonstrates how Wycheproof found three CVEs in the popular elliptic npm package (3000+ dependents, millions of weekly downloads).
382
+
383
+ ### Overview
384
+
385
+ The [elliptic](https://www.npmjs.com/package/elliptic) library is an elliptic-curve cryptography library written in JavaScript, supporting ECDH, ECDSA, and EdDSA. Using Wycheproof test vectors on version 6.5.6 revealed multiple vulnerabilities:
386
+
387
+ - **CVE-2024-42459**: EdDSA signature malleability (appending/removing zeros)
388
+ - **CVE-2024-42460**: ECDSA DER encoding - invalid bit placement
389
+ - **CVE-2024-42461**: ECDSA DER encoding - leading zero in length field
390
+
391
+ ### Methodology
392
+
393
+ 1. **Identify supported curves**: ed25519 for EdDSA
394
+ 2. **Find test vectors**: `testvectors_v1/ed25519_test.json`
395
+ 3. **Parse test vectors**: Load JSON and extract tests
396
+ 4. **Write test harness**: Create parameterized tests
397
+ 5. **Run tests**: Identify failures
398
+ 6. **Analyze root causes**: Examine implementation code
399
+ 7. **Propose fixes**: Add validation checks
400
+
401
+ ### Key Findings
402
+
403
+ **EdDSA Issue (CVE-2024-42459):**
404
+ - Missing signature length validation
405
+ - Allowed trailing zeros in signatures
406
+ - Fix: Add `if(sig.length !== 128) return false;`
407
+
408
+ **ECDSA Issue 1 (CVE-2024-42460):**
409
+ - Missing check for first bit being zero in DER-encoded r and s values
410
+ - Fix: Add `if ((data[p.place] & 128) !== 0) return false;`
411
+
412
+ **ECDSA Issue 2 (CVE-2024-42461):**
413
+ - DER length field accepted leading zeros
414
+ - Fix: Add `if(buf[p.place] === 0x00) return false;`
415
+
416
+ ### Impact
417
+
418
+ All three vulnerabilities allowed multiple valid signatures for a single message, leading to consensus problems across implementations.
419
+
420
+ **Lessons learned:**
421
+ - Wycheproof catches subtle encoding bugs
422
+ - Reusable test harnesses pay dividends
423
+ - Test vector comments and flags help diagnose issues
424
+ - Even popular libraries benefit from systematic test vector validation
425
+
426
+ ## Advanced Usage
427
+
428
+ ### Tips and Tricks
429
+
430
+ | Tip | Why It Helps |
431
+ |-----|--------------|
432
+ | Filter test groups by parameters | Focus on test vectors relevant to your implementation constraints |
433
+ | Use test vector flags | Understand specific vulnerability patterns being tested |
434
+ | Check the `notes` field | Get detailed explanations of flag meanings |
435
+ | Test both encrypt/decrypt and sign/verify | Ensure bidirectional correctness |
436
+ | Run tests in CI | Catch regressions and benefit from new test vectors |
437
+ | Use parameterized tests | Get clear failure messages with tcId and comment |
438
+
439
+ ### Common Mistakes
440
+
441
+ | Mistake | Why It's Wrong | Correct Approach |
442
+ |---------|----------------|------------------|
443
+ | Only testing valid cases | Misses vulnerabilities where invalid inputs are accepted | Test all result types: valid, invalid, acceptable |
444
+ | Ignoring "acceptable" result | Implementation might have subtle bugs | Treat acceptable as warnings worth investigating |
445
+ | Not filtering test groups | Wastes time on unsupported parameters | Filter by keySize, ivSize, etc. based on your implementation |
446
+ | Not updating test vectors | Miss new vulnerability patterns | Use submodules or scheduled fetches |
447
+ | Testing only one direction | Encrypt/sign might work but decrypt/verify fails | Test both operations |
448
+
449
+ ## Related Skills
450
+
451
+ ### Tool Skills
452
+
453
+ | Skill | Primary Use in Wycheproof Testing |
454
+ |-------|-----------------------------------|
455
+ | **pytest** | Python testing framework for parameterized tests |
456
+ | **mocha** | JavaScript testing framework for test generation |
457
+ | **constant-time-testing** | Complement Wycheproof with timing side-channel testing |
458
+ | **cryptofuzz** | Fuzz-based crypto testing to find additional bugs |
459
+
460
+ ### Technique Skills
461
+
462
+ | Skill | When to Apply |
463
+ |-------|---------------|
464
+ | **coverage-analysis** | Ensure test vectors cover all code paths in crypto implementation |
465
+ | **property-based-testing** | Test mathematical properties (e.g., encrypt/decrypt round-trip) |
466
+ | **fuzz-harness-writing** | Create harnesses for crypto parsers (complements Wycheproof) |
467
+
468
+ ### Related Domain Skills
469
+
470
+ | Skill | Relationship |
471
+ |-------|--------------|
472
+ | **crypto-testing** | Wycheproof is a key tool in comprehensive crypto testing methodology |
473
+ | **fuzzing** | Use fuzzing to find bugs Wycheproof doesn't cover (new edge cases) |
474
+
475
+ ## Skill Dependency Map
476
+
477
+ ```
478
+ ┌─────────────────────┐
479
+ │ wycheproof │
480
+ │ (this skill) │
481
+ └──────────┬──────────┘
482
+
483
+ ┌───────────────────┼───────────────────┐
484
+ │ │ │
485
+ ▼ ▼ ▼
486
+ ┌─────────────────┐ ┌─────────────────┐ ┌─────────────────┐
487
+ │ pytest/mocha │ │ constant-time │ │ cryptofuzz │
488
+ │ (test framework)│ │ testing │ │ (fuzzing) │
489
+ └────────┬────────┘ └────────┬────────┘ └────────┬────────┘
490
+ │ │ │
491
+ └───────────────────┼───────────────────┘
492
+
493
+
494
+ ┌──────────────────────────┐
495
+ │ Technique Skills │
496
+ │ coverage, harness, PBT │
497
+ └──────────────────────────┘
498
+ ```
499
+
500
+ ## Resources
501
+
502
+ ### Official Repository
503
+
504
+ **[Wycheproof GitHub Repository](https://github.com/C2SP/wycheproof)**
505
+
506
+ The official repository contains:
507
+ - All test vectors in `testvectors/` and `testvectors_v1/`
508
+ - JSON schemas in `schemas/`
509
+ - Reference implementations in Java and JavaScript
510
+ - Documentation in `doc/`
511
+
512
+ ### Real-World Examples
513
+
514
+ **[pycryptodome](https://pypi.org/project/pycryptodome/)**
515
+
516
+ The pycryptodome library integrates Wycheproof test vectors in their test suite, demonstrating best practices for Python crypto implementations.
517
+
518
+ ### Community Resources
519
+
520
+ - [C2SP Community](https://c2sp.org/) - Cryptographic specifications and standards community maintaining Wycheproof
521
+ - Wycheproof issues tracker - Report bugs in test vectors or suggest new constructions
522
+
523
+ ## Summary
524
+
525
+ Wycheproof is an essential tool for validating cryptographic implementations against known attack vectors and edge cases. By integrating Wycheproof test vectors into your testing workflow:
526
+
527
+ 1. Catch subtle encoding and validation bugs
528
+ 2. Prevent signature malleability issues
529
+ 3. Ensure consistent behavior across implementations
530
+ 4. Benefit from community-contributed test vectors
531
+ 5. Protect against known cryptographic vulnerabilities
532
+
533
+ The investment in writing a reusable testing harness pays dividends through continuous validation as new test vectors are added to the Wycheproof repository.
@@ -0,0 +1,86 @@
1
+ ---
2
+ name: things-mac
3
+ description: Manage Things 3 via the `things` CLI on macOS (add/update projects+todos via URL scheme; read/search/list from the local Things database). Use when a user asks Otto to add a task to Things, list inbox/today/upcoming, search tasks, or inspect projects/areas/tags.
4
+ homepage: https://github.com/ossianhempel/things3-cli
5
+ metadata:
6
+ {
7
+ "otto":
8
+ {
9
+ "emoji": "✅",
10
+ "os": ["darwin"],
11
+ "requires": { "bins": ["things"] },
12
+ "install":
13
+ [
14
+ {
15
+ "id": "go",
16
+ "kind": "go",
17
+ "module": "github.com/ossianhempel/things3-cli/cmd/things@latest",
18
+ "bins": ["things"],
19
+ "label": "Install things3-cli (go)",
20
+ },
21
+ ],
22
+ },
23
+ }
24
+ ---
25
+
26
+ # Things 3 CLI
27
+
28
+ Use `things` to read your local Things database (inbox/today/search/projects/areas/tags) and to add/update todos via the Things URL scheme.
29
+
30
+ Setup
31
+
32
+ - Install (recommended, Apple Silicon): `GOBIN=/opt/homebrew/bin go install github.com/ossianhempel/things3-cli/cmd/things@latest`
33
+ - If DB reads fail: grant **Full Disk Access** to the calling app (Terminal for manual runs; `Otto.app` for gateway runs).
34
+ - Optional: set `THINGSDB` (or pass `--db`) to point at your `ThingsData-*` folder.
35
+ - Optional: set `THINGS_AUTH_TOKEN` to avoid passing `--auth-token` for update ops.
36
+
37
+ Read-only (DB)
38
+
39
+ - `things inbox --limit 50`
40
+ - `things today`
41
+ - `things upcoming`
42
+ - `things search "query"`
43
+ - `things projects` / `things areas` / `things tags`
44
+
45
+ Write (URL scheme)
46
+
47
+ - Prefer safe preview: `things --dry-run add "Title"`
48
+ - Add: `things add "Title" --notes "..." --when today --deadline 2026-01-02`
49
+ - Bring Things to front: `things --foreground add "Title"`
50
+
51
+ Examples: add a todo
52
+
53
+ - Basic: `things add "Buy milk"`
54
+ - With notes: `things add "Buy milk" --notes "2% + bananas"`
55
+ - Into a project/area: `things add "Book flights" --list "Travel"`
56
+ - Into a project heading: `things add "Pack charger" --list "Travel" --heading "Before"`
57
+ - With tags: `things add "Call dentist" --tags "health,phone"`
58
+ - Checklist: `things add "Trip prep" --checklist-item "Passport" --checklist-item "Tickets"`
59
+ - From STDIN (multi-line => title + notes):
60
+ - `cat <<'EOF' | things add -`
61
+ - `Title line`
62
+ - `Notes line 1`
63
+ - `Notes line 2`
64
+ - `EOF`
65
+
66
+ Examples: modify a todo (needs auth token)
67
+
68
+ - First: get the ID (UUID column): `things search "milk" --limit 5`
69
+ - Auth: set `THINGS_AUTH_TOKEN` or pass `--auth-token <TOKEN>`
70
+ - Title: `things update --id <UUID> --auth-token <TOKEN> "New title"`
71
+ - Notes replace: `things update --id <UUID> --auth-token <TOKEN> --notes "New notes"`
72
+ - Notes append/prepend: `things update --id <UUID> --auth-token <TOKEN> --append-notes "..."` / `--prepend-notes "..."`
73
+ - Move lists: `things update --id <UUID> --auth-token <TOKEN> --list "Travel" --heading "Before"`
74
+ - Tags replace/add: `things update --id <UUID> --auth-token <TOKEN> --tags "a,b"` / `things update --id <UUID> --auth-token <TOKEN> --add-tags "a,b"`
75
+ - Complete/cancel (soft-delete-ish): `things update --id <UUID> --auth-token <TOKEN> --completed` / `--canceled`
76
+ - Safe preview: `things --dry-run update --id <UUID> --auth-token <TOKEN> --completed`
77
+
78
+ Delete a todo?
79
+
80
+ - Not supported by `things3-cli` right now (no “delete/move-to-trash” write command; `things trash` is read-only listing).
81
+ - Options: use Things UI to delete/trash, or mark as `--completed` / `--canceled` via `things update`.
82
+
83
+ Notes
84
+
85
+ - macOS-only.
86
+ - `--dry-run` prints the URL and does not open Things.