compact-agent 1.10.1 → 1.11.0

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 (697) hide show
  1. package/bin/ecc-hooks.cjs +110 -0
  2. package/dist/ecc.d.ts +11 -0
  3. package/dist/ecc.js +142 -27
  4. package/dist/ecc.js.map +1 -1
  5. package/dist/index.js +47 -7
  6. package/dist/index.js.map +1 -1
  7. package/package.json +1 -1
  8. package/resources/ecc/agents/a11y-architect.md +149 -0
  9. package/resources/ecc/agents/architect.md +11 -3
  10. package/resources/ecc/agents/build-error-resolver.md +11 -4
  11. package/resources/ecc/agents/chief-of-staff.md +11 -4
  12. package/resources/ecc/agents/code-architect.md +80 -0
  13. package/resources/ecc/agents/code-explorer.md +78 -0
  14. package/resources/ecc/agents/code-reviewer.md +89 -4
  15. package/resources/ecc/agents/code-simplifier.md +56 -0
  16. package/resources/ecc/agents/comment-analyzer.md +54 -0
  17. package/resources/ecc/agents/conversation-analyzer.md +61 -0
  18. package/resources/ecc/agents/cpp-build-resolver.md +99 -0
  19. package/resources/ecc/agents/cpp-reviewer.md +81 -0
  20. package/resources/ecc/agents/csharp-reviewer.md +110 -0
  21. package/resources/ecc/agents/dart-build-resolver.md +210 -0
  22. package/resources/ecc/agents/database-reviewer.md +11 -3
  23. package/resources/ecc/agents/django-build-resolver.md +252 -0
  24. package/resources/ecc/agents/django-reviewer.md +169 -0
  25. package/resources/ecc/agents/doc-updater.md +11 -3
  26. package/resources/ecc/agents/docs-lookup.md +77 -0
  27. package/resources/ecc/agents/e2e-runner.md +11 -4
  28. package/resources/ecc/agents/fastapi-reviewer.md +79 -0
  29. package/resources/ecc/agents/flutter-reviewer.md +252 -0
  30. package/resources/ecc/agents/fsharp-reviewer.md +109 -0
  31. package/resources/ecc/agents/gan-evaluator.md +218 -0
  32. package/resources/ecc/agents/gan-generator.md +140 -0
  33. package/resources/ecc/agents/gan-planner.md +108 -0
  34. package/resources/ecc/agents/go-build-resolver.md +11 -4
  35. package/resources/ecc/agents/go-reviewer.md +11 -3
  36. package/resources/ecc/agents/harmonyos-app-resolver.md +182 -0
  37. package/resources/ecc/agents/harness-optimizer.md +12 -2
  38. package/resources/ecc/agents/healthcare-reviewer.md +92 -0
  39. package/resources/ecc/agents/homelab-architect.md +107 -0
  40. package/resources/ecc/agents/java-build-resolver.md +275 -0
  41. package/resources/ecc/agents/java-reviewer.md +190 -0
  42. package/resources/ecc/agents/kotlin-build-resolver.md +127 -0
  43. package/resources/ecc/agents/kotlin-reviewer.md +168 -0
  44. package/resources/ecc/agents/loop-operator.md +12 -3
  45. package/resources/ecc/agents/mle-reviewer.md +162 -0
  46. package/resources/ecc/agents/network-architect.md +106 -0
  47. package/resources/ecc/agents/network-config-reviewer.md +106 -0
  48. package/resources/ecc/agents/network-troubleshooter.md +128 -0
  49. package/resources/ecc/agents/opensource-forker.md +207 -0
  50. package/resources/ecc/agents/opensource-packager.md +258 -0
  51. package/resources/ecc/agents/opensource-sanitizer.md +197 -0
  52. package/resources/ecc/agents/performance-optimizer.md +455 -0
  53. package/resources/ecc/agents/planner.md +11 -2
  54. package/resources/ecc/agents/pr-test-analyzer.md +54 -0
  55. package/resources/ecc/agents/python-reviewer.md +11 -3
  56. package/resources/ecc/agents/pytorch-build-resolver.md +129 -0
  57. package/resources/ecc/agents/refactor-cleaner.md +11 -4
  58. package/resources/ecc/agents/rust-build-resolver.md +157 -0
  59. package/resources/ecc/agents/rust-reviewer.md +103 -0
  60. package/resources/ecc/agents/security-reviewer.md +11 -3
  61. package/resources/ecc/agents/seo-specialist.md +71 -0
  62. package/resources/ecc/agents/silent-failure-hunter.md +59 -0
  63. package/resources/ecc/agents/swift-build-resolver.md +170 -0
  64. package/resources/ecc/agents/swift-reviewer.md +116 -0
  65. package/resources/ecc/agents/tdd-guide.md +11 -4
  66. package/resources/ecc/agents/type-design-analyzer.md +50 -0
  67. package/resources/ecc/agents/typescript-reviewer.md +121 -0
  68. package/resources/ecc/commands/aside.md +164 -0
  69. package/resources/ecc/commands/auto-update.md +28 -0
  70. package/resources/ecc/commands/build-fix.md +66 -0
  71. package/resources/ecc/commands/checkpoint.md +78 -0
  72. package/resources/ecc/commands/code-review.md +289 -0
  73. package/resources/ecc/commands/cost-report.md +107 -0
  74. package/resources/ecc/commands/cpp-build.md +173 -0
  75. package/resources/ecc/commands/cpp-review.md +132 -0
  76. package/resources/ecc/commands/cpp-test.md +251 -0
  77. package/resources/ecc/commands/ecc-guide.md +93 -0
  78. package/resources/ecc/commands/evolve.md +178 -0
  79. package/resources/ecc/commands/fastapi-review.md +39 -0
  80. package/resources/ecc/commands/feature-dev.md +49 -0
  81. package/resources/ecc/commands/flutter-build.md +164 -0
  82. package/resources/ecc/commands/flutter-review.md +116 -0
  83. package/resources/ecc/commands/flutter-test.md +144 -0
  84. package/resources/ecc/commands/gan-build.md +103 -0
  85. package/resources/ecc/commands/gan-design.md +39 -0
  86. package/resources/ecc/commands/go-build.md +183 -0
  87. package/resources/ecc/commands/go-review.md +148 -0
  88. package/resources/ecc/commands/go-test.md +268 -0
  89. package/resources/ecc/commands/gradle-build.md +70 -0
  90. package/resources/ecc/commands/harness-audit.md +77 -0
  91. package/resources/ecc/commands/hookify-configure.md +14 -0
  92. package/resources/ecc/commands/hookify-help.md +46 -0
  93. package/resources/ecc/commands/hookify-list.md +21 -0
  94. package/resources/ecc/commands/hookify.md +50 -0
  95. package/resources/ecc/commands/instinct-export.md +66 -0
  96. package/resources/ecc/commands/instinct-import.md +114 -0
  97. package/resources/ecc/commands/instinct-status.md +59 -0
  98. package/resources/ecc/commands/jira.md +106 -0
  99. package/resources/ecc/commands/kotlin-build.md +174 -0
  100. package/resources/ecc/commands/kotlin-review.md +140 -0
  101. package/resources/ecc/commands/kotlin-test.md +312 -0
  102. package/resources/ecc/commands/learn-eval.md +116 -0
  103. package/resources/ecc/commands/learn.md +74 -0
  104. package/resources/ecc/commands/loop-start.md +36 -0
  105. package/resources/ecc/commands/loop-status.md +77 -0
  106. package/resources/ecc/commands/model-route.md +30 -0
  107. package/resources/ecc/commands/multi-backend.md +162 -0
  108. package/resources/ecc/commands/multi-execute.md +319 -0
  109. package/resources/ecc/commands/multi-frontend.md +162 -0
  110. package/resources/ecc/commands/multi-plan.md +272 -0
  111. package/resources/ecc/commands/multi-workflow.md +195 -0
  112. package/resources/ecc/commands/plan-prd.md +160 -0
  113. package/resources/ecc/commands/plan.md +200 -0
  114. package/resources/ecc/commands/pm2.md +276 -0
  115. package/resources/ecc/commands/pr.md +184 -0
  116. package/resources/ecc/commands/project-init.md +86 -0
  117. package/resources/ecc/commands/projects.md +39 -0
  118. package/resources/ecc/commands/promote.md +41 -0
  119. package/resources/ecc/commands/prp-commit.md +112 -0
  120. package/resources/ecc/commands/prp-implement.md +385 -0
  121. package/resources/ecc/commands/prp-plan.md +502 -0
  122. package/resources/ecc/commands/prp-pr.md +184 -0
  123. package/resources/ecc/commands/prp-prd.md +447 -0
  124. package/resources/ecc/commands/prune.md +31 -0
  125. package/resources/ecc/commands/python-review.md +297 -0
  126. package/resources/ecc/commands/quality-gate.md +33 -0
  127. package/resources/ecc/commands/refactor-clean.md +84 -0
  128. package/resources/ecc/commands/resume-session.md +156 -0
  129. package/resources/ecc/commands/review-pr.md +37 -0
  130. package/resources/ecc/commands/rust-build.md +187 -0
  131. package/resources/ecc/commands/rust-review.md +142 -0
  132. package/resources/ecc/commands/rust-test.md +308 -0
  133. package/resources/ecc/commands/santa-loop.md +175 -0
  134. package/resources/ecc/commands/save-session.md +275 -0
  135. package/resources/ecc/commands/security-scan.md +92 -0
  136. package/resources/ecc/commands/sessions.md +339 -0
  137. package/resources/ecc/commands/setup-pm.md +80 -0
  138. package/resources/ecc/commands/skill-create.md +174 -0
  139. package/resources/ecc/commands/skill-health.md +54 -0
  140. package/resources/ecc/commands/test-coverage.md +73 -0
  141. package/resources/ecc/commands/update-codemaps.md +76 -0
  142. package/resources/ecc/commands/update-docs.md +88 -0
  143. package/resources/ecc/rules/README.md +120 -0
  144. package/resources/ecc/rules/angular/coding-style.md +182 -0
  145. package/resources/ecc/rules/angular/hooks.md +25 -0
  146. package/resources/ecc/rules/angular/patterns.md +249 -0
  147. package/resources/ecc/rules/angular/security.md +87 -0
  148. package/resources/ecc/rules/angular/testing.md +164 -0
  149. package/resources/ecc/rules/arkts/coding-style.md +153 -0
  150. package/resources/ecc/rules/arkts/hooks.md +135 -0
  151. package/resources/ecc/rules/arkts/patterns.md +236 -0
  152. package/resources/ecc/rules/arkts/security.md +141 -0
  153. package/resources/ecc/rules/arkts/testing.md +126 -0
  154. package/resources/ecc/rules/{common-agents.md → common/agents.md} +2 -4
  155. package/resources/ecc/rules/common/code-review.md +124 -0
  156. package/resources/ecc/rules/{common-coding-style.md → common/coding-style.md} +42 -4
  157. package/resources/ecc/rules/common/development-workflow.md +44 -0
  158. package/resources/ecc/rules/{common-git-workflow.md → common/git-workflow.md} +1 -5
  159. package/resources/ecc/rules/{common-hooks.md → common/hooks.md} +0 -4
  160. package/resources/ecc/rules/{common-patterns.md → common/patterns.md} +0 -4
  161. package/resources/ecc/rules/{common-performance.md → common/performance.md} +0 -4
  162. package/resources/ecc/rules/{common-security.md → common/security.md} +0 -4
  163. package/resources/ecc/rules/{common-testing.md → common/testing.md} +28 -4
  164. package/resources/ecc/rules/cpp/coding-style.md +44 -0
  165. package/resources/ecc/rules/cpp/hooks.md +39 -0
  166. package/resources/ecc/rules/cpp/patterns.md +51 -0
  167. package/resources/ecc/rules/cpp/security.md +51 -0
  168. package/resources/ecc/rules/cpp/testing.md +44 -0
  169. package/resources/ecc/rules/csharp/coding-style.md +72 -0
  170. package/resources/ecc/rules/csharp/hooks.md +25 -0
  171. package/resources/ecc/rules/csharp/patterns.md +50 -0
  172. package/resources/ecc/rules/csharp/security.md +58 -0
  173. package/resources/ecc/rules/csharp/testing.md +46 -0
  174. package/resources/ecc/rules/dart/coding-style.md +159 -0
  175. package/resources/ecc/rules/dart/hooks.md +66 -0
  176. package/resources/ecc/rules/dart/patterns.md +261 -0
  177. package/resources/ecc/rules/dart/security.md +135 -0
  178. package/resources/ecc/rules/dart/testing.md +215 -0
  179. package/resources/ecc/rules/fsharp/coding-style.md +112 -0
  180. package/resources/ecc/rules/fsharp/hooks.md +26 -0
  181. package/resources/ecc/rules/fsharp/patterns.md +111 -0
  182. package/resources/ecc/rules/fsharp/security.md +76 -0
  183. package/resources/ecc/rules/fsharp/testing.md +62 -0
  184. package/resources/ecc/rules/{golang-coding-style.md → golang/coding-style.md} +6 -5
  185. package/resources/ecc/rules/{golang-hooks.md → golang/hooks.md} +5 -4
  186. package/resources/ecc/rules/{golang-patterns.md → golang/patterns.md} +5 -4
  187. package/resources/ecc/rules/{golang-security.md → golang/security.md} +5 -4
  188. package/resources/ecc/rules/{golang-testing.md → golang/testing.md} +5 -4
  189. package/resources/ecc/rules/java/coding-style.md +114 -0
  190. package/resources/ecc/rules/java/hooks.md +18 -0
  191. package/resources/ecc/rules/java/patterns.md +147 -0
  192. package/resources/ecc/rules/java/security.md +101 -0
  193. package/resources/ecc/rules/java/testing.md +133 -0
  194. package/resources/ecc/rules/kotlin/coding-style.md +86 -0
  195. package/resources/ecc/rules/{kotlin-hooks.md → kotlin/hooks.md} +5 -4
  196. package/resources/ecc/rules/kotlin/patterns.md +146 -0
  197. package/resources/ecc/rules/kotlin/security.md +82 -0
  198. package/resources/ecc/rules/kotlin/testing.md +128 -0
  199. package/resources/ecc/rules/perl/coding-style.md +46 -0
  200. package/resources/ecc/rules/perl/hooks.md +22 -0
  201. package/resources/ecc/rules/perl/patterns.md +76 -0
  202. package/resources/ecc/rules/perl/security.md +69 -0
  203. package/resources/ecc/rules/perl/testing.md +54 -0
  204. package/resources/ecc/rules/php/coding-style.md +40 -0
  205. package/resources/ecc/rules/{php-hooks.md → php/hooks.md} +7 -4
  206. package/resources/ecc/rules/php/patterns.md +33 -0
  207. package/resources/ecc/rules/php/security.md +37 -0
  208. package/resources/ecc/rules/php/testing.md +39 -0
  209. package/resources/ecc/rules/{python-coding-style.md → python/coding-style.md} +4 -4
  210. package/resources/ecc/rules/python/fastapi.md +58 -0
  211. package/resources/ecc/rules/{python-hooks.md → python/hooks.md} +4 -4
  212. package/resources/ecc/rules/{python-patterns.md → python/patterns.md} +4 -4
  213. package/resources/ecc/rules/{python-security.md → python/security.md} +4 -4
  214. package/resources/ecc/rules/{python-testing.md → python/testing.md} +4 -4
  215. package/resources/ecc/rules/ruby/coding-style.md +46 -0
  216. package/resources/ecc/rules/ruby/hooks.md +37 -0
  217. package/resources/ecc/rules/ruby/patterns.md +44 -0
  218. package/resources/ecc/rules/ruby/security.md +51 -0
  219. package/resources/ecc/rules/ruby/testing.md +51 -0
  220. package/resources/ecc/rules/rust/coding-style.md +151 -0
  221. package/resources/ecc/rules/rust/hooks.md +16 -0
  222. package/resources/ecc/rules/rust/patterns.md +168 -0
  223. package/resources/ecc/rules/rust/security.md +141 -0
  224. package/resources/ecc/rules/rust/testing.md +154 -0
  225. package/resources/ecc/rules/{swift-coding-style.md → swift/coding-style.md} +6 -6
  226. package/resources/ecc/rules/swift/hooks.md +20 -0
  227. package/resources/ecc/rules/{swift-patterns.md → swift/patterns.md} +5 -5
  228. package/resources/ecc/rules/{swift-security.md → swift/security.md} +7 -7
  229. package/resources/ecc/rules/{swift-testing.md → swift/testing.md} +5 -5
  230. package/resources/ecc/rules/typescript/coding-style.md +199 -0
  231. package/resources/ecc/rules/{typescript-hooks.md → typescript/hooks.md} +6 -4
  232. package/resources/ecc/rules/{typescript-patterns.md → typescript/patterns.md} +6 -4
  233. package/resources/ecc/rules/{typescript-security.md → typescript/security.md} +6 -4
  234. package/resources/ecc/rules/typescript/testing.md +18 -0
  235. package/resources/ecc/rules/web/coding-style.md +96 -0
  236. package/resources/ecc/rules/web/design-quality.md +63 -0
  237. package/resources/ecc/rules/web/hooks.md +129 -0
  238. package/resources/ecc/rules/web/patterns.md +79 -0
  239. package/resources/ecc/rules/web/performance.md +64 -0
  240. package/resources/ecc/rules/web/security.md +57 -0
  241. package/resources/ecc/rules/web/testing.md +55 -0
  242. package/resources/ecc/rules/zh/README.md +108 -0
  243. package/resources/ecc/rules/zh/agents.md +50 -0
  244. package/resources/ecc/rules/zh/code-review.md +124 -0
  245. package/resources/ecc/rules/zh/coding-style.md +48 -0
  246. package/resources/ecc/rules/zh/development-workflow.md +44 -0
  247. package/resources/ecc/rules/zh/git-workflow.md +24 -0
  248. package/resources/ecc/rules/zh/hooks.md +30 -0
  249. package/resources/ecc/rules/zh/patterns.md +31 -0
  250. package/resources/ecc/rules/zh/performance.md +55 -0
  251. package/resources/ecc/rules/zh/security.md +29 -0
  252. package/resources/ecc/rules/zh/testing.md +29 -0
  253. package/resources/ecc/skills/accessibility/SKILL.md +146 -0
  254. package/resources/ecc/skills/agent-architecture-audit/SKILL.md +256 -0
  255. package/resources/ecc/skills/agent-eval/SKILL.md +145 -0
  256. package/resources/ecc/skills/agent-harness-construction/SKILL.md +73 -0
  257. package/resources/ecc/skills/agent-introspection-debugging/SKILL.md +1 -0
  258. package/resources/ecc/skills/agent-payment-x402/SKILL.md +224 -0
  259. package/resources/ecc/skills/agent-sort/SKILL.md +1 -0
  260. package/resources/ecc/skills/agentic-engineering/SKILL.md +63 -0
  261. package/resources/ecc/skills/agentic-os/SKILL.md +387 -0
  262. package/resources/ecc/skills/ai-first-engineering/SKILL.md +51 -0
  263. package/resources/ecc/skills/ai-regression-testing/SKILL.md +385 -0
  264. package/resources/ecc/skills/android-clean-architecture/SKILL.md +339 -0
  265. package/resources/ecc/skills/angular-developer/SKILL.md +154 -0
  266. package/resources/ecc/skills/angular-developer/references/angular-animations.md +160 -0
  267. package/resources/ecc/skills/angular-developer/references/angular-aria.md +410 -0
  268. package/resources/ecc/skills/angular-developer/references/cli.md +86 -0
  269. package/resources/ecc/skills/angular-developer/references/component-harnesses.md +59 -0
  270. package/resources/ecc/skills/angular-developer/references/component-styling.md +91 -0
  271. package/resources/ecc/skills/angular-developer/references/components.md +117 -0
  272. package/resources/ecc/skills/angular-developer/references/creating-services.md +97 -0
  273. package/resources/ecc/skills/angular-developer/references/data-resolvers.md +69 -0
  274. package/resources/ecc/skills/angular-developer/references/define-routes.md +67 -0
  275. package/resources/ecc/skills/angular-developer/references/defining-providers.md +72 -0
  276. package/resources/ecc/skills/angular-developer/references/di-fundamentals.md +120 -0
  277. package/resources/ecc/skills/angular-developer/references/e2e-testing.md +56 -0
  278. package/resources/ecc/skills/angular-developer/references/effects.md +83 -0
  279. package/resources/ecc/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  280. package/resources/ecc/skills/angular-developer/references/host-elements.md +80 -0
  281. package/resources/ecc/skills/angular-developer/references/injection-context.md +63 -0
  282. package/resources/ecc/skills/angular-developer/references/inputs.md +101 -0
  283. package/resources/ecc/skills/angular-developer/references/linked-signal.md +59 -0
  284. package/resources/ecc/skills/angular-developer/references/loading-strategies.md +61 -0
  285. package/resources/ecc/skills/angular-developer/references/mcp.md +108 -0
  286. package/resources/ecc/skills/angular-developer/references/navigate-to-routes.md +69 -0
  287. package/resources/ecc/skills/angular-developer/references/outputs.md +86 -0
  288. package/resources/ecc/skills/angular-developer/references/reactive-forms.md +122 -0
  289. package/resources/ecc/skills/angular-developer/references/rendering-strategies.md +44 -0
  290. package/resources/ecc/skills/angular-developer/references/resource.md +77 -0
  291. package/resources/ecc/skills/angular-developer/references/route-animations.md +56 -0
  292. package/resources/ecc/skills/angular-developer/references/route-guards.md +52 -0
  293. package/resources/ecc/skills/angular-developer/references/router-lifecycle.md +45 -0
  294. package/resources/ecc/skills/angular-developer/references/router-testing.md +87 -0
  295. package/resources/ecc/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  296. package/resources/ecc/skills/angular-developer/references/signal-forms.md +795 -0
  297. package/resources/ecc/skills/angular-developer/references/signals-overview.md +94 -0
  298. package/resources/ecc/skills/angular-developer/references/tailwind-css.md +69 -0
  299. package/resources/ecc/skills/angular-developer/references/template-driven-forms.md +114 -0
  300. package/resources/ecc/skills/angular-developer/references/testing-fundamentals.md +65 -0
  301. package/resources/ecc/skills/api-connector-builder/SKILL.md +120 -0
  302. package/resources/ecc/skills/api-design/SKILL.md +1 -0
  303. package/resources/ecc/skills/architecture-decision-records/SKILL.md +179 -0
  304. package/resources/ecc/skills/article-writing/SKILL.md +1 -0
  305. package/resources/ecc/skills/automation-audit-ops/SKILL.md +142 -0
  306. package/resources/ecc/skills/autonomous-agent-harness/SKILL.md +273 -0
  307. package/resources/ecc/skills/autonomous-loops/SKILL.md +610 -0
  308. package/resources/ecc/skills/backend-patterns/SKILL.md +8 -44
  309. package/resources/ecc/skills/benchmark/SKILL.md +93 -0
  310. package/resources/ecc/skills/blueprint/SKILL.md +105 -0
  311. package/resources/ecc/skills/brand-voice/SKILL.md +1 -0
  312. package/resources/ecc/skills/browser-qa/SKILL.md +87 -0
  313. package/resources/ecc/skills/bun-runtime/SKILL.md +1 -0
  314. package/resources/ecc/skills/canary-watch/SKILL.md +99 -0
  315. package/resources/ecc/skills/carrier-relationship-management/SKILL.md +212 -0
  316. package/resources/ecc/skills/cisco-ios-patterns/SKILL.md +163 -0
  317. package/resources/ecc/skills/ck/SKILL.md +147 -0
  318. package/resources/ecc/skills/ck/commands/forget.mjs +44 -0
  319. package/resources/ecc/skills/ck/commands/info.mjs +24 -0
  320. package/resources/ecc/skills/ck/commands/init.mjs +143 -0
  321. package/resources/ecc/skills/ck/commands/list.mjs +40 -0
  322. package/resources/ecc/skills/ck/commands/migrate.mjs +202 -0
  323. package/resources/ecc/skills/ck/commands/resume.mjs +36 -0
  324. package/resources/ecc/skills/ck/commands/save.mjs +210 -0
  325. package/resources/ecc/skills/ck/commands/shared.mjs +387 -0
  326. package/resources/ecc/skills/ck/hooks/session-start.mjs +224 -0
  327. package/resources/ecc/skills/claude-devfleet/SKILL.md +103 -0
  328. package/resources/ecc/skills/click-path-audit/SKILL.md +244 -0
  329. package/resources/ecc/skills/clickhouse-io/SKILL.md +439 -0
  330. package/resources/ecc/skills/code-tour/SKILL.md +236 -0
  331. package/resources/ecc/skills/codebase-onboarding/SKILL.md +233 -0
  332. package/resources/ecc/skills/coding-standards/SKILL.md +1 -0
  333. package/resources/ecc/skills/compose-multiplatform-patterns/SKILL.md +299 -0
  334. package/resources/ecc/skills/configure-ecc/SKILL.md +384 -0
  335. package/resources/ecc/skills/connections-optimizer/SKILL.md +189 -0
  336. package/resources/ecc/skills/content-engine/SKILL.md +1 -0
  337. package/resources/ecc/skills/content-hash-cache-pattern/SKILL.md +161 -0
  338. package/resources/ecc/skills/context-budget/SKILL.md +135 -0
  339. package/resources/ecc/skills/continuous-agent-loop/SKILL.md +45 -0
  340. package/resources/ecc/skills/continuous-learning/SKILL.md +131 -0
  341. package/resources/ecc/skills/continuous-learning/config.json +18 -0
  342. package/resources/ecc/skills/continuous-learning/evaluate-session.sh +69 -0
  343. package/resources/ecc/skills/continuous-learning-v2/SKILL.md +360 -0
  344. package/resources/ecc/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
  345. package/resources/ecc/skills/continuous-learning-v2/agents/observer.md +198 -0
  346. package/resources/ecc/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  347. package/resources/ecc/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  348. package/resources/ecc/skills/continuous-learning-v2/config.json +8 -0
  349. package/resources/ecc/skills/continuous-learning-v2/hooks/observe.sh +476 -0
  350. package/resources/ecc/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
  351. package/resources/ecc/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
  352. package/resources/ecc/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  353. package/resources/ecc/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
  354. package/resources/ecc/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
  355. package/resources/ecc/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
  356. package/resources/ecc/skills/cost-tracking/SKILL.md +147 -0
  357. package/resources/ecc/skills/council/SKILL.md +203 -0
  358. package/resources/ecc/skills/cpp-coding-standards/SKILL.md +723 -0
  359. package/resources/ecc/skills/cpp-testing/SKILL.md +324 -0
  360. package/resources/ecc/skills/crosspost/SKILL.md +1 -0
  361. package/resources/ecc/skills/csharp-testing/SKILL.md +321 -0
  362. package/resources/ecc/skills/customer-billing-ops/SKILL.md +140 -0
  363. package/resources/ecc/skills/customs-trade-compliance/SKILL.md +263 -0
  364. package/resources/ecc/skills/dart-flutter-patterns/SKILL.md +563 -0
  365. package/resources/ecc/skills/dashboard-builder/SKILL.md +108 -0
  366. package/resources/ecc/skills/data-scraper-agent/SKILL.md +764 -0
  367. package/resources/ecc/skills/database-migrations/SKILL.md +429 -0
  368. package/resources/ecc/skills/deep-research/SKILL.md +5 -0
  369. package/resources/ecc/skills/defi-amm-security/SKILL.md +166 -0
  370. package/resources/ecc/skills/deployment-patterns/SKILL.md +427 -0
  371. package/resources/ecc/skills/design-system/SKILL.md +82 -0
  372. package/resources/ecc/skills/django-celery/SKILL.md +457 -0
  373. package/resources/ecc/skills/django-patterns/SKILL.md +734 -0
  374. package/resources/ecc/skills/django-security/SKILL.md +593 -0
  375. package/resources/ecc/skills/django-tdd/SKILL.md +729 -0
  376. package/resources/ecc/skills/django-verification/SKILL.md +469 -0
  377. package/resources/ecc/skills/dmux-workflows/SKILL.md +52 -4
  378. package/resources/ecc/skills/docker-patterns/SKILL.md +364 -0
  379. package/resources/ecc/skills/documentation-lookup/SKILL.md +1 -0
  380. package/resources/ecc/skills/dotnet-patterns/SKILL.md +321 -0
  381. package/resources/ecc/skills/e2e-testing/SKILL.md +1 -0
  382. package/resources/ecc/skills/ecc-guide/SKILL.md +189 -0
  383. package/resources/ecc/skills/ecc-tools-cost-audit/SKILL.md +160 -0
  384. package/resources/ecc/skills/email-ops/SKILL.md +121 -0
  385. package/resources/ecc/skills/energy-procurement/SKILL.md +228 -0
  386. package/resources/ecc/skills/enterprise-agent-ops/SKILL.md +50 -0
  387. package/resources/ecc/skills/error-handling/SKILL.md +376 -0
  388. package/resources/ecc/skills/eval-harness/SKILL.md +36 -1
  389. package/resources/ecc/skills/evm-token-decimals/SKILL.md +130 -0
  390. package/resources/ecc/skills/exa-search/SKILL.md +18 -80
  391. package/resources/ecc/skills/fal-ai-media/SKILL.md +32 -20
  392. package/resources/ecc/skills/fastapi-patterns/SKILL.md +327 -0
  393. package/resources/ecc/skills/finance-billing-ops/SKILL.md +127 -0
  394. package/resources/ecc/skills/flox-environments/SKILL.md +496 -0
  395. package/resources/ecc/skills/flutter-dart-code-review/SKILL.md +435 -0
  396. package/resources/ecc/skills/foundation-models-on-device/SKILL.md +243 -0
  397. package/resources/ecc/skills/frontend-design-direction/SKILL.md +92 -0
  398. package/resources/ecc/skills/frontend-patterns/SKILL.md +1 -6
  399. package/resources/ecc/skills/frontend-slides/SKILL.md +2 -1
  400. package/resources/ecc/skills/frontend-slides/animation-patterns.md +122 -0
  401. package/resources/ecc/skills/frontend-slides/html-template.md +419 -0
  402. package/resources/ecc/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  403. package/resources/ecc/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  404. package/resources/ecc/skills/frontend-slides/viewport-base.css +153 -0
  405. package/resources/ecc/skills/fsharp-testing/SKILL.md +280 -0
  406. package/resources/ecc/skills/gan-style-harness/SKILL.md +278 -0
  407. package/resources/ecc/skills/gateguard/SKILL.md +125 -0
  408. package/resources/ecc/skills/git-workflow/SKILL.md +715 -0
  409. package/resources/ecc/skills/github-ops/SKILL.md +144 -0
  410. package/resources/ecc/skills/golang-patterns/SKILL.md +674 -0
  411. package/resources/ecc/skills/golang-testing/SKILL.md +720 -0
  412. package/resources/ecc/skills/google-workspace-ops/SKILL.md +95 -0
  413. package/resources/ecc/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  414. package/resources/ecc/skills/healthcare-emr-patterns/SKILL.md +159 -0
  415. package/resources/ecc/skills/healthcare-eval-harness/SKILL.md +207 -0
  416. package/resources/ecc/skills/healthcare-phi-compliance/SKILL.md +145 -0
  417. package/resources/ecc/skills/hermes-imports/SKILL.md +88 -0
  418. package/resources/ecc/skills/hexagonal-architecture/SKILL.md +276 -0
  419. package/resources/ecc/skills/hipaa-compliance/SKILL.md +78 -0
  420. package/resources/ecc/skills/homelab-network-readiness/SKILL.md +169 -0
  421. package/resources/ecc/skills/homelab-network-setup/SKILL.md +129 -0
  422. package/resources/ecc/skills/homelab-pihole-dns/SKILL.md +274 -0
  423. package/resources/ecc/skills/homelab-vlan-segmentation/SKILL.md +311 -0
  424. package/resources/ecc/skills/homelab-wireguard-vpn/SKILL.md +305 -0
  425. package/resources/ecc/skills/hookify-rules/SKILL.md +128 -0
  426. package/resources/ecc/skills/inventory-demand-planning/SKILL.md +247 -0
  427. package/resources/ecc/skills/investor-materials/SKILL.md +1 -0
  428. package/resources/ecc/skills/investor-outreach/SKILL.md +1 -0
  429. package/resources/ecc/skills/ios-icon-gen/SKILL.md +157 -0
  430. package/resources/ecc/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  431. package/resources/ecc/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  432. package/resources/ecc/skills/iterative-retrieval/SKILL.md +211 -0
  433. package/resources/ecc/skills/java-coding-standards/SKILL.md +383 -0
  434. package/resources/ecc/skills/jira-integration/SKILL.md +293 -0
  435. package/resources/ecc/skills/jpa-patterns/SKILL.md +151 -0
  436. package/resources/ecc/skills/knowledge-ops/SKILL.md +154 -0
  437. package/resources/ecc/skills/kotlin-coroutines-flows/SKILL.md +284 -0
  438. package/resources/ecc/skills/kotlin-exposed-patterns/SKILL.md +719 -0
  439. package/resources/ecc/skills/kotlin-ktor-patterns/SKILL.md +689 -0
  440. package/resources/ecc/skills/kotlin-patterns/SKILL.md +711 -0
  441. package/resources/ecc/skills/kotlin-testing/SKILL.md +824 -0
  442. package/resources/ecc/skills/laravel-patterns/SKILL.md +415 -0
  443. package/resources/ecc/skills/laravel-plugin-discovery/SKILL.md +229 -0
  444. package/resources/ecc/skills/laravel-security/SKILL.md +285 -0
  445. package/resources/ecc/skills/laravel-tdd/SKILL.md +283 -0
  446. package/resources/ecc/skills/laravel-verification/SKILL.md +179 -0
  447. package/resources/ecc/skills/lead-intelligence/SKILL.md +321 -0
  448. package/resources/ecc/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  449. package/resources/ecc/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  450. package/resources/ecc/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  451. package/resources/ecc/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  452. package/resources/ecc/skills/liquid-glass-design/SKILL.md +279 -0
  453. package/resources/ecc/skills/llm-trading-agent-security/SKILL.md +146 -0
  454. package/resources/ecc/skills/logistics-exception-management/SKILL.md +222 -0
  455. package/resources/ecc/skills/make-interfaces-feel-better/SKILL.md +151 -0
  456. package/resources/ecc/skills/manim-video/SKILL.md +89 -0
  457. package/resources/ecc/skills/manim-video/assets/network_graph_scene.py +52 -0
  458. package/resources/ecc/skills/market-research/SKILL.md +1 -0
  459. package/resources/ecc/skills/mcp-server-patterns/SKILL.md +3 -0
  460. package/resources/ecc/skills/messages-ops/SKILL.md +104 -0
  461. package/resources/ecc/skills/mle-workflow/SKILL.md +1 -1
  462. package/resources/ecc/skills/motion-advanced/SKILL.md +596 -0
  463. package/resources/ecc/skills/motion-foundations/SKILL.md +299 -0
  464. package/resources/ecc/skills/motion-patterns/SKILL.md +435 -0
  465. package/resources/ecc/skills/motion-ui/SKILL.md +575 -0
  466. package/resources/ecc/skills/mysql-patterns/SKILL.md +412 -0
  467. package/resources/ecc/skills/nanoclaw-repl/SKILL.md +33 -0
  468. package/resources/ecc/skills/nestjs-patterns/SKILL.md +230 -0
  469. package/resources/ecc/skills/netmiko-ssh-automation/SKILL.md +173 -0
  470. package/resources/ecc/skills/network-bgp-diagnostics/SKILL.md +167 -0
  471. package/resources/ecc/skills/network-config-validation/SKILL.md +210 -0
  472. package/resources/ecc/skills/network-interface-health/SKILL.md +152 -0
  473. package/resources/ecc/skills/nextjs-turbopack/SKILL.md +1 -0
  474. package/resources/ecc/skills/nodejs-keccak256/SKILL.md +102 -0
  475. package/resources/ecc/skills/nutrient-document-processing/SKILL.md +167 -0
  476. package/resources/ecc/skills/nuxt4-patterns/SKILL.md +100 -0
  477. package/resources/ecc/skills/openclaw-persona-forge/SKILL.md +288 -0
  478. package/resources/ecc/skills/openclaw-persona-forge/gacha.py +224 -0
  479. package/resources/ecc/skills/openclaw-persona-forge/gacha.sh +5 -0
  480. package/resources/ecc/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  481. package/resources/ecc/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  482. package/resources/ecc/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  483. package/resources/ecc/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  484. package/resources/ecc/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  485. package/resources/ecc/skills/openclaw-persona-forge/references/output-template.md +166 -0
  486. package/resources/ecc/skills/opensource-pipeline/SKILL.md +255 -0
  487. package/resources/ecc/skills/perl-patterns/SKILL.md +504 -0
  488. package/resources/ecc/skills/perl-security/SKILL.md +503 -0
  489. package/resources/ecc/skills/perl-testing/SKILL.md +475 -0
  490. package/resources/ecc/skills/plan-orchestrate/SKILL.md +262 -0
  491. package/resources/ecc/skills/plankton-code-quality/SKILL.md +236 -0
  492. package/resources/ecc/skills/postgres-patterns/SKILL.md +147 -0
  493. package/resources/ecc/skills/product-capability/SKILL.md +1 -0
  494. package/resources/ecc/skills/product-lens/SKILL.md +92 -0
  495. package/resources/ecc/skills/production-audit/SKILL.md +206 -0
  496. package/resources/ecc/skills/production-scheduling/SKILL.md +238 -0
  497. package/resources/ecc/skills/project-flow-ops/SKILL.md +111 -0
  498. package/resources/ecc/skills/prompt-optimizer/SKILL.md +398 -0
  499. package/resources/ecc/skills/python-patterns/SKILL.md +750 -0
  500. package/resources/ecc/skills/python-testing/SKILL.md +816 -0
  501. package/resources/ecc/skills/pytorch-patterns/SKILL.md +396 -0
  502. package/resources/ecc/skills/quality-nonconformance/SKILL.md +260 -0
  503. package/resources/ecc/skills/quarkus-patterns/SKILL.md +722 -0
  504. package/resources/ecc/skills/quarkus-security/SKILL.md +467 -0
  505. package/resources/ecc/skills/quarkus-tdd/SKILL.md +811 -0
  506. package/resources/ecc/skills/quarkus-verification/SKILL.md +479 -0
  507. package/resources/ecc/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
  508. package/resources/ecc/skills/redis-patterns/SKILL.md +403 -0
  509. package/resources/ecc/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
  510. package/resources/ecc/skills/remotion-video-creation/SKILL.md +43 -0
  511. package/resources/ecc/skills/remotion-video-creation/rules/3d.md +86 -0
  512. package/resources/ecc/skills/remotion-video-creation/rules/animations.md +29 -0
  513. package/resources/ecc/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  514. package/resources/ecc/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  515. package/resources/ecc/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  516. package/resources/ecc/skills/remotion-video-creation/rules/assets.md +78 -0
  517. package/resources/ecc/skills/remotion-video-creation/rules/audio.md +172 -0
  518. package/resources/ecc/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  519. package/resources/ecc/skills/remotion-video-creation/rules/can-decode.md +75 -0
  520. package/resources/ecc/skills/remotion-video-creation/rules/charts.md +58 -0
  521. package/resources/ecc/skills/remotion-video-creation/rules/compositions.md +146 -0
  522. package/resources/ecc/skills/remotion-video-creation/rules/display-captions.md +126 -0
  523. package/resources/ecc/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  524. package/resources/ecc/skills/remotion-video-creation/rules/fonts.md +152 -0
  525. package/resources/ecc/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  526. package/resources/ecc/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  527. package/resources/ecc/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  528. package/resources/ecc/skills/remotion-video-creation/rules/gifs.md +138 -0
  529. package/resources/ecc/skills/remotion-video-creation/rules/images.md +130 -0
  530. package/resources/ecc/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  531. package/resources/ecc/skills/remotion-video-creation/rules/lottie.md +67 -0
  532. package/resources/ecc/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  533. package/resources/ecc/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  534. package/resources/ecc/skills/remotion-video-creation/rules/sequencing.md +106 -0
  535. package/resources/ecc/skills/remotion-video-creation/rules/tailwind.md +11 -0
  536. package/resources/ecc/skills/remotion-video-creation/rules/text-animations.md +20 -0
  537. package/resources/ecc/skills/remotion-video-creation/rules/timing.md +179 -0
  538. package/resources/ecc/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  539. package/resources/ecc/skills/remotion-video-creation/rules/transitions.md +122 -0
  540. package/resources/ecc/skills/remotion-video-creation/rules/trimming.md +52 -0
  541. package/resources/ecc/skills/remotion-video-creation/rules/videos.md +171 -0
  542. package/resources/ecc/skills/repo-scan/SKILL.md +78 -0
  543. package/resources/ecc/skills/research-ops/SKILL.md +112 -0
  544. package/resources/ecc/skills/returns-reverse-logistics/SKILL.md +240 -0
  545. package/resources/ecc/skills/rules-distill/SKILL.md +264 -0
  546. package/resources/ecc/skills/rules-distill/scripts/scan-rules.sh +58 -0
  547. package/resources/ecc/skills/rules-distill/scripts/scan-skills.sh +129 -0
  548. package/resources/ecc/skills/rust-patterns/SKILL.md +499 -0
  549. package/resources/ecc/skills/rust-testing/SKILL.md +500 -0
  550. package/resources/ecc/skills/safety-guard/SKILL.md +75 -0
  551. package/resources/ecc/skills/santa-method/SKILL.md +306 -0
  552. package/resources/ecc/skills/scientific-db-pubmed-database/SKILL.md +175 -0
  553. package/resources/ecc/skills/scientific-db-uspto-database/SKILL.md +177 -0
  554. package/resources/ecc/skills/scientific-pkg-gget/SKILL.md +166 -0
  555. package/resources/ecc/skills/scientific-thinking-literature-review/SKILL.md +192 -0
  556. package/resources/ecc/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
  557. package/resources/ecc/skills/search-first/SKILL.md +182 -0
  558. package/resources/ecc/skills/security-bounty-hunter/SKILL.md +99 -0
  559. package/resources/ecc/skills/security-review/SKILL.md +11 -2
  560. package/resources/ecc/skills/security-review/cloud-infrastructure-security.md +361 -0
  561. package/resources/ecc/skills/security-scan/SKILL.md +165 -0
  562. package/resources/ecc/skills/seo/SKILL.md +154 -0
  563. package/resources/ecc/skills/skill-comply/SKILL.md +58 -0
  564. package/resources/ecc/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  565. package/resources/ecc/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  566. package/resources/ecc/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  567. package/resources/ecc/skills/skill-comply/prompts/classifier.md +24 -0
  568. package/resources/ecc/skills/skill-comply/prompts/scenario_generator.md +62 -0
  569. package/resources/ecc/skills/skill-comply/prompts/spec_generator.md +42 -0
  570. package/resources/ecc/skills/skill-comply/pyproject.toml +15 -0
  571. package/resources/ecc/skills/skill-comply/scripts/__init__.py +0 -0
  572. package/resources/ecc/skills/skill-comply/scripts/classifier.py +85 -0
  573. package/resources/ecc/skills/skill-comply/scripts/grader.py +124 -0
  574. package/resources/ecc/skills/skill-comply/scripts/parser.py +107 -0
  575. package/resources/ecc/skills/skill-comply/scripts/report.py +170 -0
  576. package/resources/ecc/skills/skill-comply/scripts/run.py +127 -0
  577. package/resources/ecc/skills/skill-comply/scripts/runner.py +186 -0
  578. package/resources/ecc/skills/skill-comply/scripts/scenario_generator.py +70 -0
  579. package/resources/ecc/skills/skill-comply/scripts/spec_generator.py +72 -0
  580. package/resources/ecc/skills/skill-comply/scripts/utils.py +13 -0
  581. package/resources/ecc/skills/skill-comply/tests/test_grader.py +197 -0
  582. package/resources/ecc/skills/skill-comply/tests/test_parser.py +90 -0
  583. package/resources/ecc/skills/skill-comply/tests/test_runner.py +172 -0
  584. package/resources/ecc/skills/skill-scout/SKILL.md +140 -0
  585. package/resources/ecc/skills/skill-stocktake/SKILL.md +194 -0
  586. package/resources/ecc/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  587. package/resources/ecc/skills/skill-stocktake/scripts/save-results.sh +56 -0
  588. package/resources/ecc/skills/skill-stocktake/scripts/scan.sh +170 -0
  589. package/resources/ecc/skills/social-graph-ranker/SKILL.md +154 -0
  590. package/resources/ecc/skills/springboot-patterns/SKILL.md +314 -0
  591. package/resources/ecc/skills/springboot-security/SKILL.md +272 -0
  592. package/resources/ecc/skills/springboot-tdd/SKILL.md +158 -0
  593. package/resources/ecc/skills/springboot-verification/SKILL.md +231 -0
  594. package/resources/ecc/skills/strategic-compact/SKILL.md +31 -2
  595. package/resources/ecc/skills/strategic-compact/suggest-compact.sh +54 -0
  596. package/resources/ecc/skills/swift-actor-persistence/SKILL.md +143 -0
  597. package/resources/ecc/skills/swift-concurrency-6-2/SKILL.md +216 -0
  598. package/resources/ecc/skills/swift-protocol-di-testing/SKILL.md +190 -0
  599. package/resources/ecc/skills/swiftui-patterns/SKILL.md +259 -0
  600. package/resources/ecc/skills/tdd-workflow/SKILL.md +54 -0
  601. package/resources/ecc/skills/team-builder/SKILL.md +168 -0
  602. package/resources/ecc/skills/terminal-ops/SKILL.md +109 -0
  603. package/resources/ecc/skills/tinystruct-patterns/SKILL.md +131 -0
  604. package/resources/ecc/skills/tinystruct-patterns/references/architecture.md +77 -0
  605. package/resources/ecc/skills/tinystruct-patterns/references/data-handling.md +35 -0
  606. package/resources/ecc/skills/tinystruct-patterns/references/routing.md +57 -0
  607. package/resources/ecc/skills/tinystruct-patterns/references/system-usage.md +74 -0
  608. package/resources/ecc/skills/tinystruct-patterns/references/testing.md +59 -0
  609. package/resources/ecc/skills/token-budget-advisor/SKILL.md +133 -0
  610. package/resources/ecc/skills/ui-demo/SKILL.md +465 -0
  611. package/resources/ecc/skills/ui-to-vue/SKILL.md +134 -0
  612. package/resources/ecc/skills/unified-notifications-ops/SKILL.md +187 -0
  613. package/resources/ecc/skills/verification-loop/SKILL.md +1 -0
  614. package/resources/ecc/skills/video-editing/SKILL.md +4 -1
  615. package/resources/ecc/skills/videodb/SKILL.md +374 -0
  616. package/resources/ecc/skills/videodb/reference/api-reference.md +550 -0
  617. package/resources/ecc/skills/videodb/reference/capture-reference.md +407 -0
  618. package/resources/ecc/skills/videodb/reference/capture.md +101 -0
  619. package/resources/ecc/skills/videodb/reference/editor.md +443 -0
  620. package/resources/ecc/skills/videodb/reference/generative.md +331 -0
  621. package/resources/ecc/skills/videodb/reference/rtstream-reference.md +564 -0
  622. package/resources/ecc/skills/videodb/reference/rtstream.md +65 -0
  623. package/resources/ecc/skills/videodb/reference/search.md +230 -0
  624. package/resources/ecc/skills/videodb/reference/streaming.md +406 -0
  625. package/resources/ecc/skills/videodb/reference/use-cases.md +118 -0
  626. package/resources/ecc/skills/videodb/scripts/ws_listener.py +282 -0
  627. package/resources/ecc/skills/visa-doc-translate/README.md +86 -0
  628. package/resources/ecc/skills/visa-doc-translate/SKILL.md +117 -0
  629. package/resources/ecc/skills/vite-patterns/SKILL.md +449 -0
  630. package/resources/ecc/skills/windows-desktop-e2e/SKILL.md +788 -0
  631. package/resources/ecc/skills/workspace-surface-audit/SKILL.md +125 -0
  632. package/resources/ecc/skills/x-api/SKILL.md +5 -0
  633. package/resources/ecc/agents/architect.json +0 -16
  634. package/resources/ecc/agents/build-error-resolver.json +0 -17
  635. package/resources/ecc/agents/chief-of-staff.json +0 -17
  636. package/resources/ecc/agents/code-reviewer.json +0 -16
  637. package/resources/ecc/agents/database-reviewer.json +0 -16
  638. package/resources/ecc/agents/doc-updater.json +0 -16
  639. package/resources/ecc/agents/e2e-runner.json +0 -17
  640. package/resources/ecc/agents/go-build-resolver.json +0 -17
  641. package/resources/ecc/agents/go-reviewer.json +0 -16
  642. package/resources/ecc/agents/harness-optimizer.json +0 -15
  643. package/resources/ecc/agents/loop-operator.json +0 -16
  644. package/resources/ecc/agents/planner.json +0 -15
  645. package/resources/ecc/agents/python-reviewer.json +0 -16
  646. package/resources/ecc/agents/refactor-cleaner.json +0 -17
  647. package/resources/ecc/agents/security-reviewer.json +0 -16
  648. package/resources/ecc/agents/tdd-guide.json +0 -17
  649. package/resources/ecc/commands/add-language-rules.md +0 -39
  650. package/resources/ecc/commands/database-migration.md +0 -36
  651. package/resources/ecc/commands/feature-development.md +0 -38
  652. package/resources/ecc/rules/common-development-workflow.md +0 -33
  653. package/resources/ecc/rules/kotlin-coding-style.md +0 -39
  654. package/resources/ecc/rules/kotlin-patterns.md +0 -50
  655. package/resources/ecc/rules/kotlin-security.md +0 -58
  656. package/resources/ecc/rules/kotlin-testing.md +0 -38
  657. package/resources/ecc/rules/php-coding-style.md +0 -25
  658. package/resources/ecc/rules/php-patterns.md +0 -23
  659. package/resources/ecc/rules/php-security.md +0 -24
  660. package/resources/ecc/rules/php-testing.md +0 -26
  661. package/resources/ecc/rules/swift-hooks.md +0 -20
  662. package/resources/ecc/rules/typescript-coding-style.md +0 -63
  663. package/resources/ecc/rules/typescript-testing.md +0 -16
  664. package/resources/ecc/skills/agent-introspection-debugging/agents/openai.yaml +0 -7
  665. package/resources/ecc/skills/agent-sort/agents/openai.yaml +0 -7
  666. package/resources/ecc/skills/api-design/agents/openai.yaml +0 -7
  667. package/resources/ecc/skills/article-writing/agents/openai.yaml +0 -7
  668. package/resources/ecc/skills/backend-patterns/agents/openai.yaml +0 -7
  669. package/resources/ecc/skills/brand-voice/agents/openai.yaml +0 -7
  670. package/resources/ecc/skills/bun-runtime/agents/openai.yaml +0 -7
  671. package/resources/ecc/skills/coding-standards/agents/openai.yaml +0 -7
  672. package/resources/ecc/skills/content-engine/agents/openai.yaml +0 -7
  673. package/resources/ecc/skills/crosspost/agents/openai.yaml +0 -7
  674. package/resources/ecc/skills/deep-research/agents/openai.yaml +0 -7
  675. package/resources/ecc/skills/dmux-workflows/agents/openai.yaml +0 -7
  676. package/resources/ecc/skills/documentation-lookup/agents/openai.yaml +0 -7
  677. package/resources/ecc/skills/e2e-testing/agents/openai.yaml +0 -7
  678. package/resources/ecc/skills/eval-harness/agents/openai.yaml +0 -7
  679. package/resources/ecc/skills/everything-claude-code/SKILL.md +0 -442
  680. package/resources/ecc/skills/everything-claude-code/agents/openai.yaml +0 -7
  681. package/resources/ecc/skills/exa-search/agents/openai.yaml +0 -7
  682. package/resources/ecc/skills/fal-ai-media/agents/openai.yaml +0 -7
  683. package/resources/ecc/skills/frontend-patterns/agents/openai.yaml +0 -7
  684. package/resources/ecc/skills/frontend-slides/agents/openai.yaml +0 -7
  685. package/resources/ecc/skills/investor-materials/agents/openai.yaml +0 -7
  686. package/resources/ecc/skills/investor-outreach/agents/openai.yaml +0 -7
  687. package/resources/ecc/skills/market-research/agents/openai.yaml +0 -7
  688. package/resources/ecc/skills/mcp-server-patterns/agents/openai.yaml +0 -7
  689. package/resources/ecc/skills/mle-workflow/agents/openai.yaml +0 -7
  690. package/resources/ecc/skills/nextjs-turbopack/agents/openai.yaml +0 -7
  691. package/resources/ecc/skills/product-capability/agents/openai.yaml +0 -7
  692. package/resources/ecc/skills/security-review/agents/openai.yaml +0 -7
  693. package/resources/ecc/skills/strategic-compact/agents/openai.yaml +0 -7
  694. package/resources/ecc/skills/tdd-workflow/agents/openai.yaml +0 -7
  695. package/resources/ecc/skills/verification-loop/agents/openai.yaml +0 -7
  696. package/resources/ecc/skills/video-editing/agents/openai.yaml +0 -7
  697. package/resources/ecc/skills/x-api/agents/openai.yaml +0 -7
