tribunal-kit 2.4.6 → 3.1.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 (250) hide show
  1. package/.agent/ARCHITECTURE.md +99 -99
  2. package/.agent/GEMINI.md +52 -52
  3. package/.agent/agents/accessibility-reviewer.md +139 -86
  4. package/.agent/agents/ai-code-reviewer.md +160 -90
  5. package/.agent/agents/backend-specialist.md +164 -127
  6. package/.agent/agents/code-archaeologist.md +115 -73
  7. package/.agent/agents/database-architect.md +130 -110
  8. package/.agent/agents/debugger.md +137 -97
  9. package/.agent/agents/dependency-reviewer.md +78 -30
  10. package/.agent/agents/devops-engineer.md +161 -118
  11. package/.agent/agents/documentation-writer.md +151 -87
  12. package/.agent/agents/explorer-agent.md +117 -99
  13. package/.agent/agents/frontend-reviewer.md +127 -47
  14. package/.agent/agents/frontend-specialist.md +169 -109
  15. package/.agent/agents/game-developer.md +28 -164
  16. package/.agent/agents/logic-reviewer.md +87 -49
  17. package/.agent/agents/mobile-developer.md +151 -103
  18. package/.agent/agents/mobile-reviewer.md +133 -50
  19. package/.agent/agents/orchestrator.md +121 -110
  20. package/.agent/agents/penetration-tester.md +103 -77
  21. package/.agent/agents/performance-optimizer.md +136 -92
  22. package/.agent/agents/performance-reviewer.md +139 -69
  23. package/.agent/agents/product-manager.md +104 -70
  24. package/.agent/agents/product-owner.md +6 -25
  25. package/.agent/agents/project-planner.md +95 -95
  26. package/.agent/agents/qa-automation-engineer.md +174 -87
  27. package/.agent/agents/security-auditor.md +133 -129
  28. package/.agent/agents/seo-specialist.md +160 -99
  29. package/.agent/agents/sql-reviewer.md +132 -44
  30. package/.agent/agents/supervisor-agent.md +137 -109
  31. package/.agent/agents/swarm-worker-contracts.md +17 -17
  32. package/.agent/agents/swarm-worker-registry.md +46 -46
  33. package/.agent/agents/test-coverage-reviewer.md +132 -53
  34. package/.agent/agents/test-engineer.md +0 -21
  35. package/.agent/agents/type-safety-reviewer.md +143 -33
  36. package/.agent/patterns/generator.md +9 -9
  37. package/.agent/patterns/inversion.md +12 -12
  38. package/.agent/patterns/pipeline.md +9 -9
  39. package/.agent/patterns/reviewer.md +13 -13
  40. package/.agent/patterns/tool-wrapper.md +9 -9
  41. package/.agent/rules/GEMINI.md +63 -63
  42. package/.agent/scripts/__pycache__/auto_preview.cpython-311.pyc +0 -0
  43. package/.agent/scripts/__pycache__/bundle_analyzer.cpython-311.pyc +0 -0
  44. package/.agent/scripts/__pycache__/checklist.cpython-311.pyc +0 -0
  45. package/.agent/scripts/__pycache__/dependency_analyzer.cpython-311.pyc +0 -0
  46. package/.agent/scripts/__pycache__/security_scan.cpython-311.pyc +0 -0
  47. package/.agent/scripts/__pycache__/session_manager.cpython-311.pyc +0 -0
  48. package/.agent/scripts/__pycache__/skill_integrator.cpython-311.pyc +0 -0
  49. package/.agent/scripts/__pycache__/swarm_dispatcher.cpython-311.pyc +0 -0
  50. package/.agent/scripts/__pycache__/test_runner.cpython-311.pyc +0 -0
  51. package/.agent/scripts/__pycache__/verify_all.cpython-311.pyc +0 -0
  52. package/.agent/scripts/compress_skills.py +167 -0
  53. package/.agent/scripts/consolidate_skills.py +173 -0
  54. package/.agent/scripts/deep_compress.py +202 -0
  55. package/.agent/scripts/minify_context.py +80 -0
  56. package/.agent/scripts/security_scan.py +1 -1
  57. package/.agent/scripts/strip_tribunal.py +41 -0
  58. package/.agent/skills/agent-organizer/SKILL.md +60 -100
  59. package/.agent/skills/agentic-patterns/SKILL.md +0 -70
  60. package/.agent/skills/ai-prompt-injection-defense/SKILL.md +108 -53
  61. package/.agent/skills/api-patterns/SKILL.md +197 -257
  62. package/.agent/skills/api-security-auditor/SKILL.md +125 -57
  63. package/.agent/skills/app-builder/SKILL.md +326 -50
  64. package/.agent/skills/app-builder/templates/SKILL.md +13 -15
  65. package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +16 -16
  66. package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +22 -22
  67. package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +18 -18
  68. package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +20 -20
  69. package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +17 -17
  70. package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +18 -18
  71. package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +21 -21
  72. package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +19 -19
  73. package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +26 -26
  74. package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +26 -26
  75. package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +19 -19
  76. package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +18 -18
  77. package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +20 -20
  78. package/.agent/skills/appflow-wireframe/SKILL.md +71 -98
  79. package/.agent/skills/architecture/SKILL.md +161 -200
  80. package/.agent/skills/authentication-best-practices/SKILL.md +121 -54
  81. package/.agent/skills/bash-linux/SKILL.md +71 -166
  82. package/.agent/skills/behavioral-modes/SKILL.md +8 -69
  83. package/.agent/skills/brainstorming/SKILL.md +345 -127
  84. package/.agent/skills/building-native-ui/SKILL.md +125 -57
  85. package/.agent/skills/clean-code/SKILL.md +266 -149
  86. package/.agent/skills/code-review-checklist/SKILL.md +0 -62
  87. package/.agent/skills/config-validator/SKILL.md +73 -131
  88. package/.agent/skills/csharp-developer/SKILL.md +434 -73
  89. package/.agent/skills/database-design/SKILL.md +190 -275
  90. package/.agent/skills/deployment-procedures/SKILL.md +81 -158
  91. package/.agent/skills/devops-engineer/SKILL.md +255 -94
  92. package/.agent/skills/devops-incident-responder/SKILL.md +50 -69
  93. package/.agent/skills/doc.md +5 -5
  94. package/.agent/skills/documentation-templates/SKILL.md +19 -63
  95. package/.agent/skills/edge-computing/SKILL.md +75 -165
  96. package/.agent/skills/extract-design-system/SKILL.md +84 -58
  97. package/.agent/skills/framer-motion-expert/SKILL.md +195 -0
  98. package/.agent/skills/frontend-design/SKILL.md +151 -499
  99. package/.agent/skills/game-design-expert/SKILL.md +71 -0
  100. package/.agent/skills/game-engineering-expert/SKILL.md +88 -0
  101. package/.agent/skills/geo-fundamentals/SKILL.md +52 -178
  102. package/.agent/skills/github-operations/SKILL.md +197 -272
  103. package/.agent/skills/gsap-expert/SKILL.md +194 -0
  104. package/.agent/skills/i18n-localization/SKILL.md +60 -172
  105. package/.agent/skills/intelligent-routing/SKILL.md +123 -103
  106. package/.agent/skills/lint-and-validate/SKILL.md +8 -52
  107. package/.agent/skills/llm-engineering/SKILL.md +281 -195
  108. package/.agent/skills/local-first/SKILL.md +76 -159
  109. package/.agent/skills/mcp-builder/SKILL.md +48 -188
  110. package/.agent/skills/mobile-design/SKILL.md +213 -219
  111. package/.agent/skills/motion-engineering/SKILL.md +184 -0
  112. package/.agent/skills/nextjs-react-expert/SKILL.md +184 -203
  113. package/.agent/skills/nodejs-best-practices/SKILL.md +403 -185
  114. package/.agent/skills/observability/SKILL.md +211 -203
  115. package/.agent/skills/parallel-agents/SKILL.md +53 -146
  116. package/.agent/skills/performance-profiling/SKILL.md +171 -151
  117. package/.agent/skills/plan-writing/SKILL.md +49 -153
  118. package/.agent/skills/platform-engineer/SKILL.md +57 -103
  119. package/.agent/skills/playwright-best-practices/SKILL.md +110 -63
  120. package/.agent/skills/powershell-windows/SKILL.md +61 -179
  121. package/.agent/skills/python-patterns/SKILL.md +7 -35
  122. package/.agent/skills/python-pro/SKILL.md +273 -114
  123. package/.agent/skills/react-specialist/SKILL.md +227 -108
  124. package/.agent/skills/readme-builder/SKILL.md +15 -85
  125. package/.agent/skills/realtime-patterns/SKILL.md +216 -243
  126. package/.agent/skills/red-team-tactics/SKILL.md +10 -51
  127. package/.agent/skills/rust-pro/SKILL.md +525 -142
  128. package/.agent/skills/seo-fundamentals/SKILL.md +92 -153
  129. package/.agent/skills/server-management/SKILL.md +110 -166
  130. package/.agent/skills/shadcn-ui-expert/SKILL.md +154 -55
  131. package/.agent/skills/skill-creator/SKILL.md +18 -58
  132. package/.agent/skills/sql-pro/SKILL.md +543 -68
  133. package/.agent/skills/supabase-postgres-best-practices/SKILL.md +28 -68
  134. package/.agent/skills/swiftui-expert/SKILL.md +124 -57
  135. package/.agent/skills/systematic-debugging/SKILL.md +49 -151
  136. package/.agent/skills/tailwind-patterns/SKILL.md +433 -149
  137. package/.agent/skills/tdd-workflow/SKILL.md +63 -169
  138. package/.agent/skills/test-result-analyzer/SKILL.md +33 -73
  139. package/.agent/skills/testing-patterns/SKILL.md +437 -130
  140. package/.agent/skills/trend-researcher/SKILL.md +30 -71
  141. package/.agent/skills/ui-ux-pro-max/SKILL.md +0 -41
  142. package/.agent/skills/ui-ux-researcher/SKILL.md +51 -91
  143. package/.agent/skills/vue-expert/SKILL.md +225 -119
  144. package/.agent/skills/vulnerability-scanner/SKILL.md +264 -226
  145. package/.agent/skills/web-accessibility-auditor/SKILL.md +141 -58
  146. package/.agent/skills/web-design-guidelines/SKILL.md +17 -61
  147. package/.agent/skills/webapp-testing/SKILL.md +71 -196
  148. package/.agent/skills/whimsy-injector/SKILL.md +58 -132
  149. package/.agent/skills/workflow-optimizer/SKILL.md +28 -68
  150. package/.agent/workflows/api-tester.md +96 -224
  151. package/.agent/workflows/audit.md +81 -122
  152. package/.agent/workflows/brainstorm.md +69 -105
  153. package/.agent/workflows/changelog.md +65 -97
  154. package/.agent/workflows/create.md +73 -88
  155. package/.agent/workflows/debug.md +80 -111
  156. package/.agent/workflows/deploy.md +119 -92
  157. package/.agent/workflows/enhance.md +80 -91
  158. package/.agent/workflows/fix.md +68 -97
  159. package/.agent/workflows/generate.md +165 -164
  160. package/.agent/workflows/migrate.md +106 -109
  161. package/.agent/workflows/orchestrate.md +103 -86
  162. package/.agent/workflows/performance-benchmarker.md +77 -268
  163. package/.agent/workflows/plan.md +120 -98
  164. package/.agent/workflows/preview.md +39 -96
  165. package/.agent/workflows/refactor.md +105 -97
  166. package/.agent/workflows/review-ai.md +63 -102
  167. package/.agent/workflows/review.md +71 -110
  168. package/.agent/workflows/session.md +53 -113
  169. package/.agent/workflows/status.md +42 -88
  170. package/.agent/workflows/strengthen-skills.md +90 -51
  171. package/.agent/workflows/swarm.md +114 -129
  172. package/.agent/workflows/test.md +125 -102
  173. package/.agent/workflows/tribunal-backend.md +60 -78
  174. package/.agent/workflows/tribunal-database.md +62 -100
  175. package/.agent/workflows/tribunal-frontend.md +62 -82
  176. package/.agent/workflows/tribunal-full.md +56 -100
  177. package/.agent/workflows/tribunal-mobile.md +65 -94
  178. package/.agent/workflows/tribunal-performance.md +62 -105
  179. package/.agent/workflows/ui-ux-pro-max.md +72 -121
  180. package/README.md +11 -15
  181. package/package.json +1 -1
  182. package/.agent/skills/api-patterns/api-style.md +0 -42
  183. package/.agent/skills/api-patterns/auth.md +0 -24
  184. package/.agent/skills/api-patterns/documentation.md +0 -26
  185. package/.agent/skills/api-patterns/graphql.md +0 -41
  186. package/.agent/skills/api-patterns/rate-limiting.md +0 -31
  187. package/.agent/skills/api-patterns/response.md +0 -37
  188. package/.agent/skills/api-patterns/rest.md +0 -40
  189. package/.agent/skills/api-patterns/security-testing.md +0 -122
  190. package/.agent/skills/api-patterns/trpc.md +0 -41
  191. package/.agent/skills/api-patterns/versioning.md +0 -22
  192. package/.agent/skills/app-builder/agent-coordination.md +0 -71
  193. package/.agent/skills/app-builder/feature-building.md +0 -53
  194. package/.agent/skills/app-builder/project-detection.md +0 -34
  195. package/.agent/skills/app-builder/scaffolding.md +0 -118
  196. package/.agent/skills/app-builder/tech-stack.md +0 -40
  197. package/.agent/skills/architecture/context-discovery.md +0 -43
  198. package/.agent/skills/architecture/examples.md +0 -94
  199. package/.agent/skills/architecture/pattern-selection.md +0 -68
  200. package/.agent/skills/architecture/patterns-reference.md +0 -50
  201. package/.agent/skills/architecture/trade-off-analysis.md +0 -77
  202. package/.agent/skills/brainstorming/dynamic-questioning.md +0 -360
  203. package/.agent/skills/database-design/database-selection.md +0 -43
  204. package/.agent/skills/database-design/indexing.md +0 -39
  205. package/.agent/skills/database-design/migrations.md +0 -48
  206. package/.agent/skills/database-design/optimization.md +0 -36
  207. package/.agent/skills/database-design/orm-selection.md +0 -30
  208. package/.agent/skills/database-design/schema-design.md +0 -56
  209. package/.agent/skills/dotnet-core-expert/SKILL.md +0 -103
  210. package/.agent/skills/framer-motion-animations/SKILL.md +0 -74
  211. package/.agent/skills/frontend-design/animation-guide.md +0 -331
  212. package/.agent/skills/frontend-design/color-system.md +0 -329
  213. package/.agent/skills/frontend-design/decision-trees.md +0 -418
  214. package/.agent/skills/frontend-design/motion-graphics.md +0 -306
  215. package/.agent/skills/frontend-design/typography-system.md +0 -363
  216. package/.agent/skills/frontend-design/ux-psychology.md +0 -1116
  217. package/.agent/skills/frontend-design/visual-effects.md +0 -383
  218. package/.agent/skills/game-development/2d-games/SKILL.md +0 -119
  219. package/.agent/skills/game-development/3d-games/SKILL.md +0 -135
  220. package/.agent/skills/game-development/SKILL.md +0 -236
  221. package/.agent/skills/game-development/game-art/SKILL.md +0 -185
  222. package/.agent/skills/game-development/game-audio/SKILL.md +0 -190
  223. package/.agent/skills/game-development/game-design/SKILL.md +0 -129
  224. package/.agent/skills/game-development/mobile-games/SKILL.md +0 -108
  225. package/.agent/skills/game-development/multiplayer/SKILL.md +0 -132
  226. package/.agent/skills/game-development/pc-games/SKILL.md +0 -144
  227. package/.agent/skills/game-development/vr-ar/SKILL.md +0 -123
  228. package/.agent/skills/game-development/web-games/SKILL.md +0 -150
  229. package/.agent/skills/intelligent-routing/router-manifest.md +0 -65
  230. package/.agent/skills/mobile-design/decision-trees.md +0 -516
  231. package/.agent/skills/mobile-design/mobile-backend.md +0 -491
  232. package/.agent/skills/mobile-design/mobile-color-system.md +0 -420
  233. package/.agent/skills/mobile-design/mobile-debugging.md +0 -122
  234. package/.agent/skills/mobile-design/mobile-design-thinking.md +0 -357
  235. package/.agent/skills/mobile-design/mobile-navigation.md +0 -458
  236. package/.agent/skills/mobile-design/mobile-performance.md +0 -767
  237. package/.agent/skills/mobile-design/mobile-testing.md +0 -356
  238. package/.agent/skills/mobile-design/mobile-typography.md +0 -433
  239. package/.agent/skills/mobile-design/platform-android.md +0 -666
  240. package/.agent/skills/mobile-design/platform-ios.md +0 -561
  241. package/.agent/skills/mobile-design/touch-psychology.md +0 -537
  242. package/.agent/skills/nextjs-react-expert/1-async-eliminating-waterfalls.md +0 -312
  243. package/.agent/skills/nextjs-react-expert/2-bundle-bundle-size-optimization.md +0 -240
  244. package/.agent/skills/nextjs-react-expert/3-server-server-side-performance.md +0 -490
  245. package/.agent/skills/nextjs-react-expert/4-client-client-side-data-fetching.md +0 -264
  246. package/.agent/skills/nextjs-react-expert/5-rerender-re-render-optimization.md +0 -581
  247. package/.agent/skills/nextjs-react-expert/6-rendering-rendering-performance.md +0 -432
  248. package/.agent/skills/nextjs-react-expert/7-js-javascript-performance.md +0 -684
  249. package/.agent/skills/nextjs-react-expert/8-advanced-advanced-patterns.md +0 -150
  250. package/.agent/skills/vulnerability-scanner/checklists.md +0 -121
