@heytherevibin/skillforge 0.2.1

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 (402) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/CODE_OF_CONDUCT.md +34 -0
  3. package/CONTRIBUTING.md +38 -0
  4. package/LICENSE +21 -0
  5. package/README.md +337 -0
  6. package/RELEASING.md +93 -0
  7. package/SECURITY.md +31 -0
  8. package/STRATEGY.md +26 -0
  9. package/bin/cli.js +547 -0
  10. package/lib/packs.js +184 -0
  11. package/package.json +38 -0
  12. package/python/app/__init__.py +0 -0
  13. package/python/app/__pycache__/__init__.cpython-312.pyc +0 -0
  14. package/python/app/__pycache__/auth.cpython-312.pyc +0 -0
  15. package/python/app/__pycache__/main.cpython-312.pyc +0 -0
  16. package/python/app/auth.py +63 -0
  17. package/python/app/cli.py +78 -0
  18. package/python/app/db_paths.py +26 -0
  19. package/python/app/events_cli.py +175 -0
  20. package/python/app/main.py +647 -0
  21. package/python/app/materialize.py +138 -0
  22. package/python/app/mcp_server.py +610 -0
  23. package/python/app/route_cli.py +117 -0
  24. package/python/requirements-dev.txt +1 -0
  25. package/python/requirements.txt +7 -0
  26. package/python/tests/test_db_paths.py +41 -0
  27. package/skills/accessibility/SKILL.md +145 -0
  28. package/skills/agent-architecture-audit/SKILL.md +256 -0
  29. package/skills/agent-eval/SKILL.md +144 -0
  30. package/skills/agent-harness-construction/SKILL.md +72 -0
  31. package/skills/agent-introspection-debugging/SKILL.md +152 -0
  32. package/skills/agent-payment-x402/SKILL.md +224 -0
  33. package/skills/agent-sort/SKILL.md +214 -0
  34. package/skills/agentic-engineering/SKILL.md +62 -0
  35. package/skills/agentic-os/SKILL.md +386 -0
  36. package/skills/ai-first-engineering/SKILL.md +50 -0
  37. package/skills/ai-regression-testing/SKILL.md +384 -0
  38. package/skills/android-clean-architecture/SKILL.md +338 -0
  39. package/skills/angular-developer/SKILL.md +153 -0
  40. package/skills/angular-developer/references/angular-animations.md +160 -0
  41. package/skills/angular-developer/references/angular-aria.md +410 -0
  42. package/skills/angular-developer/references/cli.md +86 -0
  43. package/skills/angular-developer/references/component-harnesses.md +59 -0
  44. package/skills/angular-developer/references/component-styling.md +91 -0
  45. package/skills/angular-developer/references/components.md +117 -0
  46. package/skills/angular-developer/references/creating-services.md +97 -0
  47. package/skills/angular-developer/references/data-resolvers.md +69 -0
  48. package/skills/angular-developer/references/define-routes.md +67 -0
  49. package/skills/angular-developer/references/defining-providers.md +72 -0
  50. package/skills/angular-developer/references/di-fundamentals.md +120 -0
  51. package/skills/angular-developer/references/e2e-testing.md +56 -0
  52. package/skills/angular-developer/references/effects.md +83 -0
  53. package/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  54. package/skills/angular-developer/references/host-elements.md +80 -0
  55. package/skills/angular-developer/references/injection-context.md +63 -0
  56. package/skills/angular-developer/references/inputs.md +101 -0
  57. package/skills/angular-developer/references/linked-signal.md +59 -0
  58. package/skills/angular-developer/references/loading-strategies.md +61 -0
  59. package/skills/angular-developer/references/mcp.md +108 -0
  60. package/skills/angular-developer/references/navigate-to-routes.md +69 -0
  61. package/skills/angular-developer/references/outputs.md +86 -0
  62. package/skills/angular-developer/references/reactive-forms.md +122 -0
  63. package/skills/angular-developer/references/rendering-strategies.md +44 -0
  64. package/skills/angular-developer/references/resource.md +77 -0
  65. package/skills/angular-developer/references/route-animations.md +56 -0
  66. package/skills/angular-developer/references/route-guards.md +52 -0
  67. package/skills/angular-developer/references/router-lifecycle.md +45 -0
  68. package/skills/angular-developer/references/router-testing.md +87 -0
  69. package/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  70. package/skills/angular-developer/references/signal-forms.md +795 -0
  71. package/skills/angular-developer/references/signals-overview.md +94 -0
  72. package/skills/angular-developer/references/tailwind-css.md +69 -0
  73. package/skills/angular-developer/references/template-driven-forms.md +114 -0
  74. package/skills/angular-developer/references/testing-fundamentals.md +65 -0
  75. package/skills/api-connector-builder/SKILL.md +120 -0
  76. package/skills/api-design/SKILL.md +522 -0
  77. package/skills/architecture-decision-records/SKILL.md +178 -0
  78. package/skills/article-writing/SKILL.md +78 -0
  79. package/skills/automation-audit-ops/SKILL.md +141 -0
  80. package/skills/autonomous-agent-harness/SKILL.md +272 -0
  81. package/skills/autonomous-loops/SKILL.md +609 -0
  82. package/skills/backend-patterns/SKILL.md +560 -0
  83. package/skills/benchmark/SKILL.md +92 -0
  84. package/skills/blueprint/SKILL.md +104 -0
  85. package/skills/browser-qa/SKILL.md +86 -0
  86. package/skills/bun-runtime/SKILL.md +83 -0
  87. package/skills/canary-watch/SKILL.md +98 -0
  88. package/skills/carrier-relationship-management/SKILL.md +211 -0
  89. package/skills/cisco-ios-patterns/SKILL.md +163 -0
  90. package/skills/ck/SKILL.md +147 -0
  91. package/skills/ck/commands/forget.mjs +44 -0
  92. package/skills/ck/commands/info.mjs +24 -0
  93. package/skills/ck/commands/init.mjs +143 -0
  94. package/skills/ck/commands/list.mjs +40 -0
  95. package/skills/ck/commands/migrate.mjs +202 -0
  96. package/skills/ck/commands/resume.mjs +36 -0
  97. package/skills/ck/commands/save.mjs +210 -0
  98. package/skills/ck/commands/shared.mjs +387 -0
  99. package/skills/ck/hooks/session-start.mjs +224 -0
  100. package/skills/claude-devfleet/SKILL.md +103 -0
  101. package/skills/click-path-audit/SKILL.md +244 -0
  102. package/skills/clickhouse-io/SKILL.md +438 -0
  103. package/skills/code-tour/SKILL.md +235 -0
  104. package/skills/codebase-onboarding/SKILL.md +232 -0
  105. package/skills/coding-standards/SKILL.md +548 -0
  106. package/skills/compose-multiplatform-patterns/SKILL.md +298 -0
  107. package/skills/connections-optimizer/SKILL.md +188 -0
  108. package/skills/content-engine/SKILL.md +126 -0
  109. package/skills/content-hash-cache-pattern/SKILL.md +160 -0
  110. package/skills/context-budget/SKILL.md +134 -0
  111. package/skills/continuous-agent-loop/SKILL.md +44 -0
  112. package/skills/continuous-learning/SKILL.md +129 -0
  113. package/skills/continuous-learning/config.json +18 -0
  114. package/skills/continuous-learning/evaluate-session.sh +69 -0
  115. package/skills/continuous-learning-v2/SKILL.md +358 -0
  116. package/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
  117. package/skills/continuous-learning-v2/agents/observer.md +198 -0
  118. package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  119. package/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  120. package/skills/continuous-learning-v2/config.json +8 -0
  121. package/skills/continuous-learning-v2/hooks/observe.sh +476 -0
  122. package/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
  123. package/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
  124. package/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  125. package/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
  126. package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
  127. package/skills/cost-aware-llm-pipeline/SKILL.md +182 -0
  128. package/skills/cost-tracking/SKILL.md +147 -0
  129. package/skills/council/SKILL.md +202 -0
  130. package/skills/cpp-coding-standards/SKILL.md +722 -0
  131. package/skills/cpp-testing/SKILL.md +323 -0
  132. package/skills/crosspost/SKILL.md +110 -0
  133. package/skills/csharp-testing/SKILL.md +320 -0
  134. package/skills/customer-billing-ops/SKILL.md +139 -0
  135. package/skills/customs-trade-compliance/SKILL.md +262 -0
  136. package/skills/dart-flutter-patterns/SKILL.md +562 -0
  137. package/skills/dashboard-builder/SKILL.md +108 -0
  138. package/skills/data-scraper-agent/SKILL.md +764 -0
  139. package/skills/database-migrations/SKILL.md +428 -0
  140. package/skills/deep-research/SKILL.md +158 -0
  141. package/skills/defi-amm-security/SKILL.md +166 -0
  142. package/skills/deployment-patterns/SKILL.md +426 -0
  143. package/skills/design-system/SKILL.md +81 -0
  144. package/skills/django-celery/SKILL.md +456 -0
  145. package/skills/django-patterns/SKILL.md +733 -0
  146. package/skills/django-security/SKILL.md +592 -0
  147. package/skills/django-tdd/SKILL.md +728 -0
  148. package/skills/django-verification/SKILL.md +468 -0
  149. package/skills/dmux-workflows/SKILL.md +190 -0
  150. package/skills/docker-patterns/SKILL.md +363 -0
  151. package/skills/documentation-lookup/SKILL.md +89 -0
  152. package/skills/dotnet-patterns/SKILL.md +320 -0
  153. package/skills/e2e-testing/SKILL.md +325 -0
  154. package/skills/email-ops/SKILL.md +120 -0
  155. package/skills/energy-procurement/SKILL.md +227 -0
  156. package/skills/enterprise-agent-ops/SKILL.md +49 -0
  157. package/skills/error-handling/SKILL.md +375 -0
  158. package/skills/eval-harness/SKILL.md +269 -0
  159. package/skills/evm-token-decimals/SKILL.md +130 -0
  160. package/skills/exa-search/SKILL.md +106 -0
  161. package/skills/fal-ai-media/SKILL.md +287 -0
  162. package/skills/fastapi-patterns/SKILL.md +327 -0
  163. package/skills/finance-billing-ops/SKILL.md +126 -0
  164. package/skills/flox-environments/SKILL.md +496 -0
  165. package/skills/flutter-dart-code-review/SKILL.md +434 -0
  166. package/skills/foundation-models-on-device/SKILL.md +243 -0
  167. package/skills/frontend-design-direction/SKILL.md +92 -0
  168. package/skills/frontend-patterns/SKILL.md +641 -0
  169. package/skills/frontend-slides/SKILL.md +183 -0
  170. package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  171. package/skills/frontend-slides/animation-patterns.md +122 -0
  172. package/skills/frontend-slides/html-template.md +419 -0
  173. package/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  174. package/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  175. package/skills/frontend-slides/viewport-base.css +153 -0
  176. package/skills/fsharp-testing/SKILL.md +279 -0
  177. package/skills/gan-style-harness/SKILL.md +278 -0
  178. package/skills/gateguard/SKILL.md +125 -0
  179. package/skills/git-workflow/SKILL.md +714 -0
  180. package/skills/github-ops/SKILL.md +143 -0
  181. package/skills/golang-patterns/SKILL.md +673 -0
  182. package/skills/golang-testing/SKILL.md +719 -0
  183. package/skills/google-workspace-ops/SKILL.md +94 -0
  184. package/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  185. package/skills/healthcare-emr-patterns/SKILL.md +159 -0
  186. package/skills/healthcare-eval-harness/SKILL.md +207 -0
  187. package/skills/healthcare-phi-compliance/SKILL.md +145 -0
  188. package/skills/hermes-imports/SKILL.md +87 -0
  189. package/skills/hexagonal-architecture/SKILL.md +275 -0
  190. package/skills/hipaa-compliance/SKILL.md +78 -0
  191. package/skills/homelab-network-readiness/SKILL.md +169 -0
  192. package/skills/homelab-network-setup/SKILL.md +129 -0
  193. package/skills/homelab-pihole-dns/SKILL.md +274 -0
  194. package/skills/homelab-vlan-segmentation/SKILL.md +311 -0
  195. package/skills/homelab-wireguard-vpn/SKILL.md +305 -0
  196. package/skills/hookify-rules/SKILL.md +128 -0
  197. package/skills/inventory-demand-planning/SKILL.md +246 -0
  198. package/skills/investor-materials/SKILL.md +95 -0
  199. package/skills/investor-outreach/SKILL.md +90 -0
  200. package/skills/ios-icon-gen/SKILL.md +157 -0
  201. package/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  202. package/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  203. package/skills/iterative-retrieval/SKILL.md +209 -0
  204. package/skills/java-coding-standards/SKILL.md +382 -0
  205. package/skills/jira-integration/SKILL.md +292 -0
  206. package/skills/jpa-patterns/SKILL.md +150 -0
  207. package/skills/knowledge-ops/SKILL.md +153 -0
  208. package/skills/kotlin-coroutines-flows/SKILL.md +283 -0
  209. package/skills/kotlin-exposed-patterns/SKILL.md +718 -0
  210. package/skills/kotlin-ktor-patterns/SKILL.md +688 -0
  211. package/skills/kotlin-patterns/SKILL.md +710 -0
  212. package/skills/kotlin-testing/SKILL.md +823 -0
  213. package/skills/laravel-patterns/SKILL.md +414 -0
  214. package/skills/laravel-plugin-discovery/SKILL.md +228 -0
  215. package/skills/laravel-security/SKILL.md +284 -0
  216. package/skills/laravel-tdd/SKILL.md +282 -0
  217. package/skills/laravel-verification/SKILL.md +178 -0
  218. package/skills/lead-intelligence/SKILL.md +320 -0
  219. package/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  220. package/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  221. package/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  222. package/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  223. package/skills/liquid-glass-design/SKILL.md +279 -0
  224. package/skills/llm-trading-agent-security/SKILL.md +146 -0
  225. package/skills/logistics-exception-management/SKILL.md +221 -0
  226. package/skills/make-interfaces-feel-better/SKILL.md +151 -0
  227. package/skills/manim-video/SKILL.md +88 -0
  228. package/skills/manim-video/assets/network_graph_scene.py +52 -0
  229. package/skills/market-research/SKILL.md +74 -0
  230. package/skills/mcp-server-patterns/SKILL.md +68 -0
  231. package/skills/messages-ops/SKILL.md +103 -0
  232. package/skills/mle-workflow/SKILL.md +345 -0
  233. package/skills/motion-advanced/SKILL.md +596 -0
  234. package/skills/motion-foundations/SKILL.md +299 -0
  235. package/skills/motion-patterns/SKILL.md +435 -0
  236. package/skills/motion-ui/SKILL.md +574 -0
  237. package/skills/mysql-patterns/SKILL.md +411 -0
  238. package/skills/nanoclaw-repl/SKILL.md +32 -0
  239. package/skills/nestjs-patterns/SKILL.md +229 -0
  240. package/skills/netmiko-ssh-automation/SKILL.md +173 -0
  241. package/skills/network-bgp-diagnostics/SKILL.md +167 -0
  242. package/skills/network-config-validation/SKILL.md +210 -0
  243. package/skills/network-interface-health/SKILL.md +152 -0
  244. package/skills/nextjs-turbopack/SKILL.md +43 -0
  245. package/skills/nodejs-keccak256/SKILL.md +102 -0
  246. package/skills/nutrient-document-processing/SKILL.md +166 -0
  247. package/skills/nuxt4-patterns/SKILL.md +99 -0
  248. package/skills/openclaw-persona-forge/SKILL.md +288 -0
  249. package/skills/openclaw-persona-forge/gacha.py +224 -0
  250. package/skills/openclaw-persona-forge/gacha.sh +5 -0
  251. package/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  252. package/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  253. package/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  254. package/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  255. package/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  256. package/skills/openclaw-persona-forge/references/output-template.md +166 -0
  257. package/skills/opensource-pipeline/SKILL.md +254 -0
  258. package/skills/perl-patterns/SKILL.md +503 -0
  259. package/skills/perl-security/SKILL.md +502 -0
  260. package/skills/perl-testing/SKILL.md +474 -0
  261. package/skills/plan-orchestrate/SKILL.md +253 -0
  262. package/skills/plankton-code-quality/SKILL.md +236 -0
  263. package/skills/postgres-patterns/SKILL.md +146 -0
  264. package/skills/product-capability/SKILL.md +140 -0
  265. package/skills/product-lens/SKILL.md +91 -0
  266. package/skills/production-audit/SKILL.md +206 -0
  267. package/skills/production-scheduling/SKILL.md +237 -0
  268. package/skills/project-flow-ops/SKILL.md +110 -0
  269. package/skills/prompt-optimizer/SKILL.md +398 -0
  270. package/skills/python-patterns/SKILL.md +749 -0
  271. package/skills/python-testing/SKILL.md +815 -0
  272. package/skills/pytorch-patterns/SKILL.md +395 -0
  273. package/skills/quality-nonconformance/SKILL.md +259 -0
  274. package/skills/quarkus-patterns/SKILL.md +721 -0
  275. package/skills/quarkus-security/SKILL.md +466 -0
  276. package/skills/quarkus-tdd/SKILL.md +810 -0
  277. package/skills/quarkus-verification/SKILL.md +478 -0
  278. package/skills/ralphinho-rfc-pipeline/SKILL.md +66 -0
  279. package/skills/redis-patterns/SKILL.md +402 -0
  280. package/skills/regex-vs-llm-structured-text/SKILL.md +219 -0
  281. package/skills/remotion-video-creation/SKILL.md +43 -0
  282. package/skills/remotion-video-creation/rules/3d.md +86 -0
  283. package/skills/remotion-video-creation/rules/animations.md +29 -0
  284. package/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  285. package/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  286. package/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  287. package/skills/remotion-video-creation/rules/assets.md +78 -0
  288. package/skills/remotion-video-creation/rules/audio.md +172 -0
  289. package/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  290. package/skills/remotion-video-creation/rules/can-decode.md +75 -0
  291. package/skills/remotion-video-creation/rules/charts.md +58 -0
  292. package/skills/remotion-video-creation/rules/compositions.md +146 -0
  293. package/skills/remotion-video-creation/rules/display-captions.md +126 -0
  294. package/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  295. package/skills/remotion-video-creation/rules/fonts.md +152 -0
  296. package/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  297. package/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  298. package/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  299. package/skills/remotion-video-creation/rules/gifs.md +138 -0
  300. package/skills/remotion-video-creation/rules/images.md +130 -0
  301. package/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  302. package/skills/remotion-video-creation/rules/lottie.md +67 -0
  303. package/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  304. package/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  305. package/skills/remotion-video-creation/rules/sequencing.md +106 -0
  306. package/skills/remotion-video-creation/rules/tailwind.md +11 -0
  307. package/skills/remotion-video-creation/rules/text-animations.md +20 -0
  308. package/skills/remotion-video-creation/rules/timing.md +179 -0
  309. package/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  310. package/skills/remotion-video-creation/rules/transitions.md +122 -0
  311. package/skills/remotion-video-creation/rules/trimming.md +52 -0
  312. package/skills/remotion-video-creation/rules/videos.md +171 -0
  313. package/skills/repo-scan/SKILL.md +78 -0
  314. package/skills/research-ops/SKILL.md +111 -0
  315. package/skills/returns-reverse-logistics/SKILL.md +239 -0
  316. package/skills/rules-distill/SKILL.md +263 -0
  317. package/skills/rules-distill/scripts/scan-rules.sh +58 -0
  318. package/skills/rules-distill/scripts/scan-skills.sh +129 -0
  319. package/skills/rust-patterns/SKILL.md +498 -0
  320. package/skills/rust-testing/SKILL.md +499 -0
  321. package/skills/safety-guard/SKILL.md +74 -0
  322. package/skills/santa-method/SKILL.md +306 -0
  323. package/skills/scientific-db-pubmed-database/SKILL.md +175 -0
  324. package/skills/scientific-db-uspto-database/SKILL.md +177 -0
  325. package/skills/scientific-pkg-gget/SKILL.md +166 -0
  326. package/skills/scientific-thinking-literature-review/SKILL.md +192 -0
  327. package/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
  328. package/skills/search-first/SKILL.md +181 -0
  329. package/skills/security-bounty-hunter/SKILL.md +99 -0
  330. package/skills/security-review/SKILL.md +502 -0
  331. package/skills/security-review/cloud-infrastructure-security.md +361 -0
  332. package/skills/seo/SKILL.md +153 -0
  333. package/skills/skill-comply/SKILL.md +57 -0
  334. package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  335. package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  336. package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  337. package/skills/skill-comply/prompts/classifier.md +24 -0
  338. package/skills/skill-comply/prompts/scenario_generator.md +62 -0
  339. package/skills/skill-comply/prompts/spec_generator.md +42 -0
  340. package/skills/skill-comply/pyproject.toml +15 -0
  341. package/skills/skill-comply/scripts/__init__.py +0 -0
  342. package/skills/skill-comply/scripts/classifier.py +85 -0
  343. package/skills/skill-comply/scripts/grader.py +124 -0
  344. package/skills/skill-comply/scripts/parser.py +107 -0
  345. package/skills/skill-comply/scripts/report.py +170 -0
  346. package/skills/skill-comply/scripts/run.py +127 -0
  347. package/skills/skill-comply/scripts/runner.py +186 -0
  348. package/skills/skill-comply/scripts/scenario_generator.py +70 -0
  349. package/skills/skill-comply/scripts/spec_generator.py +72 -0
  350. package/skills/skill-comply/scripts/utils.py +13 -0
  351. package/skills/skill-comply/tests/test_grader.py +197 -0
  352. package/skills/skill-comply/tests/test_parser.py +90 -0
  353. package/skills/skill-comply/tests/test_runner.py +172 -0
  354. package/skills/skill-scout/SKILL.md +139 -0
  355. package/skills/skill-stocktake/SKILL.md +193 -0
  356. package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  357. package/skills/skill-stocktake/scripts/save-results.sh +56 -0
  358. package/skills/skill-stocktake/scripts/scan.sh +170 -0
  359. package/skills/social-graph-ranker/SKILL.md +153 -0
  360. package/skills/springboot-patterns/SKILL.md +313 -0
  361. package/skills/springboot-security/SKILL.md +271 -0
  362. package/skills/springboot-tdd/SKILL.md +157 -0
  363. package/skills/springboot-verification/SKILL.md +230 -0
  364. package/skills/strategic-compact/SKILL.md +129 -0
  365. package/skills/strategic-compact/suggest-compact.sh +54 -0
  366. package/skills/swift-actor-persistence/SKILL.md +142 -0
  367. package/skills/swift-concurrency-6-2/SKILL.md +216 -0
  368. package/skills/swift-protocol-di-testing/SKILL.md +189 -0
  369. package/skills/swiftui-patterns/SKILL.md +259 -0
  370. package/skills/tdd-workflow/SKILL.md +462 -0
  371. package/skills/team-builder/SKILL.md +166 -0
  372. package/skills/terminal-ops/SKILL.md +108 -0
  373. package/skills/tinystruct-patterns/SKILL.md +130 -0
  374. package/skills/tinystruct-patterns/references/architecture.md +77 -0
  375. package/skills/tinystruct-patterns/references/data-handling.md +35 -0
  376. package/skills/tinystruct-patterns/references/routing.md +57 -0
  377. package/skills/tinystruct-patterns/references/system-usage.md +74 -0
  378. package/skills/tinystruct-patterns/references/testing.md +59 -0
  379. package/skills/token-budget-advisor/SKILL.md +133 -0
  380. package/skills/ui-demo/SKILL.md +464 -0
  381. package/skills/ui-to-vue/SKILL.md +134 -0
  382. package/skills/unified-notifications-ops/SKILL.md +186 -0
  383. package/skills/verification-loop/SKILL.md +125 -0
  384. package/skills/video-editing/SKILL.md +309 -0
  385. package/skills/videodb/SKILL.md +373 -0
  386. package/skills/videodb/reference/api-reference.md +550 -0
  387. package/skills/videodb/reference/capture-reference.md +407 -0
  388. package/skills/videodb/reference/capture.md +101 -0
  389. package/skills/videodb/reference/editor.md +443 -0
  390. package/skills/videodb/reference/generative.md +331 -0
  391. package/skills/videodb/reference/rtstream-reference.md +564 -0
  392. package/skills/videodb/reference/rtstream.md +65 -0
  393. package/skills/videodb/reference/search.md +230 -0
  394. package/skills/videodb/reference/streaming.md +406 -0
  395. package/skills/videodb/reference/use-cases.md +118 -0
  396. package/skills/videodb/scripts/ws_listener.py +282 -0
  397. package/skills/visa-doc-translate/README.md +86 -0
  398. package/skills/visa-doc-translate/SKILL.md +117 -0
  399. package/skills/vite-patterns/SKILL.md +448 -0
  400. package/skills/windows-desktop-e2e/SKILL.md +787 -0
  401. package/skills/workspace-surface-audit/SKILL.md +124 -0
  402. package/skills/x-api/SKILL.md +233 -0
