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.
- package/.agent/ARCHITECTURE.md +99 -99
- package/.agent/GEMINI.md +52 -52
- package/.agent/agents/accessibility-reviewer.md +139 -86
- package/.agent/agents/ai-code-reviewer.md +160 -90
- package/.agent/agents/backend-specialist.md +164 -127
- package/.agent/agents/code-archaeologist.md +115 -73
- package/.agent/agents/database-architect.md +130 -110
- package/.agent/agents/debugger.md +137 -97
- package/.agent/agents/dependency-reviewer.md +78 -30
- package/.agent/agents/devops-engineer.md +161 -118
- package/.agent/agents/documentation-writer.md +151 -87
- package/.agent/agents/explorer-agent.md +117 -99
- package/.agent/agents/frontend-reviewer.md +127 -47
- package/.agent/agents/frontend-specialist.md +169 -109
- package/.agent/agents/game-developer.md +28 -164
- package/.agent/agents/logic-reviewer.md +87 -49
- package/.agent/agents/mobile-developer.md +151 -103
- package/.agent/agents/mobile-reviewer.md +133 -50
- package/.agent/agents/orchestrator.md +121 -110
- package/.agent/agents/penetration-tester.md +103 -77
- package/.agent/agents/performance-optimizer.md +136 -92
- package/.agent/agents/performance-reviewer.md +139 -69
- package/.agent/agents/product-manager.md +104 -70
- package/.agent/agents/product-owner.md +6 -25
- package/.agent/agents/project-planner.md +95 -95
- package/.agent/agents/qa-automation-engineer.md +174 -87
- package/.agent/agents/security-auditor.md +133 -129
- package/.agent/agents/seo-specialist.md +160 -99
- package/.agent/agents/sql-reviewer.md +132 -44
- package/.agent/agents/supervisor-agent.md +137 -109
- package/.agent/agents/swarm-worker-contracts.md +17 -17
- package/.agent/agents/swarm-worker-registry.md +46 -46
- package/.agent/agents/test-coverage-reviewer.md +132 -53
- package/.agent/agents/test-engineer.md +0 -21
- package/.agent/agents/type-safety-reviewer.md +143 -33
- package/.agent/patterns/generator.md +9 -9
- package/.agent/patterns/inversion.md +12 -12
- package/.agent/patterns/pipeline.md +9 -9
- package/.agent/patterns/reviewer.md +13 -13
- package/.agent/patterns/tool-wrapper.md +9 -9
- package/.agent/rules/GEMINI.md +63 -63
- package/.agent/scripts/__pycache__/auto_preview.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/bundle_analyzer.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/checklist.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/dependency_analyzer.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/security_scan.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/session_manager.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/skill_integrator.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/swarm_dispatcher.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/test_runner.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/verify_all.cpython-311.pyc +0 -0
- package/.agent/scripts/compress_skills.py +167 -0
- package/.agent/scripts/consolidate_skills.py +173 -0
- package/.agent/scripts/deep_compress.py +202 -0
- package/.agent/scripts/minify_context.py +80 -0
- package/.agent/scripts/security_scan.py +1 -1
- package/.agent/scripts/strip_tribunal.py +41 -0
- package/.agent/skills/agent-organizer/SKILL.md +60 -100
- package/.agent/skills/agentic-patterns/SKILL.md +0 -70
- package/.agent/skills/ai-prompt-injection-defense/SKILL.md +108 -53
- package/.agent/skills/api-patterns/SKILL.md +197 -257
- package/.agent/skills/api-security-auditor/SKILL.md +125 -57
- package/.agent/skills/app-builder/SKILL.md +326 -50
- package/.agent/skills/app-builder/templates/SKILL.md +13 -15
- package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +16 -16
- package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +22 -22
- package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +18 -18
- package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +20 -20
- package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +17 -17
- package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +18 -18
- package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +21 -21
- package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +19 -19
- package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +26 -26
- package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +26 -26
- package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +19 -19
- package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +18 -18
- package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +20 -20
- package/.agent/skills/appflow-wireframe/SKILL.md +71 -98
- package/.agent/skills/architecture/SKILL.md +161 -200
- package/.agent/skills/authentication-best-practices/SKILL.md +121 -54
- package/.agent/skills/bash-linux/SKILL.md +71 -166
- package/.agent/skills/behavioral-modes/SKILL.md +8 -69
- package/.agent/skills/brainstorming/SKILL.md +345 -127
- package/.agent/skills/building-native-ui/SKILL.md +125 -57
- package/.agent/skills/clean-code/SKILL.md +266 -149
- package/.agent/skills/code-review-checklist/SKILL.md +0 -62
- package/.agent/skills/config-validator/SKILL.md +73 -131
- package/.agent/skills/csharp-developer/SKILL.md +434 -73
- package/.agent/skills/database-design/SKILL.md +190 -275
- package/.agent/skills/deployment-procedures/SKILL.md +81 -158
- package/.agent/skills/devops-engineer/SKILL.md +255 -94
- package/.agent/skills/devops-incident-responder/SKILL.md +50 -69
- package/.agent/skills/doc.md +5 -5
- package/.agent/skills/documentation-templates/SKILL.md +19 -63
- package/.agent/skills/edge-computing/SKILL.md +75 -165
- package/.agent/skills/extract-design-system/SKILL.md +84 -58
- package/.agent/skills/framer-motion-expert/SKILL.md +195 -0
- package/.agent/skills/frontend-design/SKILL.md +151 -499
- package/.agent/skills/game-design-expert/SKILL.md +71 -0
- package/.agent/skills/game-engineering-expert/SKILL.md +88 -0
- package/.agent/skills/geo-fundamentals/SKILL.md +52 -178
- package/.agent/skills/github-operations/SKILL.md +197 -272
- package/.agent/skills/gsap-expert/SKILL.md +194 -0
- package/.agent/skills/i18n-localization/SKILL.md +60 -172
- package/.agent/skills/intelligent-routing/SKILL.md +123 -103
- package/.agent/skills/lint-and-validate/SKILL.md +8 -52
- package/.agent/skills/llm-engineering/SKILL.md +281 -195
- package/.agent/skills/local-first/SKILL.md +76 -159
- package/.agent/skills/mcp-builder/SKILL.md +48 -188
- package/.agent/skills/mobile-design/SKILL.md +213 -219
- package/.agent/skills/motion-engineering/SKILL.md +184 -0
- package/.agent/skills/nextjs-react-expert/SKILL.md +184 -203
- package/.agent/skills/nodejs-best-practices/SKILL.md +403 -185
- package/.agent/skills/observability/SKILL.md +211 -203
- package/.agent/skills/parallel-agents/SKILL.md +53 -146
- package/.agent/skills/performance-profiling/SKILL.md +171 -151
- package/.agent/skills/plan-writing/SKILL.md +49 -153
- package/.agent/skills/platform-engineer/SKILL.md +57 -103
- package/.agent/skills/playwright-best-practices/SKILL.md +110 -63
- package/.agent/skills/powershell-windows/SKILL.md +61 -179
- package/.agent/skills/python-patterns/SKILL.md +7 -35
- package/.agent/skills/python-pro/SKILL.md +273 -114
- package/.agent/skills/react-specialist/SKILL.md +227 -108
- package/.agent/skills/readme-builder/SKILL.md +15 -85
- package/.agent/skills/realtime-patterns/SKILL.md +216 -243
- package/.agent/skills/red-team-tactics/SKILL.md +10 -51
- package/.agent/skills/rust-pro/SKILL.md +525 -142
- package/.agent/skills/seo-fundamentals/SKILL.md +92 -153
- package/.agent/skills/server-management/SKILL.md +110 -166
- package/.agent/skills/shadcn-ui-expert/SKILL.md +154 -55
- package/.agent/skills/skill-creator/SKILL.md +18 -58
- package/.agent/skills/sql-pro/SKILL.md +543 -68
- package/.agent/skills/supabase-postgres-best-practices/SKILL.md +28 -68
- package/.agent/skills/swiftui-expert/SKILL.md +124 -57
- package/.agent/skills/systematic-debugging/SKILL.md +49 -151
- package/.agent/skills/tailwind-patterns/SKILL.md +433 -149
- package/.agent/skills/tdd-workflow/SKILL.md +63 -169
- package/.agent/skills/test-result-analyzer/SKILL.md +33 -73
- package/.agent/skills/testing-patterns/SKILL.md +437 -130
- package/.agent/skills/trend-researcher/SKILL.md +30 -71
- package/.agent/skills/ui-ux-pro-max/SKILL.md +0 -41
- package/.agent/skills/ui-ux-researcher/SKILL.md +51 -91
- package/.agent/skills/vue-expert/SKILL.md +225 -119
- package/.agent/skills/vulnerability-scanner/SKILL.md +264 -226
- package/.agent/skills/web-accessibility-auditor/SKILL.md +141 -58
- package/.agent/skills/web-design-guidelines/SKILL.md +17 -61
- package/.agent/skills/webapp-testing/SKILL.md +71 -196
- package/.agent/skills/whimsy-injector/SKILL.md +58 -132
- package/.agent/skills/workflow-optimizer/SKILL.md +28 -68
- package/.agent/workflows/api-tester.md +96 -224
- package/.agent/workflows/audit.md +81 -122
- package/.agent/workflows/brainstorm.md +69 -105
- package/.agent/workflows/changelog.md +65 -97
- package/.agent/workflows/create.md +73 -88
- package/.agent/workflows/debug.md +80 -111
- package/.agent/workflows/deploy.md +119 -92
- package/.agent/workflows/enhance.md +80 -91
- package/.agent/workflows/fix.md +68 -97
- package/.agent/workflows/generate.md +165 -164
- package/.agent/workflows/migrate.md +106 -109
- package/.agent/workflows/orchestrate.md +103 -86
- package/.agent/workflows/performance-benchmarker.md +77 -268
- package/.agent/workflows/plan.md +120 -98
- package/.agent/workflows/preview.md +39 -96
- package/.agent/workflows/refactor.md +105 -97
- package/.agent/workflows/review-ai.md +63 -102
- package/.agent/workflows/review.md +71 -110
- package/.agent/workflows/session.md +53 -113
- package/.agent/workflows/status.md +42 -88
- package/.agent/workflows/strengthen-skills.md +90 -51
- package/.agent/workflows/swarm.md +114 -129
- package/.agent/workflows/test.md +125 -102
- package/.agent/workflows/tribunal-backend.md +60 -78
- package/.agent/workflows/tribunal-database.md +62 -100
- package/.agent/workflows/tribunal-frontend.md +62 -82
- package/.agent/workflows/tribunal-full.md +56 -100
- package/.agent/workflows/tribunal-mobile.md +65 -94
- package/.agent/workflows/tribunal-performance.md +62 -105
- package/.agent/workflows/ui-ux-pro-max.md +72 -121
- package/README.md +11 -15
- package/package.json +1 -1
- package/.agent/skills/api-patterns/api-style.md +0 -42
- package/.agent/skills/api-patterns/auth.md +0 -24
- package/.agent/skills/api-patterns/documentation.md +0 -26
- package/.agent/skills/api-patterns/graphql.md +0 -41
- package/.agent/skills/api-patterns/rate-limiting.md +0 -31
- package/.agent/skills/api-patterns/response.md +0 -37
- package/.agent/skills/api-patterns/rest.md +0 -40
- package/.agent/skills/api-patterns/security-testing.md +0 -122
- package/.agent/skills/api-patterns/trpc.md +0 -41
- package/.agent/skills/api-patterns/versioning.md +0 -22
- package/.agent/skills/app-builder/agent-coordination.md +0 -71
- package/.agent/skills/app-builder/feature-building.md +0 -53
- package/.agent/skills/app-builder/project-detection.md +0 -34
- package/.agent/skills/app-builder/scaffolding.md +0 -118
- package/.agent/skills/app-builder/tech-stack.md +0 -40
- package/.agent/skills/architecture/context-discovery.md +0 -43
- package/.agent/skills/architecture/examples.md +0 -94
- package/.agent/skills/architecture/pattern-selection.md +0 -68
- package/.agent/skills/architecture/patterns-reference.md +0 -50
- package/.agent/skills/architecture/trade-off-analysis.md +0 -77
- package/.agent/skills/brainstorming/dynamic-questioning.md +0 -360
- package/.agent/skills/database-design/database-selection.md +0 -43
- package/.agent/skills/database-design/indexing.md +0 -39
- package/.agent/skills/database-design/migrations.md +0 -48
- package/.agent/skills/database-design/optimization.md +0 -36
- package/.agent/skills/database-design/orm-selection.md +0 -30
- package/.agent/skills/database-design/schema-design.md +0 -56
- package/.agent/skills/dotnet-core-expert/SKILL.md +0 -103
- package/.agent/skills/framer-motion-animations/SKILL.md +0 -74
- package/.agent/skills/frontend-design/animation-guide.md +0 -331
- package/.agent/skills/frontend-design/color-system.md +0 -329
- package/.agent/skills/frontend-design/decision-trees.md +0 -418
- package/.agent/skills/frontend-design/motion-graphics.md +0 -306
- package/.agent/skills/frontend-design/typography-system.md +0 -363
- package/.agent/skills/frontend-design/ux-psychology.md +0 -1116
- package/.agent/skills/frontend-design/visual-effects.md +0 -383
- package/.agent/skills/game-development/2d-games/SKILL.md +0 -119
- package/.agent/skills/game-development/3d-games/SKILL.md +0 -135
- package/.agent/skills/game-development/SKILL.md +0 -236
- package/.agent/skills/game-development/game-art/SKILL.md +0 -185
- package/.agent/skills/game-development/game-audio/SKILL.md +0 -190
- package/.agent/skills/game-development/game-design/SKILL.md +0 -129
- package/.agent/skills/game-development/mobile-games/SKILL.md +0 -108
- package/.agent/skills/game-development/multiplayer/SKILL.md +0 -132
- package/.agent/skills/game-development/pc-games/SKILL.md +0 -144
- package/.agent/skills/game-development/vr-ar/SKILL.md +0 -123
- package/.agent/skills/game-development/web-games/SKILL.md +0 -150
- package/.agent/skills/intelligent-routing/router-manifest.md +0 -65
- package/.agent/skills/mobile-design/decision-trees.md +0 -516
- package/.agent/skills/mobile-design/mobile-backend.md +0 -491
- package/.agent/skills/mobile-design/mobile-color-system.md +0 -420
- package/.agent/skills/mobile-design/mobile-debugging.md +0 -122
- package/.agent/skills/mobile-design/mobile-design-thinking.md +0 -357
- package/.agent/skills/mobile-design/mobile-navigation.md +0 -458
- package/.agent/skills/mobile-design/mobile-performance.md +0 -767
- package/.agent/skills/mobile-design/mobile-testing.md +0 -356
- package/.agent/skills/mobile-design/mobile-typography.md +0 -433
- package/.agent/skills/mobile-design/platform-android.md +0 -666
- package/.agent/skills/mobile-design/platform-ios.md +0 -561
- package/.agent/skills/mobile-design/touch-psychology.md +0 -537
- package/.agent/skills/nextjs-react-expert/1-async-eliminating-waterfalls.md +0 -312
- package/.agent/skills/nextjs-react-expert/2-bundle-bundle-size-optimization.md +0 -240
- package/.agent/skills/nextjs-react-expert/3-server-server-side-performance.md +0 -490
- package/.agent/skills/nextjs-react-expert/4-client-client-side-data-fetching.md +0 -264
- package/.agent/skills/nextjs-react-expert/5-rerender-re-render-optimization.md +0 -581
- package/.agent/skills/nextjs-react-expert/6-rendering-rendering-performance.md +0 -432
- package/.agent/skills/nextjs-react-expert/7-js-javascript-performance.md +0 -684
- package/.agent/skills/nextjs-react-expert/8-advanced-advanced-patterns.md +0 -150
- package/.agent/skills/vulnerability-scanner/checklists.md +0 -121
|
@@ -1,200 +1,161 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: architecture
|
|
3
|
-
description:
|
|
4
|
-
allowed-tools: Read, Write, Edit, Glob, Grep
|
|
5
|
-
version: 1.0
|
|
6
|
-
last-updated: 2026-
|
|
7
|
-
applies-to-model: gemini-
|
|
8
|
-
---
|
|
9
|
-
|
|
10
|
-
# Architecture
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
```
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
|
111
|
-
|
|
|
112
|
-
|
|
|
113
|
-
|
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
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
|
|
4
|
-
allowed-tools: Read, Write, Edit, Glob, Grep
|
|
5
|
-
version:
|
|
6
|
-
last-updated: 2026-
|
|
7
|
-
applies-to-model: claude-3-7-sonnet
|
|
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
|
-
##
|
|
14
|
+
## Passwords & Hashing
|
|
36
15
|
|
|
37
|
-
|
|
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
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
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
|
-
##
|
|
45
|
+
## Session Management vs. JWT
|
|
48
46
|
|
|
49
|
-
|
|
50
|
-
**
|
|
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
|
-
###
|
|
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
|
-
|
|
55
|
-
|
|
56
|
-
|
|
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
|
-
|
|
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
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
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
|
-
|
|
103
|
+
---
|
|
69
104
|
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
-
|
|
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
|
+
---
|