@@ -1,200 +1,161 @@
1
- ---
2
- name: architecture
3
- description: Architectural decision-making framework. Requirements analysis, trade-off evaluation, ADR documentation. Use when making architecture decisions or analyzing system design.
4
- allowed-tools: Read, Write, Edit, Glob, Grep
5
- version: 1.0.0
6
- last-updated: 2026-03-12
7
- applies-to-model: gemini-2.5-pro, claude-3-7-sonnet
8
- ---
9
-
10
- # Architecture Decision Framework
11
-
12
- > An architecture decision is only good until the constraints change.
13
- > Document the decision AND the reasoning — future teams need both.
14
-
15
- ---
16
-
17
- ## When to Use This Skill
18
-
19
- - A new system, service, or major feature is being designed
20
- - An existing architecture is being evaluated for scaling, cost, or maintainability problems
21
- - A team disagrees on technical direction and needs a structured decision process
22
- - A decision needs to be documented so future engineers understand the "why"
23
-
24
- ---
25
-
26
- ## The Decision Process
27
-
28
- Good architecture decisions follow a sequence. Skipping steps creates decisions that look good in a diagram and fail in production.
29
-
30
- ### Phase 1 — Understand the Forces
31
-
32
- Before proposing anything, map what actually constrains the design:
33
-
34
- ```
35
- Requirements: What must this system do?
36
- Quality attributes: Speed, reliability, security, cost, maintainability — rank them
37
- Constraints: Team size, existing tech, regulatory, budget
38
- Team context: What does the team already know? What can they operate?
39
- ```
40
-
41
- **The trap:** Jumping to technology before understanding quality attributes.
42
- If the top priority is "cheap to run" — that's a different answer than "sub-100ms response time."
43
-
44
- ### Phase 2 Generate Options
45
-
46
- Produce at least 2 real alternates. "We could do X, or we could not" is not a comparison.
47
-
48
- For each option document:
49
- - How it satisfies the top quality attributes
50
- - Where it falls short
51
- - Long-term operational cost (not just build cost)
52
- - Risk to the team given their current knowledge
53
-
54
- ### Phase 3 Evaluate Trade-offs
55
-
56
- Use a table:
57
-
58
- | Quality Attribute | Option A | Option B | Option C |
59
- |---|---|---|---|
60
- | Time to first delivery | ★★★ | ★★ | ★★★★ |
61
- | Operational complexity | Low | High | Medium |
62
- | Cost at 10x scale | $ | $$$ | $$ |
63
-
64
- The option with the most stars doesn't always win. **The one that best fits the top-priority attributes wins.**
65
-
66
- ### Phase 4 — Document the Decision (ADR)
67
-
68
- Every significant architecture decision gets an ADR (Architecture Decision Record).
69
-
70
- ```markdown
71
- # ADR-NNN: [Short title]
72
-
73
- ## Status
74
- Accepted / Proposed / Deprecated / Superseded by ADR-NNN
75
-
76
- ## Context
77
- [What situation or problem prompted this decision?]
78
-
79
- ## Options Considered
80
- [Brief description of each option]
81
-
82
- ## Decision
83
- [What was chosen and why]
84
-
85
- ## Trade-offs Accepted
86
- [What downsides are being consciously accepted?]
87
-
88
- ## Consequences
89
- [What becomes easier? What becomes harder?]
90
- ```
91
-
92
- ---
93
-
94
- ## File Index
95
-
96
- | File | Covers | When to Load |
97
- |---|---|---|
98
- | `context-discovery.md` | Questions to map requirements and constraints | Early in design |
99
- | `pattern-selection.md` | Monolith vs microservices, event-driven, CQRS, etc. | Choosing structural patterns |
100
- | `patterns-reference.md` | Reference descriptions of common patterns | Evaluating patterns |
101
- | `trade-off-analysis.md` | Scoring and comparison frameworks | Decision phase |
102
- | `examples.md` | Worked architecture examples | Concrete reference |
103
-
104
- ---
105
-
106
- ## Anti-Patterns in Architecture Work
107
-
108
- | Pattern | Problem |
109
- |---|---|
110
- | Resume-driven architecture | Choosing tech because it's interesting, not because it fits |
111
- | Premature microservices | Splitting a monolith before the domain boundaries are known |
112
- | Ignoring operational cost | Systems that are brilliant to build and terrible to run |
113
- | No ADR | Decision rationale lost future engineers repeat the same debates |
114
- | One option considered | Not an evaluation, just a justification |
115
-
116
- ---
117
-
118
- ## Output Format
119
-
120
- When this skill produces a recommendation or design decision, structure your output as:
121
-
122
- ```
123
- ━━━ Architecture Recommendation ━━━━━━━━━━━━━━━━
124
- Decision: [what was chosen / proposed]
125
- Rationale: [whyone concise line]
126
- Trade-offs: [what is consciously accepted]
127
- Next action: [concrete next step for the user]
128
- ─────────────────────────────────────────────────
129
- Pre-Flight: ✅ All checks passed
130
- or ❌ [blocking item that must be resolved first]
131
- ```
132
-
133
-
134
- ---
135
-
136
- ## 🏛️ Tribunal Integration (Anti-Hallucination)
137
-
138
- **Slash command: `/brainstorm` or `/plan`**
139
- **Active reviewers: `project-planner` · `logic-reviewer`**
140
-
141
- ### ❌ Forbidden AI Tropes in Architecture
142
-
143
- 1. **Defaulting to Microservices** — never recommend Microservices for a new or small project without explicit scale requirements. Monolith first.
144
- 2. **Over-engineering with CQRS/Event Sourcing** — do not suggest complex distributed patterns unless the domain demands it.
145
- 3. **Assuming AWS/Cloud Provider** — ask where the user deploys, do not hallucinate AWS services as the default solution.
146
- 4. **Ignoring Operational Cost** do not recommend architectures that require dedicated DevOps teams if the user is a solo developer.
147
- 5. **Failing to Document Trade-offs** every architecture decision has a downside. Never present a "perfect" solution.
148
-
149
- ### Pre-Flight Self-Audit
150
-
151
- Review these questions before proposing an architecture:
152
- ```
153
- Did I start with the simplest architecture that satisfies the constraints?
154
- ✅ Did I explicitly document the downsides (cost, complexity, maintainability) of my proposal?
155
- ✅ Is my proposal grounded in the user's actual constraints (team size, budget, timeline)?
156
- ✅ Did I ask about the read/write ratio and data shape before choosing a database?
157
- ✅ Is my solution resilient to partial failures?
158
- ```
159
-
160
-
161
- ---
162
-
163
- ## 🤖 LLM-Specific Traps
164
-
165
- AI coding assistants often fall into specific bad habits when dealing with this domain. These are strictly forbidden:
166
-
167
- 1. **Over-engineering:** Proposing complex abstractions or distributed systems when a simpler approach suffices.
168
- 2. **Hallucinated Libraries/Methods:** Using non-existent methods or packages. Always `// VERIFY` or check `package.json` / `requirements.txt`.
169
- 3. **Skipping Edge Cases:** Writing the "happy path" and ignoring error handling, timeouts, or data validation.
170
- 4. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
171
- 5. **Silent Degradation:** Catching and suppressing errors without logging or re-raising.
172
-
173
- ---
174
-
175
- ## 🏛️ Tribunal Integration (Anti-Hallucination)
176
-
177
- **Slash command: `/review` or `/tribunal-full`**
178
- **Active reviewers: `logic-reviewer` · `security-auditor`**
179
-
180
- ### ❌ Forbidden AI Tropes
181
-
182
- 1. **Blind Assumptions:** Never make an assumption without documenting it clearly with `// VERIFY: [reason]`.
183
- 2. **Silent Degradation:** Catching and suppressing errors without logging or handling.
184
- 3. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
185
-
186
- ### ✅ Pre-Flight Self-Audit
187
-
188
- Review these questions before confirming output:
189
- ```
190
- ✅ Did I rely ONLY on real, verified tools and methods?
191
- ✅ Is this solution appropriately scoped to the user's constraints?
192
- ✅ Did I handle potential failure modes and edge cases?
193
- ✅ Have I avoided generic boilerplate that doesn't add value?
194
- ```
195
-
196
- ### 🛑 Verification-Before-Completion (VBC) Protocol
197
-
198
- **CRITICAL:** You must follow a strict "evidence-based closeout" state machine.
199
- - ❌ **Forbidden:** Declaring a task complete because the output "looks correct."
200
- - ✅ **Required:** You are explicitly forbidden from finalizing any task without providing **concrete evidence** (terminal output, passing tests, compile success, or equivalent proof) that your output works as intended.
1
+ ---
2
+ name: architecture
3
+ description: Software architecture mastery. System design patterns, clean architecture, hexagonal/ports-and-adapters, event-driven architecture, microservices vs monolith decision framework, CQRS, domain-driven design, Architecture Decision Records (ADRs), and scalability patterns. Use when making architecture decisions, designing systems, or documenting technical decisions.
4
+ allowed-tools: Read, Write, Edit, Glob, Grep
5
+ version: 3.1.0
6
+ last-updated: 2026-04-07
7
+ applies-to-model: gemini-3-1-pro, claude-3-7-sonnet
8
+ ---
9
+
10
+ # Architecture System Design Mastery
11
+
12
+ ## Architecture Selection
13
+
14
+ ```
15
+ Team size? Scale? Cadence?
16
+ 1–5 → Monolith <10K RPM → Monolith Weekly → Monolith
17
+ 5–20 → Mod. Mono <100K RPM Mono+CDN Daily → Modular Mono
18
+ 20+ → Microsvcs >100K RPM → Microsvcs Per-svc → Microsvcs
19
+
20
+ Microservices are NOT inherently better.
21
+ A well-structured monolith beats a poorly designed microservice system.
22
+ Start monolith. Extract services only when proven necessary.
23
+ ```
24
+
25
+ **3 Questions Before Any Pattern:**
26
+ 1. What SPECIFIC problem does this pattern solve?
27
+ 2. Is there a simpler solution?
28
+ 3. Can we add this LATER when proven needed?
29
+
30
+ ---
31
+
32
+ ## Clean Architecture (Dependency Rule)
33
+
34
+ ```
35
+ Presentation Application Domain ← Infrastructure
36
+ (Controllers) (Use Cases) (Entities) (DB, APIs)
37
+
38
+ Dependency Rule: arrows point INWARD. Domain knows NOTHING about infra.
39
+ Application defines interfaces (ports). Infrastructure implements them (adapters).
40
+ ```
41
+
42
+ ```typescript
43
+ // Domain — pure business logic, zero external dependencies
44
+ interface UserRepository { findById(id: string): Promise<User | null>; }
45
+ class User {
46
+ promote(): void {
47
+ if (this._role === UserRole.ADMIN) throw new DomainError("Already admin");
48
+ this._role = UserRole.ADMIN;
49
+ }
50
+ }
51
+
52
+ // Application orchestrates use cases
53
+ class PromoteUserUseCase {
54
+ async execute(userId: string): Promise<void> {
55
+ const user = await this.userRepo.findById(userId);
56
+ if (!user) throw new NotFoundError("User", userId);
57
+ user.promote();
58
+ await this.userRepo.save(user);
59
+ await this.eventBus.publish(new UserPromotedEvent(userId));
60
+ }
61
+ }
62
+
63
+ // Infrastructure — concrete implementations of ports
64
+ class PostgresUserRepository implements UserRepository {
65
+ async findById(id: string) { /* db.query(...) */ }
66
+ }
67
+ ```
68
+
69
+ ---
70
+
71
+ ## CQRS
72
+
73
+ ```
74
+ Commands (Write) Normalized Write DB
75
+ Queries (Read) → Denormalized/Cached Read Model
76
+
77
+ When to use: ✅ Read/write patterns diverge ✅ 10:1+ read:write ratio ✅ Event sourcing
78
+ When NOT to: ❌ Simple CRUD ❌ Team < 3 devs ❌ Read/write models are identical
79
+ ```
80
+
81
+ ---
82
+
83
+ ## Event-Driven Architecture
84
+
85
+ ```
86
+ Event Types:
87
+ Domain Events → "OrderPlaced" within a bounded context
88
+ Integration Events → Cross-service via message queue
89
+ Notification Events Fire-and-forget (logging, analytics)
90
+
91
+ Broker Selection:
92
+ BullMQ / Redis Streams → Simple, single-service queues
93
+ RabbitMQ → Complex routing, dead-letter queues
94
+ Apache Kafka → High throughput, replay, event log
95
+ AWS SQS/SNS → Managed, serverless-friendly
96
+
97
+ Outbox Pattern (reliable publishing):
98
+ 1. Save entity + event in ONE DB transaction
99
+ 2. Background worker polls outbox publishes to broker
100
+ 3. Mark as published guarantees at-least-once delivery
101
+ ```
102
+
103
+ ---
104
+
105
+ ## Anti-Patterns Reference
106
+
107
+ | Pattern | When it's an Anti-Pattern | Simpler Alternative |
108
+ |---------|--------------------------|---------------------|
109
+ | Microservices | Before team or scale justifies it | Modular monolith |
110
+ | Clean/Hexagonal | Over-abstraction for simple CRUD | Concrete first, interfaces later |
111
+ | Event Sourcing | No business requirement for audit/replay | Append-only audit log |
112
+ | CQRS | Simple data model, no read/write divergence | Single model |
113
+ | Repository | Simple CRUD, single database | ORM direct access |
114
+
115
+ ---
116
+
117
+ ## Architecture Decision Records (ADRs)
118
+
119
+ ```markdown
120
+ ## ADR-001: [Decision Title]
121
+ **Status:** Proposed | Accepted | Deprecated | Superseded by ADR-XXX
122
+
123
+ **Context:** [Problem + constraints: team, scale, timeline]
124
+
125
+ **Decision:** [What was chosen be specific]
126
+
127
+ **Rationale:** [Why tied to requirements]
128
+
129
+ **Trade-offs:** [What we consciously give up]
130
+
131
+ **Consequences:**
132
+ - Positive: [Benefits]
133
+ - Negative: [Costs/Risks]
134
+ - Mitigation: [How to address negatives]
135
+
136
+ **Revisit when:** [Trigger conditions]
137
+ ```
138
+
139
+ ADR storage: `docs/architecture/adr-001-title.md`
140
+
141
+ ---
142
+
143
+ ## Scalability Patterns
144
+
145
+ ```
146
+ Read scaling: Redis cache Read replicas CDN for static assets
147
+ Write scaling: Queue writes Partition data Event sourcing
148
+ Stateless: Sessions in Redis → JWT → No server affinity
149
+ DB scaling: Connection pooling → Read replicas → Partitioning → Sharding (last resort)
150
+ Cache layers: L1: In-memory (process) L2: Redis (shared) L3: CDN (edge)
151
+ ```
152
+
153
+ ## Scale-to-Architecture Matrix
154
+
155
+ ```
156
+ MVP SaaS Enterprise
157
+ Scale: <1K 1K–100K 100K+
158
+ Team: Solo 2–10 10+
159
+ Architecture: Simple Mono Modular Mono Distributed
160
+ Framework: Next.js API NestJS Microservices
161
+ ```
@@ -1,72 +1,139 @@
1
- ---
2
- name: authentication-best-practices
3
- description: Authentication and Identity Management expert. Specializes in JWTs, OIDC, HTTP-Only Cookies, and secure password hashing.
4
- allowed-tools: Read, Write, Edit, Glob, Grep
5
- version: 1.0.0
6
- last-updated: 2026-03-30
7
- applies-to-model: claude-3-7-sonnet, gemini-2.5-pro
8
- ---
9
-
10
- # Authentication & Session Best Practices
11
-
12
- You are an Identity and Access Management (IAM) Specialist. You are strictly forbidden from writing custom cryptography or insecure authentication flows.
13
-
14
- ## Core Directives
15
-
16
- 1. **Token Storage & JWTs:**
17
- - Never store JWTs or session tokens in `localStorage` or `sessionStorage` where they are vulnerable to XSS.
18
- - Always issue access tokens as `Secure, HttpOnly, SameSite=Strict/Lax` browser cookies.
19
- - When verifying JWTs, always explicitly define the `algorithms` array (e.g., `['HS256']`) to prevent algorithm confusion attacks where the attacker sets `alg: none`.
20
-
21
- 2. **Password Hashing:**
22
- - Never write a custom hashing algorithm.
23
- - If managing raw passwords, use `Argon2id` or `Bcrypt` with a sufficient work factor (e.g., 10-12 rounds salt).
24
- - Never log passwords, tokens, or PII to the standard `stdout` or custom loggers.
25
-
26
- 3. **Session Revocation:**
27
- - JWTs scale well but cannot be instantly revoked without a denylist. If instant revocation or device management is required, default to opaque, stateful session tokens backed by Redis or an equivalent fast KV store.
28
-
29
- ## Execution
30
- Review identity handling mechanisms forcefully. If you catch an agent or a user attempting to place a secret in client-side code, throw a high-level alert and immediately rewrite the architecture to utilize backend-for-frontend (BFF) proxying or HttpOnly cookes.
1
+ ---
2
+ name: authentication-best-practices
3
+ description: Authentication and Authorization mastery. Best practices for OAuth2, OpenID Connect, JWT (JSON Web Tokens), session management, password hashing, MFA (Multi-Factor Authentication), RBAC/ABAC, SSO, and secure credential storage. Use when auditing or implementing login flows, identity systems, or access control.
4
+ allowed-tools: Read, Write, Edit, Glob, Grep
5
+ version: 2.0.0
6
+ last-updated: 2026-04-02
7
+ applies-to-model: gemini-2.5-pro, claude-3-7-sonnet
8
+ ---
31
9
 