@@ -0,0 +1,502 @@
1
+ ---
2
+ name: perl-security
3
+ description: Comprehensive Perl security covering taint mode, input validation, safe process execution, DBI parameterized queries, web security (XSS/SQLi/CSRF), and perlcritic security policies.
4
+ ---
5
+
6
+ # Perl Security Patterns
7
+
8
+ Comprehensive security guidelines for Perl applications covering input validation, injection prevention, and secure coding practices.
9
+
10
+ ## When to Activate
11
+
12
+ - Handling user input in Perl applications
13
+ - Building Perl web applications (CGI, Mojolicious, Dancer2, Catalyst)
14
+ - Reviewing Perl code for security vulnerabilities
15
+ - Performing file operations with user-supplied paths
16
+ - Executing system commands from Perl
17
+ - Writing DBI database queries
18
+
19
+ ## How It Works
20
+
21
+ Start with taint-aware input boundaries, then move outward: validate and untaint inputs, keep filesystem and process execution constrained, and use parameterized DBI queries everywhere. The examples below show the safe defaults this skill expects you to apply before shipping Perl code that touches user input, the shell, or the network.
22
+
23
+ ## Taint Mode
24
+
25
+ Perl's taint mode (`-T`) tracks data from external sources and prevents it from being used in unsafe operations without explicit validation.
26
+
27
+ ### Enabling Taint Mode
28
+
29
+ ```perl
30
+ #!/usr/bin/perl -T
31
+ use v5.36;
32
+
33
+ # Tainted: anything from outside the program
34
+ my $input = $ARGV[0]; # Tainted
35
+ my $env_path = $ENV{PATH}; # Tainted
36
+ my $form = <STDIN>; # Tainted
37
+ my $query = $ENV{QUERY_STRING}; # Tainted
38
+
39
+ # Sanitize PATH early (required in taint mode)
40
+ $ENV{PATH} = '/usr/local/bin:/usr/bin:/bin';
41
+ delete @ENV{qw(IFS CDPATH ENV BASH_ENV)};
42
+ ```
43
+
44
+ ### Untainting Pattern
45
+
46
+ ```perl
47
+ use v5.36;
48
+
49
+ # Good: Validate and untaint with a specific regex
50
+ sub untaint_username($input) {
51
+ if ($input =~ /^([a-zA-Z0-9_]{3,30})$/) {
52
+ return $1; # $1 is untainted
53
+ }
54
+ die "Invalid username: must be 3-30 alphanumeric characters\n";
55
+ }
56
+
57
+ # Good: Validate and untaint a file path
58
+ sub untaint_filename($input) {
59
+ if ($input =~ m{^([a-zA-Z0-9._-]+)$}) {
60
+ return $1;
61
+ }
62
+ die "Invalid filename: contains unsafe characters\n";
63
+ }
64
+
65
+ # Bad: Overly permissive untainting (defeats the purpose)
66
+ sub bad_untaint($input) {
67
+ $input =~ /^(.*)$/s;
68
+ return $1; # Accepts ANYTHING — pointless
69
+ }
70
+ ```
71
+
72
+ ## Input Validation
73
+
74
+ ### Allowlist Over Blocklist
75
+
76
+ ```perl
77
+ use v5.36;
78
+
79
+ # Good: Allowlist — define exactly what's permitted
80
+ sub validate_sort_field($field) {
81
+ my %allowed = map { $_ => 1 } qw(name email created_at updated_at);
82
+ die "Invalid sort field: $field\n" unless $allowed{$field};
83
+ return $field;
84
+ }
85
+
86
+ # Good: Validate with specific patterns
87
+ sub validate_email($email) {
88
+ if ($email =~ /^([a-zA-Z0-9._%+-]+\@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,})$/) {
89
+ return $1;
90
+ }
91
+ die "Invalid email address\n";
92
+ }
93
+
94
+ sub validate_integer($input) {
95
+ if ($input =~ /^(-?\d{1,10})$/) {
96
+ return $1 + 0; # Coerce to number
97
+ }
98
+ die "Invalid integer\n";
99
+ }
100
+
101
+ # Bad: Blocklist — always incomplete
102
+ sub bad_validate($input) {
103
+ die "Invalid" if $input =~ /[<>"';&|]/; # Misses encoded attacks
104
+ return $input;
105
+ }
106
+ ```
107
+
108
+ ### Length Constraints
109
+
110
+ ```perl
111
+ use v5.36;
112
+
113
+ sub validate_comment($text) {
114
+ die "Comment is required\n" unless length($text) > 0;
115
+ die "Comment exceeds 10000 chars\n" if length($text) > 10_000;
116
+ return $text;
117
+ }
118
+ ```
119
+
120
+ ## Safe Regular Expressions
121
+
122
+ ### ReDoS Prevention
123
+
124
+ Catastrophic backtracking occurs with nested quantifiers on overlapping patterns.
125
+
126
+ ```perl
127
+ use v5.36;
128
+
129
+ # Bad: Vulnerable to ReDoS (exponential backtracking)
130
+ my $bad_re = qr/^(a+)+$/; # Nested quantifiers
131
+ my $bad_re2 = qr/^([a-zA-Z]+)*$/; # Nested quantifiers on class
132
+ my $bad_re3 = qr/^(.*?,){10,}$/; # Repeated greedy/lazy combo
133
+
134
+ # Good: Rewrite without nesting
135
+ my $good_re = qr/^a+$/; # Single quantifier
136
+ my $good_re2 = qr/^[a-zA-Z]+$/; # Single quantifier on class
137
+
138
+ # Good: Use possessive quantifiers or atomic groups to prevent backtracking
139
+ my $safe_re = qr/^[a-zA-Z]++$/; # Possessive (5.10+)
140
+ my $safe_re2 = qr/^(?>a+)$/; # Atomic group
141
+
142
+ # Good: Enforce timeout on untrusted patterns
143
+ use POSIX qw(alarm);
144
+ sub safe_match($string, $pattern, $timeout = 2) {
145
+ my $matched;
146
+ eval {
147
+ local $SIG{ALRM} = sub { die "Regex timeout\n" };
148
+ alarm($timeout);
149
+ $matched = $string =~ $pattern;
150
+ alarm(0);
151
+ };
152
+ alarm(0);
153
+ die $@ if $@;
154
+ return $matched;
155
+ }
156
+ ```
157
+
158
+ ## Safe File Operations
159
+
160
+ ### Three-Argument Open
161
+
162
+ ```perl
163
+ use v5.36;
164
+
165
+ # Good: Three-arg open, lexical filehandle, check return
166
+ sub read_file($path) {
167
+ open my $fh, '<:encoding(UTF-8)', $path
168
+ or die "Cannot open '$path': $!\n";
169
+ local $/;
170
+ my $content = <$fh>;
171
+ close $fh;
172
+ return $content;
173
+ }
174
+
175
+ # Bad: Two-arg open with user data (command injection)
176
+ sub bad_read($path) {
177
+ open my $fh, $path; # If $path = "|rm -rf /", runs command!
178
+ open my $fh, "< $path"; # Shell metacharacter injection
179
+ }
180
+ ```
181
+
182
+ ### TOCTOU Prevention and Path Traversal
183
+
184
+ ```perl
185
+ use v5.36;
186
+ use Fcntl qw(:DEFAULT :flock);
187
+ use File::Spec;
188
+ use Cwd qw(realpath);
189
+
190
+ # Atomic file creation
191
+ sub create_file_safe($path) {
192
+ sysopen(my $fh, $path, O_WRONLY | O_CREAT | O_EXCL, 0600)
193
+ or die "Cannot create '$path': $!\n";
194
+ return $fh;
195
+ }
196
+
197
+ # Validate path stays within allowed directory
198
+ sub safe_path($base_dir, $user_path) {
199
+ my $real = realpath(File::Spec->catfile($base_dir, $user_path))
200
+ // die "Path does not exist\n";
201
+ my $base_real = realpath($base_dir)
202
+ // die "Base dir does not exist\n";
203
+ die "Path traversal blocked\n" unless $real =~ /^\Q$base_real\E(?:\/|\z)/;
204
+ return $real;
205
+ }
206
+ ```
207
+
208
+ Use `File::Temp` for temporary files (`tempfile(UNLINK => 1)`) and `flock(LOCK_EX)` to prevent race conditions.
209
+
210
+ ## Safe Process Execution
211
+
212
+ ### List-Form system and exec
213
+
214
+ ```perl
215
+ use v5.36;
216
+
217
+ # Good: List form — no shell interpolation
218
+ sub run_command(@cmd) {
219
+ system(@cmd) == 0
220
+ or die "Command failed: @cmd\n";
221
+ }
222
+
223
+ run_command('grep', '-r', $user_pattern, '/var/log/app/');
224
+
225
+ # Good: Capture output safely with IPC::Run3
226
+ use IPC::Run3;
227
+ sub capture_output(@cmd) {
228
+ my ($stdout, $stderr);
229
+ run3(\@cmd, \undef, \$stdout, \$stderr);
230
+ if ($?) {
231
+ die "Command failed (exit $?): $stderr\n";
232
+ }
233
+ return $stdout;
234
+ }
235
+
236
+ # Bad: String form — shell injection!
237
+ sub bad_search($pattern) {
238
+ system("grep -r '$pattern' /var/log/app/"); # If $pattern = "'; rm -rf / #"
239
+ }
240
+
241
+ # Bad: Backticks with interpolation
242
+ my $output = `ls $user_dir`; # Shell injection risk
243
+ ```
244
+
245
+ Also use `Capture::Tiny` for capturing stdout/stderr from external commands safely.
246
+
247
+ ## SQL Injection Prevention
248
+
249
+ ### DBI Placeholders
250
+
251
+ ```perl
252
+ use v5.36;
253
+ use DBI;
254
+
255
+ my $dbh = DBI->connect($dsn, $user, $pass, {
256
+ RaiseError => 1,
257
+ PrintError => 0,
258
+ AutoCommit => 1,
259
+ });
260
+
261
+ # Good: Parameterized queries — always use placeholders
262
+ sub find_user($dbh, $email) {
263
+ my $sth = $dbh->prepare('SELECT * FROM users WHERE email = ?');
264
+ $sth->execute($email);
265
+ return $sth->fetchrow_hashref;
266
+ }
267
+
268
+ sub search_users($dbh, $name, $status) {
269
+ my $sth = $dbh->prepare(
270
+ 'SELECT * FROM users WHERE name LIKE ? AND status = ? ORDER BY name'
271
+ );
272
+ $sth->execute("%$name%", $status);
273
+ return $sth->fetchall_arrayref({});
274
+ }
275
+
276
+ # Bad: String interpolation in SQL (SQLi vulnerability!)
277
+ sub bad_find($dbh, $email) {
278
+ my $sth = $dbh->prepare("SELECT * FROM users WHERE email = '$email'");
279
+ # If $email = "' OR 1=1 --", returns all users
280
+ $sth->execute;
281
+ return $sth->fetchrow_hashref;
282
+ }
283
+ ```
284
+
285
+ ### Dynamic Column Allowlists
286
+
287
+ ```perl
288
+ use v5.36;
289
+
290
+ # Good: Validate column names against an allowlist
291
+ sub order_by($dbh, $column, $direction) {
292
+ my %allowed_cols = map { $_ => 1 } qw(name email created_at);
293
+ my %allowed_dirs = map { $_ => 1 } qw(ASC DESC);
294
+
295
+ die "Invalid column: $column\n" unless $allowed_cols{$column};
296
+ die "Invalid direction: $direction\n" unless $allowed_dirs{uc $direction};
297
+
298
+ my $sth = $dbh->prepare("SELECT * FROM users ORDER BY $column $direction");
299
+ $sth->execute;
300
+ return $sth->fetchall_arrayref({});
301
+ }
302
+
303
+ # Bad: Directly interpolating user-chosen column
304
+ sub bad_order($dbh, $column) {
305
+ $dbh->prepare("SELECT * FROM users ORDER BY $column"); # SQLi!
306
+ }
307
+ ```
308
+
309
+ ### DBIx::Class (ORM Safety)
310
+
311
+ ```perl
312
+ use v5.36;
313
+
314
+ # DBIx::Class generates safe parameterized queries
315
+ my @users = $schema->resultset('User')->search({
316
+ status => 'active',
317
+ email => { -like => '%@example.com' },
318
+ }, {
319
+ order_by => { -asc => 'name' },
320
+ rows => 50,
321
+ });
322
+ ```
323
+
324
+ ## Web Security
325
+
326
+ ### XSS Prevention
327
+
328
+ ```perl
329
+ use v5.36;
330
+ use HTML::Entities qw(encode_entities);
331
+ use URI::Escape qw(uri_escape_utf8);
332
+
333
+ # Good: Encode output for HTML context
334
+ sub safe_html($user_input) {
335
+ return encode_entities($user_input);
336
+ }
337
+
338
+ # Good: Encode for URL context
339
+ sub safe_url_param($value) {
340
+ return uri_escape_utf8($value);
341
+ }
342
+
343
+ # Good: Encode for JSON context
344
+ use JSON::MaybeXS qw(encode_json);
345
+ sub safe_json($data) {
346
+ return encode_json($data); # Handles escaping
347
+ }
348
+
349
+ # Template auto-escaping (Mojolicious)
350
+ # <%= $user_input %> — auto-escaped (safe)
351
+ # <%== $raw_html %> — raw output (dangerous, use only for trusted content)
352
+
353
+ # Template auto-escaping (Template Toolkit)
354
+ # [% user_input | html %] — explicit HTML encoding
355
+
356
+ # Bad: Raw output in HTML
357
+ sub bad_html($input) {
358
+ print "<div>$input</div>"; # XSS if $input contains <script>
359
+ }
360
+ ```
361
+
362
+ ### CSRF Protection
363
+
364
+ ```perl
365
+ use v5.36;
366
+ use Crypt::URandom qw(urandom);
367
+ use MIME::Base64 qw(encode_base64url);
368
+
369
+ sub generate_csrf_token() {
370
+ return encode_base64url(urandom(32));
371
+ }
372
+ ```
373
+
374
+ Use constant-time comparison when verifying tokens. Most web frameworks (Mojolicious, Dancer2, Catalyst) provide built-in CSRF protection — prefer those over hand-rolled solutions.
375
+
376
+ ### Session and Header Security
377
+
378
+ ```perl
379
+ use v5.36;
380
+
381
+ # Mojolicious session + headers
382
+ $app->secrets(['long-random-secret-rotated-regularly']);
383
+ $app->sessions->secure(1); # HTTPS only
384
+ $app->sessions->samesite('Lax');
385
+
386
+ $app->hook(after_dispatch => sub ($c) {
387
+ $c->res->headers->header('X-Content-Type-Options' => 'nosniff');
388
+ $c->res->headers->header('X-Frame-Options' => 'DENY');
389
+ $c->res->headers->header('Content-Security-Policy' => "default-src 'self'");
390
+ $c->res->headers->header('Strict-Transport-Security' => 'max-age=31536000; includeSubDomains');
391
+ });
392
+ ```
393
+
394
+ ## Output Encoding
395
+
396
+ Always encode output for its context: `HTML::Entities::encode_entities()` for HTML, `URI::Escape::uri_escape_utf8()` for URLs, `JSON::MaybeXS::encode_json()` for JSON.
397
+
398
+ ## CPAN Module Security
399
+
400
+ - **Pin versions** in cpanfile: `requires 'DBI', '== 1.643';`
401
+ - **Prefer maintained modules**: Check MetaCPAN for recent releases
402
+ - **Minimize dependencies**: Each dependency is an attack surface
403
+
404
+ ## Security Tooling
405
+
406
+ ### perlcritic Security Policies
407
+
408
+ ```ini
409
+ # .perlcriticrc — security-focused configuration
410
+ severity = 3
411
+ theme = security + core
412
+
413
+ # Require three-arg open
414
+ [InputOutput::RequireThreeArgOpen]
415
+ severity = 5
416
+
417
+ # Require checked system calls
418
+ [InputOutput::RequireCheckedSyscalls]
419
+ functions = :builtins
420
+ severity = 4
421
+
422
+ # Prohibit string eval
423
+ [BuiltinFunctions::ProhibitStringyEval]
424
+ severity = 5
425
+
426
+ # Prohibit backtick operators
427
+ [InputOutput::ProhibitBacktickOperators]
428
+ severity = 4
429
+
430
+ # Require taint checking in CGI
431
+ [Modules::RequireTaintChecking]
432
+ severity = 5
433
+
434
+ # Prohibit two-arg open
435
+ [InputOutput::ProhibitTwoArgOpen]
436
+ severity = 5
437
+
438
+ # Prohibit bare-word filehandles
439
+ [InputOutput::ProhibitBarewordFileHandles]
440
+ severity = 5
441
+ ```
442
+
443
+ ### Running perlcritic
444
+
445
+ ```bash
446
+ # Check a file
447
+ perlcritic --severity 3 --theme security lib/MyApp/Handler.pm
448
+
449
+ # Check entire project
450
+ perlcritic --severity 3 --theme security lib/
451
+
452
+ # CI integration
453
+ perlcritic --severity 4 --theme security --quiet lib/ || exit 1
454
+ ```
455
+
456
+ ## Quick Security Checklist
457
+
458
+ | Check | What to Verify |
459
+ |---|---|
460
+ | Taint mode | `-T` flag on CGI/web scripts |
461
+ | Input validation | Allowlist patterns, length limits |
462
+ | File operations | Three-arg open, path traversal checks |
463
+ | Process execution | List-form system, no shell interpolation |
464
+ | SQL queries | DBI placeholders, never interpolate |
465
+ | HTML output | `encode_entities()`, template auto-escape |
466
+ | CSRF tokens | Generated, verified on state-changing requests |
467
+ | Session config | Secure, HttpOnly, SameSite cookies |
468
+ | HTTP headers | CSP, X-Frame-Options, HSTS |
469
+ | Dependencies | Pinned versions, audited modules |
470
+ | Regex safety | No nested quantifiers, anchored patterns |
471
+ | Error messages | No stack traces or paths leaked to users |
472
+
473
+ ## Anti-Patterns
474
+
475
+ ```perl
476
+ # 1. Two-arg open with user data (command injection)
477
+ open my $fh, $user_input; # CRITICAL vulnerability
478
+
479
+ # 2. String-form system (shell injection)
480
+ system("convert $user_file output.png"); # CRITICAL vulnerability
481
+
482
+ # 3. SQL string interpolation
483
+ $dbh->do("DELETE FROM users WHERE id = $id"); # SQLi
484
+
485
+ # 4. eval with user input (code injection)
486
+ eval $user_code; # Remote code execution
487
+
488
+ # 5. Trusting $ENV without sanitizing
489
+ my $path = $ENV{UPLOAD_DIR}; # Could be manipulated
490
+ system("ls $path"); # Double vulnerability
491
+
492
+ # 6. Disabling taint without validation
493
+ ($input) = $input =~ /(.*)/s; # Lazy untaint — defeats purpose
494
+
495
+ # 7. Raw user data in HTML
496
+ print "<div>Welcome, $username!</div>"; # XSS
497
+
498
+ # 8. Unvalidated redirects
499
+ print $cgi->redirect($user_url); # Open redirect
500
+ ```
501
+
502
+ **Remember**: Perl's flexibility is powerful but requires discipline. Use taint mode for web-facing code, validate all input with allowlists, use DBI placeholders for every query, and encode all output for its context. Defense in depth — never rely on a single layer.