@@ -0,0 +1,314 @@
1
+ ---
2
+ name: springboot-patterns
3
+ description: Spring Boot architecture patterns, REST API design, layered services, data access, caching, async processing, and logging. Use for Java Spring Boot backend work.
4
+ origin: ECC
5
+ ---
6
+
7
+ # Spring Boot Development Patterns
8
+
9
+ Spring Boot architecture and API patterns for scalable, production-grade services.
10
+
11
+ ## When to Activate
12
+
13
+ - Building REST APIs with Spring MVC or WebFlux
14
+ - Structuring controller → service → repository layers
15
+ - Configuring Spring Data JPA, caching, or async processing
16
+ - Adding validation, exception handling, or pagination
17
+ - Setting up profiles for dev/staging/production environments
18
+ - Implementing event-driven patterns with Spring Events or Kafka
19
+
20
+ ## REST API Structure
21
+
22
+ ```java
23
+ @RestController
24
+ @RequestMapping("/api/markets")
25
+ @Validated
26
+ class MarketController {
27
+ private final MarketService marketService;
28
+
29
+ MarketController(MarketService marketService) {
30
+ this.marketService = marketService;
31
+ }
32
+
33
+ @GetMapping
34
+ ResponseEntity<Page<MarketResponse>> list(
35
+ @RequestParam(defaultValue = "0") int page,
36
+ @RequestParam(defaultValue = "20") int size) {
37
+ Page<Market> markets = marketService.list(PageRequest.of(page, size));
38
+ return ResponseEntity.ok(markets.map(MarketResponse::from));
39
+ }
40
+
41
+ @PostMapping
42
+ ResponseEntity<MarketResponse> create(@Valid @RequestBody CreateMarketRequest request) {
43
+ Market market = marketService.create(request);
44
+ return ResponseEntity.status(HttpStatus.CREATED).body(MarketResponse.from(market));
45
+ }
46
+ }
47
+ ```
48
+
49
+ ## Repository Pattern (Spring Data JPA)
50
+
51
+ ```java
52
+ public interface MarketRepository extends JpaRepository<MarketEntity, Long> {
53
+ @Query("select m from MarketEntity m where m.status = :status order by m.volume desc")
54
+ List<MarketEntity> findActive(@Param("status") MarketStatus status, Pageable pageable);
55
+ }
56
+ ```
57
+
58
+ ## Service Layer with Transactions
59
+
60
+ ```java
61
+ @Service
62
+ public class MarketService {
63
+ private final MarketRepository repo;
64
+
65
+ public MarketService(MarketRepository repo) {
66
+ this.repo = repo;
67
+ }
68
+
69
+ @Transactional
70
+ public Market create(CreateMarketRequest request) {
71
+ MarketEntity entity = MarketEntity.from(request);
72
+ MarketEntity saved = repo.save(entity);
73
+ return Market.from(saved);
74
+ }
75
+ }
76
+ ```
77
+
78
+ ## DTOs and Validation
79
+
80
+ ```java
81
+ public record CreateMarketRequest(
82
+ @NotBlank @Size(max = 200) String name,
83
+ @NotBlank @Size(max = 2000) String description,
84
+ @NotNull @FutureOrPresent Instant endDate,
85
+ @NotEmpty List<@NotBlank String> categories) {}
86
+
87
+ public record MarketResponse(Long id, String name, MarketStatus status) {
88
+ static MarketResponse from(Market market) {
89
+ return new MarketResponse(market.id(), market.name(), market.status());
90
+ }
91
+ }
92
+ ```
93
+
94
+ ## Exception Handling
95
+
96
+ ```java
97
+ @ControllerAdvice
98
+ class GlobalExceptionHandler {
99
+ @ExceptionHandler(MethodArgumentNotValidException.class)
100
+ ResponseEntity<ApiError> handleValidation(MethodArgumentNotValidException ex) {
101
+ String message = ex.getBindingResult().getFieldErrors().stream()
102
+ .map(e -> e.getField() + ": " + e.getDefaultMessage())
103
+ .collect(Collectors.joining(", "));
104
+ return ResponseEntity.badRequest().body(ApiError.validation(message));
105
+ }
106
+
107
+ @ExceptionHandler(AccessDeniedException.class)
108
+ ResponseEntity<ApiError> handleAccessDenied() {
109
+ return ResponseEntity.status(HttpStatus.FORBIDDEN).body(ApiError.of("Forbidden"));
110
+ }
111
+
112
+ @ExceptionHandler(Exception.class)
113
+ ResponseEntity<ApiError> handleGeneric(Exception ex) {
114
+ // Log unexpected errors with stack traces
115
+ return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR)
116
+ .body(ApiError.of("Internal server error"));
117
+ }
118
+ }
119
+ ```
120
+
121
+ ## Caching
122
+
123
+ Requires `@EnableCaching` on a configuration class.
124
+
125
+ ```java
126
+ @Service
127
+ public class MarketCacheService {
128
+ private final MarketRepository repo;
129
+
130
+ public MarketCacheService(MarketRepository repo) {
131
+ this.repo = repo;
132
+ }
133
+
134
+ @Cacheable(value = "market", key = "#id")
135
+ public Market getById(Long id) {
136
+ return repo.findById(id)
137
+ .map(Market::from)
138
+ .orElseThrow(() -> new EntityNotFoundException("Market not found"));
139
+ }
140
+
141
+ @CacheEvict(value = "market", key = "#id")
142
+ public void evict(Long id) {}
143
+ }
144
+ ```
145
+
146
+ ## Async Processing
147
+
148
+ Requires `@EnableAsync` on a configuration class.
149
+
150
+ ```java
151
+ @Service
152
+ public class NotificationService {
153
+ @Async
154
+ public CompletableFuture<Void> sendAsync(Notification notification) {
155
+ // send email/SMS
156
+ return CompletableFuture.completedFuture(null);
157
+ }
158
+ }
159
+ ```
160
+
161
+ ## Logging (SLF4J)
162
+
163
+ ```java
164
+ @Service
165
+ public class ReportService {
166
+ private static final Logger log = LoggerFactory.getLogger(ReportService.class);
167
+
168
+ public Report generate(Long marketId) {
169
+ log.info("generate_report marketId={}", marketId);
170
+ try {
171
+ // logic
172
+ } catch (Exception ex) {
173
+ log.error("generate_report_failed marketId={}", marketId, ex);
174
+ throw ex;
175
+ }
176
+ return new Report();
177
+ }
178
+ }
179
+ ```
180
+
181
+ ## Middleware / Filters
182
+
183
+ ```java
184
+ @Component
185
+ public class RequestLoggingFilter extends OncePerRequestFilter {
186
+ private static final Logger log = LoggerFactory.getLogger(RequestLoggingFilter.class);
187
+
188
+ @Override
189
+ protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response,
190
+ FilterChain filterChain) throws ServletException, IOException {
191
+ long start = System.currentTimeMillis();
192
+ try {
193
+ filterChain.doFilter(request, response);
194
+ } finally {
195
+ long duration = System.currentTimeMillis() - start;
196
+ log.info("req method={} uri={} status={} durationMs={}",
197
+ request.getMethod(), request.getRequestURI(), response.getStatus(), duration);
198
+ }
199
+ }
200
+ }
201
+ ```
202
+
203
+ ## Pagination and Sorting
204
+
205
+ ```java
206
+ PageRequest page = PageRequest.of(pageNumber, pageSize, Sort.by("createdAt").descending());
207
+ Page<Market> results = marketService.list(page);
208
+ ```
209
+
210
+ ## Error-Resilient External Calls
211
+
212
+ ```java
213
+ public <T> T withRetry(Supplier<T> supplier, int maxRetries) {
214
+ int attempts = 0;
215
+ while (true) {
216
+ try {
217
+ return supplier.get();
218
+ } catch (Exception ex) {
219
+ attempts++;
220
+ if (attempts >= maxRetries) {
221
+ throw ex;
222
+ }
223
+ try {
224
+ Thread.sleep((long) Math.pow(2, attempts) * 100L);
225
+ } catch (InterruptedException ie) {
226
+ Thread.currentThread().interrupt();
227
+ throw ex;
228
+ }
229
+ }
230
+ }
231
+ }
232
+ ```
233
+
234
+ ## Rate Limiting (Filter + Bucket4j)
235
+
236
+ **Security Note**: The `X-Forwarded-For` header is untrusted by default because clients can spoof it.
237
+ Only use forwarded headers when:
238
+ 1. Your app is behind a trusted reverse proxy (nginx, AWS ALB, etc.)
239
+ 2. You have registered `ForwardedHeaderFilter` as a bean
240
+ 3. You have configured `server.forward-headers-strategy=NATIVE` or `FRAMEWORK` in application properties
241
+ 4. Your proxy is configured to overwrite (not append to) the `X-Forwarded-For` header
242
+
243
+ When `ForwardedHeaderFilter` is properly configured, `request.getRemoteAddr()` will automatically
244
+ return the correct client IP from the forwarded headers. Without this configuration, use
245
+ `request.getRemoteAddr()` directly—it returns the immediate connection IP, which is the only
246
+ trustworthy value.
247
+
248
+ ```java
249
+ @Component
250
+ public class RateLimitFilter extends OncePerRequestFilter {
251
+ private final Map<String, Bucket> buckets = new ConcurrentHashMap<>();
252
+
253
+ /*
254
+ * SECURITY: This filter uses request.getRemoteAddr() to identify clients for rate limiting.
255
+ *
256
+ * If your application is behind a reverse proxy (nginx, AWS ALB, etc.), you MUST configure
257
+ * Spring to handle forwarded headers properly for accurate client IP detection:
258
+ *
259
+ * 1. Set server.forward-headers-strategy=NATIVE (for cloud platforms) or FRAMEWORK in
260
+ * application.properties/yaml
261
+ * 2. If using FRAMEWORK strategy, register ForwardedHeaderFilter:
262
+ *
263
+ * @Bean
264
+ * ForwardedHeaderFilter forwardedHeaderFilter() {
265
+ * return new ForwardedHeaderFilter();
266
+ * }
267
+ *
268
+ * 3. Ensure your proxy overwrites (not appends) the X-Forwarded-For header to prevent spoofing
269
+ * 4. Configure server.tomcat.remoteip.trusted-proxies or equivalent for your container
270
+ *
271
+ * Without this configuration, request.getRemoteAddr() returns the proxy IP, not the client IP.
272
+ * Do NOT read X-Forwarded-For directly—it is trivially spoofable without trusted proxy handling.
273
+ */
274
+ @Override
275
+ protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response,
276
+ FilterChain filterChain) throws ServletException, IOException {
277
+ // Use getRemoteAddr() which returns the correct client IP when ForwardedHeaderFilter
278
+ // is configured, or the direct connection IP otherwise. Never trust X-Forwarded-For
279
+ // headers directly without proper proxy configuration.
280
+ String clientIp = request.getRemoteAddr();
281
+
282
+ Bucket bucket = buckets.computeIfAbsent(clientIp,
283
+ k -> Bucket.builder()
284
+ .addLimit(Bandwidth.classic(100, Refill.greedy(100, Duration.ofMinutes(1))))
285
+ .build());
286
+
287
+ if (bucket.tryConsume(1)) {
288
+ filterChain.doFilter(request, response);
289
+ } else {
290
+ response.setStatus(HttpStatus.TOO_MANY_REQUESTS.value());
291
+ }
292
+ }
293
+ }
294
+ ```
295
+
296
+ ## Background Jobs
297
+
298
+ Use Spring’s `@Scheduled` or integrate with queues (e.g., Kafka, SQS, RabbitMQ). Keep handlers idempotent and observable.
299
+
300
+ ## Observability
301
+
302
+ - Structured logging (JSON) via Logback encoder
303
+ - Metrics: Micrometer + Prometheus/OTel
304
+ - Tracing: Micrometer Tracing with OpenTelemetry or Brave backend
305
+
306
+ ## Production Defaults
307
+
308
+ - Prefer constructor injection, avoid field injection
309
+ - Enable `spring.mvc.problemdetails.enabled=true` for RFC 7807 errors (Spring Boot 3+)
310
+ - Configure HikariCP pool sizes for workload, set timeouts
311
+ - Use `@Transactional(readOnly = true)` for queries
312
+ - Enforce null-safety via `@NonNull` and `Optional` where appropriate
313
+
314
+ **Remember**: Keep controllers thin, services focused, repositories simple, and errors handled centrally. Optimize for maintainability and testability.
@@ -0,0 +1,272 @@
1
+ ---
2
+ name: springboot-security
3
+ description: Spring Security best practices for authn/authz, validation, CSRF, secrets, headers, rate limiting, and dependency security in Java Spring Boot services.
4
+ origin: ECC
5
+ ---
6
+
7
+ # Spring Boot Security Review
8
+
9
+ Use when adding auth, handling input, creating endpoints, or dealing with secrets.
10
+
11
+ ## When to Activate
12
+
13
+ - Adding authentication (JWT, OAuth2, session-based)
14
+ - Implementing authorization (@PreAuthorize, role-based access)
15
+ - Validating user input (Bean Validation, custom validators)
16
+ - Configuring CORS, CSRF, or security headers
17
+ - Managing secrets (Vault, environment variables)
18
+ - Adding rate limiting or brute-force protection
19
+ - Scanning dependencies for CVEs
20
+
21
+ ## Authentication
22
+
23
+ - Prefer stateless JWT or opaque tokens with revocation list
24
+ - Use `httpOnly`, `Secure`, `SameSite=Strict` cookies for sessions
25
+ - Validate tokens with `OncePerRequestFilter` or resource server
26
+
27
+ ```java
28
+ @Component
29
+ public class JwtAuthFilter extends OncePerRequestFilter {
30
+ private final JwtService jwtService;
31
+
32
+ public JwtAuthFilter(JwtService jwtService) {
33
+ this.jwtService = jwtService;
34
+ }
35
+
36
+ @Override
37
+ protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response,
38
+ FilterChain chain) throws ServletException, IOException {
39
+ String header = request.getHeader(HttpHeaders.AUTHORIZATION);
40
+ if (header != null && header.startsWith("Bearer ")) {
41
+ String token = header.substring(7);
42
+ Authentication auth = jwtService.authenticate(token);
43
+ SecurityContextHolder.getContext().setAuthentication(auth);
44
+ }
45
+ chain.doFilter(request, response);
46
+ }
47
+ }
48
+ ```
49
+
50
+ ## Authorization
51
+
52
+ - Enable method security: `@EnableMethodSecurity`
53
+ - Use `@PreAuthorize("hasRole('ADMIN')")` or `@PreAuthorize("@authz.canEdit(#id)")`
54
+ - Deny by default; expose only required scopes
55
+
56
+ ```java
57
+ @RestController
58
+ @RequestMapping("/api/admin")
59
+ public class AdminController {
60
+
61
+ @PreAuthorize("hasRole('ADMIN')")
62
+ @GetMapping("/users")
63
+ public List<UserDto> listUsers() {
64
+ return userService.findAll();
65
+ }
66
+
67
+ @PreAuthorize("@authz.isOwner(#id, authentication)")
68
+ @DeleteMapping("/users/{id}")
69
+ public ResponseEntity<Void> deleteUser(@PathVariable Long id) {
70
+ userService.delete(id);
71
+ return ResponseEntity.noContent().build();
72
+ }
73
+ }
74
+ ```
75
+
76
+ ## Input Validation
77
+
78
+ - Use Bean Validation with `@Valid` on controllers
79
+ - Apply constraints on DTOs: `@NotBlank`, `@Email`, `@Size`, custom validators
80
+ - Sanitize any HTML with a whitelist before rendering
81
+
82
+ ```java
83
+ // BAD: No validation
84
+ @PostMapping("/users")
85
+ public User createUser(@RequestBody UserDto dto) {
86
+ return userService.create(dto);
87
+ }
88
+
89
+ // GOOD: Validated DTO
90
+ public record CreateUserDto(
91
+ @NotBlank @Size(max = 100) String name,
92
+ @NotBlank @Email String email,
93
+ @NotNull @Min(0) @Max(150) Integer age
94
+ ) {}
95
+
96
+ @PostMapping("/users")
97
+ public ResponseEntity<UserDto> createUser(@Valid @RequestBody CreateUserDto dto) {
98
+ return ResponseEntity.status(HttpStatus.CREATED)
99
+ .body(userService.create(dto));
100
+ }
101
+ ```
102
+
103
+ ## SQL Injection Prevention
104
+
105
+ - Use Spring Data repositories or parameterized queries
106
+ - For native queries, use `:param` bindings; never concatenate strings
107
+
108
+ ```java
109
+ // BAD: String concatenation in native query
110
+ @Query(value = "SELECT * FROM users WHERE name = '" + name + "'", nativeQuery = true)
111
+
112
+ // GOOD: Parameterized native query
113
+ @Query(value = "SELECT * FROM users WHERE name = :name", nativeQuery = true)
114
+ List<User> findByName(@Param("name") String name);
115
+
116
+ // GOOD: Spring Data derived query (auto-parameterized)
117
+ List<User> findByEmailAndActiveTrue(String email);
118
+ ```
119
+
120
+ ## Password Encoding
121
+
122
+ - Always hash passwords with BCrypt or Argon2 — never store plaintext
123
+ - Use `PasswordEncoder` bean, not manual hashing
124
+
125
+ ```java
126
+ @Bean
127
+ public PasswordEncoder passwordEncoder() {
128
+ return new BCryptPasswordEncoder(12); // cost factor 12
129
+ }
130
+
131
+ // In service
132
+ public User register(CreateUserDto dto) {
133
+ String hashedPassword = passwordEncoder.encode(dto.password());
134
+ return userRepository.save(new User(dto.email(), hashedPassword));
135
+ }
136
+ ```
137
+
138
+ ## CSRF Protection
139
+
140
+ - For browser session apps, keep CSRF enabled; include token in forms/headers
141
+ - For pure APIs with Bearer tokens, disable CSRF and rely on stateless auth
142
+
143
+ ```java
144
+ http
145
+ .csrf(csrf -> csrf.disable())
146
+ .sessionManagement(sm -> sm.sessionCreationPolicy(SessionCreationPolicy.STATELESS));
147
+ ```
148
+
149
+ ## Secrets Management
150
+
151
+ - No secrets in source; load from env or vault
152
+ - Keep `application.yml` free of credentials; use placeholders
153
+ - Rotate tokens and DB credentials regularly
154
+
155
+ ```yaml
156
+ # BAD: Hardcoded in application.yml
157
+ spring:
158
+ datasource:
159
+ password: mySecretPassword123
160
+
161
+ # GOOD: Environment variable placeholder
162
+ spring:
163
+ datasource:
164
+ password: ${DB_PASSWORD}
165
+
166
+ # GOOD: Spring Cloud Vault integration
167
+ spring:
168
+ cloud:
169
+ vault:
170
+ uri: https://vault.example.com
171
+ token: ${VAULT_TOKEN}
172
+ ```
173
+
174
+ ## Security Headers
175
+
176
+ ```java
177
+ http
178
+ .headers(headers -> headers
179
+ .contentSecurityPolicy(csp -> csp
180
+ .policyDirectives("default-src 'self'"))
181
+ .frameOptions(HeadersConfigurer.FrameOptionsConfig::sameOrigin)
182
+ .xssProtection(Customizer.withDefaults())
183
+ .referrerPolicy(rp -> rp.policy(ReferrerPolicyHeaderWriter.ReferrerPolicy.NO_REFERRER)));
184
+ ```
185
+
186
+ ## CORS Configuration
187
+
188
+ - Configure CORS at the security filter level, not per-controller
189
+ - Restrict allowed origins — never use `*` in production
190
+
191
+ ```java
192
+ @Bean
193
+ public CorsConfigurationSource corsConfigurationSource() {
194
+ CorsConfiguration config = new CorsConfiguration();
195
+ config.setAllowedOrigins(List.of("https://app.example.com"));
196
+ config.setAllowedMethods(List.of("GET", "POST", "PUT", "DELETE"));
197
+ config.setAllowedHeaders(List.of("Authorization", "Content-Type"));
198
+ config.setAllowCredentials(true);
199
+ config.setMaxAge(3600L);
200
+
201
+ UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
202
+ source.registerCorsConfiguration("/api/**", config);
203
+ return source;
204
+ }
205
+
206
+ // In SecurityFilterChain:
207
+ http.cors(cors -> cors.configurationSource(corsConfigurationSource()));
208
+ ```
209
+
210
+ ## Rate Limiting
211
+
212
+ - Apply Bucket4j or gateway-level limits on expensive endpoints
213
+ - Log and alert on bursts; return 429 with retry hints
214
+
215
+ ```java
216
+ // Using Bucket4j for per-endpoint rate limiting
217
+ @Component
218
+ public class RateLimitFilter extends OncePerRequestFilter {
219
+ private final Map<String, Bucket> buckets = new ConcurrentHashMap<>();
220
+
221
+ private Bucket createBucket() {
222
+ return Bucket.builder()
223
+ .addLimit(Bandwidth.classic(100, Refill.intervally(100, Duration.ofMinutes(1))))
224
+ .build();
225
+ }
226
+
227
+ @Override
228
+ protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response,
229
+ FilterChain chain) throws ServletException, IOException {
230
+ String clientIp = request.getRemoteAddr();
231
+ Bucket bucket = buckets.computeIfAbsent(clientIp, k -> createBucket());
232
+
233
+ if (bucket.tryConsume(1)) {
234
+ chain.doFilter(request, response);
235
+ } else {
236
+ response.setStatus(HttpStatus.TOO_MANY_REQUESTS.value());
237
+ response.getWriter().write("{\"error\": \"Rate limit exceeded\"}");
238
+ }
239
+ }
240
+ }
241
+ ```
242
+
243
+ ## Dependency Security
244
+
245
+ - Run OWASP Dependency Check / Snyk in CI
246
+ - Keep Spring Boot and Spring Security on supported versions
247
+ - Fail builds on known CVEs
248
+
249
+ ## Logging and PII
250
+
251
+ - Never log secrets, tokens, passwords, or full PAN data
252
+ - Redact sensitive fields; use structured JSON logging
253
+
254
+ ## File Uploads
255
+
256
+ - Validate size, content type, and extension
257
+ - Store outside web root; scan if required
258
+
259
+ ## Checklist Before Release
260
+
261
+ - [ ] Auth tokens validated and expired correctly
262
+ - [ ] Authorization guards on every sensitive path
263
+ - [ ] All inputs validated and sanitized
264
+ - [ ] No string-concatenated SQL
265
+ - [ ] CSRF posture correct for app type
266
+ - [ ] Secrets externalized; none committed
267
+ - [ ] Security headers configured
268
+ - [ ] Rate limiting on APIs
269
+ - [ ] Dependencies scanned and up to date
270
+ - [ ] Logs free of sensitive data
271
+
272
+ **Remember**: Deny by default, validate inputs, least privilege, and secure-by-configuration first.