10
+ # Authentication & Authorization — Identity Mastery
32
11
 
33
12
  ---
34
13
 
35
- ## 🤖 LLM-Specific Traps
14
+ ## Passwords & Hashing
36
15
 
37
- AI coding assistants often fall into specific bad habits when dealing with this domain. These are strictly forbidden:
16
+ ```typescript
17
+ // ❌ BAD: md5, sha1, sha256 (too fast, vulnerable to brute force/rainbow tables)
18
+ const hash = crypto.createHash('sha256').update(password).digest('hex');
38
19
 
39
- 1. **Over-engineering:** Proposing complex abstractions or distributed systems when a simpler approach suffices.
40
- 2. **Hallucinated Libraries/Methods:** Using non-existent methods or packages. Always `// VERIFY` or check `package.json` / `requirements.txt`.
41
- 3. **Skipping Edge Cases:** Writing the "happy path" and ignoring error handling, timeouts, or data validation.
42
- 4. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
43
- 5. **Silent Degradation:** Catching and suppressing errors without logging or re-raising.
20
+ // GOOD: Argon2 (memory-hard, ASIC resistant) or bcrypt
21
+ import * as argon2 from "argon2";
22
+
23
+ async function hashPassword(password: string): Promise<string> {
24
+ // Argon2 hashes include the salt inherently in the resulting string
25
+ return await argon2.hash(password, {
26
+ type: argon2.argon2id, // recommended variant
27
+ memoryCost: 2 ** 16, // 64 MB
28
+ timeCost: 3, // iterations
29
+ parallelism: 1, // threads
30
+ });
31
+ }
32
+
33
+ async function verifyPassword(hash: string, password: string): Promise<boolean> {
34
+ return await argon2.verify(hash, password);
35
+ }
36
+ ```
37
+
38
+ ### Password Policies
39
+ - **Length over complexity**: Require minimum 12 characters. Stop requiring arbitrary symbols (e.g., `!@#`).
40
+ - **Check against breaches**: Use HaveIBeenPwned API or similar to reject compromised passwords during signup.
41
+ - **Never expire passwords arbitrarily**: Only force resets if there is evidence of a breach.
44
42
 
45
43
  ---
46
44
 
47
- ## 🏛️ Tribunal Integration (Anti-Hallucination)
45
+ ## Session Management vs. JWT
48
46
 
49
- **Slash command: `/review` or `/tribunal-full`**
50
- **Active reviewers: `logic-reviewer` · `security-auditor`**
47
+ ### 1. Stateful Sessions (Cookies)
48
+ **Best for**: Monolithic web apps, SSR apps (Next.js, Remix).
49
+ - Server stores session ID mapped to user data in Redis/DB.
50
+ - Client stores session ID in an `HttpOnly`, `Secure`, `SameSite=Lax/Strict` cookie.
51
+ - **Pros**: Immediate revocation, server-side truth, invisible to XSS.
52
+ - **Cons**: Requires DB lookup per request.
51
53
 
52
- ### Forbidden AI Tropes
54
+ ### 2. Stateless JWT (JSON Web Tokens)
55
+ **Best for**: Distributed APIs, Microservices, Native mobile apps.
56
+ - Server signs a token containing user claims.
57
+ - Client passes it in `Authorization: Bearer <token>` header.
58
+ - **Pros**: No DB lookup needed, easy cross-origin sharing.
59
+ - **Cons**: Cannot be easily revoked before expiration.
53
60
 
54
- 1. **Blind Assumptions:** Never make an assumption without documenting it clearly with `// VERIFY: [reason]`.
55
- 2. **Silent Degradation:** Catching and suppressing errors without logging or handling.
56
- 3. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
61
+ ### The JWT "Refresh Token" Pattern
62
+ ```typescript
63
+ // Scenario: API authentication
64
+ // 1. Access Token (Short-lived: 15 mins)
65
+ const accessToken = jwt.sign({ userId: user.id }, JWT_SECRET, {
66
+ expiresIn: "15m",
67
+ algorithm: "HS256" // ALWAYS explicitly specify
68
+ });
69
+ // 2. Refresh Token (Long-lived: 7 days, opaque string in DB)
70
+ const refreshToken = crypto.randomBytes(40).toString('hex');
71
+ await db.refreshTokens.create({ token: refreshToken, userId: user.id, expires: addDays(7) });
57
72
 
58
- ### Pre-Flight Self-Audit
73
+ // Client flow:
74
+ // - Access token kept in memory (JS variable) to prevent XSS theft.
75
+ // - Refresh token kept in HttpOnly cookie.
76
+ // - When Access Token expires, endpoint reads cookie, validates DB, issues new Access Token.
77
+ ```
78
+
79
+ ---
80
+
81
+ ## OAuth2 & OIDC (OpenID Connect)
59
82
 
60
- Review these questions before confirming output:
61
83
  ```
62
- ✅ Did I rely ONLY on real, verified tools and methods?
63
- Is this solution appropriately scoped to the user's constraints?
64
- Did I handle potential failure modes and edge cases?
65
- Have I avoided generic boilerplate that doesn't add value?
84
+ Roles:
85
+ 1. Resource Owner (User)
86
+ 2. Client (Your App)
87
+ 3. Authorization Server (Google/GitHub/Auth0)
88
+ 4. Resource Server (API)
89
+
90
+ Flow (Authorization Code + PKCE):
91
+ 1. User clicks "Login with Google".
92
+ 2. App generates `code_verifier` and `code_challenge`.
93
+ 3. App redirects user to Google with `code_challenge`.
94
+ 4. User logs in, Google redirects back to App with an authorization `code`.
95
+ 5. App sends `code` + `code_verifier` to Google backend.
96
+ 6. Google returns `id_token` (OIDC identity) and `access_token` (OAuth permissions).
97
+
98
+ // ❌ HALLUCINATION TRAP: Implicit Flow is deprecated.
99
+ // Never use Implicit Flow (response_type=token) where the token is returned in the URL hash.
100
+ // Always use Authorization Code Flow with PKCE, even for Single Page Apps (SPAs).
66
101
  ```
67
102
 
68
- ### 🛑 Verification-Before-Completion (VBC) Protocol
103
+ ---
69
104
 
70
- **CRITICAL:** You must follow a strict "evidence-based closeout" state machine.
71
- - ❌ **Forbidden:** Declaring a task complete because the output "looks correct."
72
- - **Required:** You are explicitly forbidden from finalizing any task without providing **concrete evidence** (terminal output, passing tests, compile success, or equivalent proof) that your output works as intended.
105
+ ## Multi-Factor Authentication (MFA)
106
+
107
+ - **SMS**: Deprecated by NIST due to SIM swapping vulnerabilities. (Better than nothing, but avoid as primary MFA).
108
+ - **TOTP (Authenticator Apps)**: Standard implementations use HMAC-SHA1. Keep the secret key heavily encrypted at rest.
109
+ - **WebAuthn / Passkeys**: The modern gold standard. Replaces passwords entirely using hardware enclaves (FaceID, TouchID, YubiKey).
110
+
111
+ ---
112
+
113
+ ## Authorization Models
114
+
115
+ ### RBAC (Role-Based Access Control)
116
+ - Users have Roles (`admin`, `editor`, `viewer`).
117
+ - Roles have Permissions (`create:post`, `delete:user`).
118
+
119
+ ```typescript
120
+ // ✅ Check permissions, not roles directly (more flexible)
121
+ if (!user.permissions.includes("delete:user")) {
122
+ throw new ForbiddenError();
123
+ }
124
+ ```
125
+
126
+ ### ABAC (Attribute-Based Access Control)
127
+ - Access based on context (e.g., "User can edit Document if Document.department == User.department").
128
+
129
+ ```typescript
130
+ // Example Policy
131
+ function canEditPost(user: User, post: Post): boolean {
132
+ if (user.role === "admin") return true;
133
+ if (post.authorId === user.id) return true;
134
+ if (post.status === "draft" && user.department === "content") return true;
135
+ return false;
136
+ }
137
+ ```
138
+
139
+ ---