tribunal-kit 3.0.0 → 4.0.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 +187 -220
- package/.agent/agents/ai-code-reviewer.md +199 -233
- package/.agent/agents/backend-specialist.md +215 -238
- package/.agent/agents/code-archaeologist.md +161 -181
- package/.agent/agents/database-architect.md +184 -207
- package/.agent/agents/debugger.md +191 -218
- package/.agent/agents/dependency-reviewer.md +103 -136
- package/.agent/agents/devops-engineer.md +218 -238
- package/.agent/agents/documentation-writer.md +201 -221
- package/.agent/agents/explorer-agent.md +160 -180
- package/.agent/agents/frontend-reviewer.md +160 -194
- package/.agent/agents/frontend-specialist.md +248 -237
- package/.agent/agents/game-developer.md +48 -52
- package/.agent/agents/logic-reviewer.md +116 -149
- package/.agent/agents/mobile-developer.md +200 -223
- package/.agent/agents/mobile-reviewer.md +162 -195
- package/.agent/agents/orchestrator.md +181 -211
- package/.agent/agents/penetration-tester.md +157 -174
- package/.agent/agents/performance-optimizer.md +183 -203
- package/.agent/agents/performance-reviewer.md +178 -211
- package/.agent/agents/precedence-reviewer.md +213 -0
- package/.agent/agents/product-manager.md +142 -162
- package/.agent/agents/product-owner.md +6 -25
- package/.agent/agents/project-planner.md +142 -162
- package/.agent/agents/qa-automation-engineer.md +225 -242
- package/.agent/agents/security-auditor.md +174 -194
- package/.agent/agents/seo-specialist.md +193 -213
- package/.agent/agents/sql-reviewer.md +161 -194
- package/.agent/agents/supervisor-agent.md +184 -203
- 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 +160 -193
- package/.agent/agents/test-engineer.md +0 -21
- package/.agent/agents/type-safety-reviewer.md +175 -208
- 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/append_flow.js +72 -0
- package/.agent/scripts/case_law_manager.py +525 -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/skill_evolution.py +563 -0
- package/.agent/scripts/strip_tribunal.py +41 -0
- package/.agent/skills/agent-organizer/SKILL.md +100 -126
- package/.agent/skills/agentic-patterns/SKILL.md +0 -70
- package/.agent/skills/ai-prompt-injection-defense/SKILL.md +134 -160
- package/.agent/skills/api-patterns/SKILL.md +123 -215
- package/.agent/skills/api-security-auditor/SKILL.md +143 -177
- package/.agent/skills/app-builder/SKILL.md +334 -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 +95 -121
- package/.agent/skills/architecture/SKILL.md +169 -331
- package/.agent/skills/authentication-best-practices/SKILL.md +139 -173
- package/.agent/skills/bash-linux/SKILL.md +129 -154
- package/.agent/skills/behavioral-modes/SKILL.md +8 -69
- package/.agent/skills/brainstorming/SKILL.md +436 -104
- package/.agent/skills/building-native-ui/SKILL.md +152 -174
- package/.agent/skills/clean-code/SKILL.md +331 -360
- package/.agent/skills/code-review-checklist/SKILL.md +0 -62
- package/.agent/skills/config-validator/SKILL.md +115 -141
- package/.agent/skills/csharp-developer/SKILL.md +468 -528
- package/.agent/skills/database-design/SKILL.md +104 -369
- package/.agent/skills/deployment-procedures/SKILL.md +119 -145
- package/.agent/skills/devops-engineer/SKILL.md +295 -332
- package/.agent/skills/devops-incident-responder/SKILL.md +87 -113
- package/.agent/skills/doc.md +5 -5
- package/.agent/skills/documentation-templates/SKILL.md +27 -63
- package/.agent/skills/edge-computing/SKILL.md +131 -157
- package/.agent/skills/extract-design-system/SKILL.md +108 -134
- package/.agent/skills/framer-motion-expert/SKILL.md +111 -855
- package/.agent/skills/frontend-design/SKILL.md +151 -499
- package/.agent/skills/game-design-expert/SKILL.md +79 -105
- package/.agent/skills/game-engineering-expert/SKILL.md +96 -122
- package/.agent/skills/geo-fundamentals/SKILL.md +97 -124
- package/.agent/skills/github-operations/SKILL.md +279 -314
- package/.agent/skills/gsap-expert/SKILL.md +119 -826
- package/.agent/skills/i18n-localization/SKILL.md +113 -138
- package/.agent/skills/intelligent-routing/SKILL.md +167 -127
- package/.agent/skills/lint-and-validate/SKILL.md +16 -52
- package/.agent/skills/llm-engineering/SKILL.md +344 -357
- package/.agent/skills/local-first/SKILL.md +128 -154
- package/.agent/skills/mcp-builder/SKILL.md +92 -118
- 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 +99 -698
- package/.agent/skills/nodejs-best-practices/SKILL.md +498 -559
- package/.agent/skills/observability/SKILL.md +293 -330
- package/.agent/skills/parallel-agents/SKILL.md +96 -122
- package/.agent/skills/performance-profiling/SKILL.md +217 -254
- package/.agent/skills/plan-writing/SKILL.md +92 -118
- package/.agent/skills/platform-engineer/SKILL.md +97 -123
- package/.agent/skills/playwright-best-practices/SKILL.md +137 -162
- package/.agent/skills/powershell-windows/SKILL.md +112 -146
- package/.agent/skills/project-idioms/SKILL.md +87 -0
- package/.agent/skills/python-patterns/SKILL.md +15 -35
- package/.agent/skills/python-pro/SKILL.md +148 -754
- package/.agent/skills/react-specialist/SKILL.md +123 -827
- package/.agent/skills/readme-builder/SKILL.md +23 -85
- package/.agent/skills/realtime-patterns/SKILL.md +269 -304
- package/.agent/skills/red-team-tactics/SKILL.md +18 -51
- package/.agent/skills/rust-pro/SKILL.md +623 -701
- package/.agent/skills/seo-fundamentals/SKILL.md +129 -154
- package/.agent/skills/server-management/SKILL.md +164 -190
- package/.agent/skills/shadcn-ui-expert/SKILL.md +181 -206
- package/.agent/skills/skill-creator/SKILL.md +24 -56
- package/.agent/skills/sql-pro/SKILL.md +579 -633
- package/.agent/skills/supabase-postgres-best-practices/SKILL.md +35 -66
- package/.agent/skills/swiftui-expert/SKILL.md +151 -176
- package/.agent/skills/systematic-debugging/SKILL.md +92 -118
- package/.agent/skills/tailwind-patterns/SKILL.md +516 -576
- package/.agent/skills/tdd-workflow/SKILL.md +111 -137
- package/.agent/skills/test-result-analyzer/SKILL.md +33 -73
- package/.agent/skills/testing-patterns/SKILL.md +512 -573
- package/.agent/skills/trend-researcher/SKILL.md +30 -71
- package/.agent/skills/ui-ux-pro-max/SKILL.md +8 -41
- package/.agent/skills/ui-ux-researcher/SKILL.md +51 -91
- package/.agent/skills/vue-expert/SKILL.md +127 -866
- package/.agent/skills/vulnerability-scanner/SKILL.md +354 -269
- package/.agent/skills/web-accessibility-auditor/SKILL.md +168 -193
- package/.agent/skills/web-design-guidelines/SKILL.md +25 -61
- package/.agent/skills/webapp-testing/SKILL.md +119 -145
- package/.agent/skills/whimsy-injector/SKILL.md +58 -132
- package/.agent/skills/workflow-optimizer/SKILL.md +28 -68
- package/.agent/workflows/api-tester.md +151 -151
- package/.agent/workflows/audit.md +127 -138
- package/.agent/workflows/brainstorm.md +110 -110
- package/.agent/workflows/changelog.md +112 -112
- package/.agent/workflows/create.md +124 -124
- package/.agent/workflows/debug.md +165 -189
- package/.agent/workflows/deploy.md +180 -189
- package/.agent/workflows/enhance.md +128 -151
- package/.agent/workflows/fix.md +114 -135
- package/.agent/workflows/generate.md +13 -4
- package/.agent/workflows/migrate.md +160 -160
- package/.agent/workflows/orchestrate.md +168 -168
- package/.agent/workflows/performance-benchmarker.md +114 -123
- package/.agent/workflows/plan.md +173 -173
- package/.agent/workflows/preview.md +80 -80
- package/.agent/workflows/refactor.md +161 -183
- package/.agent/workflows/review-ai.md +101 -129
- package/.agent/workflows/review.md +116 -116
- package/.agent/workflows/session.md +94 -94
- package/.agent/workflows/status.md +79 -79
- package/.agent/workflows/strengthen-skills.md +138 -139
- package/.agent/workflows/swarm.md +179 -179
- package/.agent/workflows/test.md +189 -211
- package/.agent/workflows/tribunal-backend.md +94 -113
- package/.agent/workflows/tribunal-database.md +95 -115
- package/.agent/workflows/tribunal-frontend.md +96 -118
- package/.agent/workflows/tribunal-full.md +93 -133
- package/.agent/workflows/tribunal-mobile.md +95 -119
- package/.agent/workflows/tribunal-performance.md +110 -133
- package/.agent/workflows/ui-ux-pro-max.md +122 -143
- package/README.md +30 -1
- package/bin/tribunal-kit.js +175 -12
- package/package.json +25 -4
- 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/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/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,150 +0,0 @@
|
|
|
1
|
-
# 8. Advanced Patterns
|
|
2
|
-
|
|
3
|
-
> **Impact:** VARIABLE
|
|
4
|
-
> **Focus:** Advanced patterns for specific cases that require careful implementation.
|
|
5
|
-
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
## Overview
|
|
9
|
-
|
|
10
|
-
This section contains **3 rules** focused on advanced patterns.
|
|
11
|
-
|
|
12
|
-
---
|
|
13
|
-
|
|
14
|
-
## Rule 8.1: Initialize App Once, Not Per Mount
|
|
15
|
-
|
|
16
|
-
**Impact:** LOW-MEDIUM
|
|
17
|
-
**Tags:** initialization, useEffect, app-startup, side-effects
|
|
18
|
-
|
|
19
|
-
## Initialize App Once, Not Per Mount
|
|
20
|
-
|
|
21
|
-
Do not put app-wide initialization that must run once per app load inside `useEffect([])` of a component. Components can remount and effects will re-run. Use a module-level guard or top-level init in the entry module instead.
|
|
22
|
-
|
|
23
|
-
**Incorrect (runs twice in dev, re-runs on remount):**
|
|
24
|
-
|
|
25
|
-
```tsx
|
|
26
|
-
function Comp() {
|
|
27
|
-
useEffect(() => {
|
|
28
|
-
loadFromStorage()
|
|
29
|
-
checkAuthToken()
|
|
30
|
-
}, [])
|
|
31
|
-
|
|
32
|
-
// ...
|
|
33
|
-
}
|
|
34
|
-
```
|
|
35
|
-
|
|
36
|
-
**Correct (once per app load):**
|
|
37
|
-
|
|
38
|
-
```tsx
|
|
39
|
-
let didInit = false
|
|
40
|
-
|
|
41
|
-
function Comp() {
|
|
42
|
-
useEffect(() => {
|
|
43
|
-
if (didInit) return
|
|
44
|
-
didInit = true
|
|
45
|
-
loadFromStorage()
|
|
46
|
-
checkAuthToken()
|
|
47
|
-
}, [])
|
|
48
|
-
|
|
49
|
-
// ...
|
|
50
|
-
}
|
|
51
|
-
```
|
|
52
|
-
|
|
53
|
-
Reference: [Initializing the application](https://react.dev/learn/you-might-not-need-an-effect#initializing-the-application)
|
|
54
|
-
|
|
55
|
-
---
|
|
56
|
-
|
|
57
|
-
## Rule 8.2: Store Event Handlers in Refs
|
|
58
|
-
|
|
59
|
-
**Impact:** LOW
|
|
60
|
-
**Tags:** advanced, hooks, refs, event-handlers, optimization
|
|
61
|
-
|
|
62
|
-
## Store Event Handlers in Refs
|
|
63
|
-
|
|
64
|
-
Store callbacks in refs when used in effects that shouldn't re-subscribe on callback changes.
|
|
65
|
-
|
|
66
|
-
**Incorrect (re-subscribes on every render):**
|
|
67
|
-
|
|
68
|
-
```tsx
|
|
69
|
-
function useWindowEvent(event: string, handler: (e) => void) {
|
|
70
|
-
useEffect(() => {
|
|
71
|
-
window.addEventListener(event, handler)
|
|
72
|
-
return () => window.removeEventListener(event, handler)
|
|
73
|
-
}, [event, handler])
|
|
74
|
-
}
|
|
75
|
-
```
|
|
76
|
-
|
|
77
|
-
**Correct (stable subscription):**
|
|
78
|
-
|
|
79
|
-
```tsx
|
|
80
|
-
function useWindowEvent(event: string, handler: (e) => void) {
|
|
81
|
-
const handlerRef = useRef(handler)
|
|
82
|
-
useEffect(() => {
|
|
83
|
-
handlerRef.current = handler
|
|
84
|
-
}, [handler])
|
|
85
|
-
|
|
86
|
-
useEffect(() => {
|
|
87
|
-
const listener = (e) => handlerRef.current(e)
|
|
88
|
-
window.addEventListener(event, listener)
|
|
89
|
-
return () => window.removeEventListener(event, listener)
|
|
90
|
-
}, [event])
|
|
91
|
-
}
|
|
92
|
-
```
|
|
93
|
-
|
|
94
|
-
**Alternative: use `useEffectEvent` if you're on latest React:**
|
|
95
|
-
|
|
96
|
-
```tsx
|
|
97
|
-
import { useEffectEvent } from 'react'
|
|
98
|
-
|
|
99
|
-
function useWindowEvent(event: string, handler: (e) => void) {
|
|
100
|
-
const onEvent = useEffectEvent(handler)
|
|
101
|
-
|
|
102
|
-
useEffect(() => {
|
|
103
|
-
window.addEventListener(event, onEvent)
|
|
104
|
-
return () => window.removeEventListener(event, onEvent)
|
|
105
|
-
}, [event])
|
|
106
|
-
}
|
|
107
|
-
```
|
|
108
|
-
|
|
109
|
-
`useEffectEvent` provides a cleaner API for the same pattern: it creates a stable function reference that always calls the latest version of the handler.
|
|
110
|
-
|
|
111
|
-
---
|
|
112
|
-
|
|
113
|
-
## Rule 8.3: useEffectEvent for Stable Callback Refs
|
|
114
|
-
|
|
115
|
-
**Impact:** LOW
|
|
116
|
-
**Tags:** advanced, hooks, useEffectEvent, refs, optimization
|
|
117
|
-
|
|
118
|
-
## useEffectEvent for Stable Callback Refs
|
|
119
|
-
|
|
120
|
-
Access latest values in callbacks without adding them to dependency arrays. Prevents effect re-runs while avoiding stale closures.
|
|
121
|
-
|
|
122
|
-
**Incorrect (effect re-runs on every callback change):**
|
|
123
|
-
|
|
124
|
-
```tsx
|
|
125
|
-
function SearchInput({ onSearch }: { onSearch: (q: string) => void }) {
|
|
126
|
-
const [query, setQuery] = useState('')
|
|
127
|
-
|
|
128
|
-
useEffect(() => {
|
|
129
|
-
const timeout = setTimeout(() => onSearch(query), 300)
|
|
130
|
-
return () => clearTimeout(timeout)
|
|
131
|
-
}, [query, onSearch])
|
|
132
|
-
}
|
|
133
|
-
```
|
|
134
|
-
|
|
135
|
-
**Correct (using React's useEffectEvent):**
|
|
136
|
-
|
|
137
|
-
```tsx
|
|
138
|
-
import { useEffectEvent } from 'react';
|
|
139
|
-
|
|
140
|
-
function SearchInput({ onSearch }: { onSearch: (q: string) => void }) {
|
|
141
|
-
const [query, setQuery] = useState('')
|
|
142
|
-
const onSearchEvent = useEffectEvent(onSearch)
|
|
143
|
-
|
|
144
|
-
useEffect(() => {
|
|
145
|
-
const timeout = setTimeout(() => onSearchEvent(query), 300)
|
|
146
|
-
return () => clearTimeout(timeout)
|
|
147
|
-
}, [query])
|
|
148
|
-
}
|
|
149
|
-
```
|
|
150
|
-
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
# Security Checklists
|
|
2
|
-
|
|
3
|
-
> Quick reference checklists for security audits. Use alongside vulnerability-scanner principles.
|
|
4
|
-
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
## OWASP Top 10 Audit Checklist
|
|
8
|
-
|
|
9
|
-
### A01: Broken Access Control
|
|
10
|
-
- [ ] Authorization on all protected routes
|
|
11
|
-
- [ ] Deny by default
|
|
12
|
-
- [ ] Rate limiting implemented
|
|
13
|
-
- [ ] CORS properly configured
|
|
14
|
-
|
|
15
|
-
### A02: Cryptographic Failures
|
|
16
|
-
- [ ] Passwords hashed (bcrypt/argon2, cost 12+)
|
|
17
|
-
- [ ] Sensitive data encrypted at rest
|
|
18
|
-
- [ ] TLS 1.2+ for all connections
|
|
19
|
-
- [ ] No secrets in code/logs
|
|
20
|
-
|
|
21
|
-
### A03: Injection
|
|
22
|
-
- [ ] Parameterized queries
|
|
23
|
-
- [ ] Input validation on all user data
|
|
24
|
-
- [ ] Output encoding for XSS
|
|
25
|
-
- [ ] No eval() or dynamic code execution
|
|
26
|
-
|
|
27
|
-
### A04: Insecure Design
|
|
28
|
-
- [ ] Threat modeling done
|
|
29
|
-
- [ ] Security requirements defined
|
|
30
|
-
- [ ] Business logic validated
|
|
31
|
-
|
|
32
|
-
### A05: Security Misconfiguration
|
|
33
|
-
- [ ] Unnecessary features disabled
|
|
34
|
-
- [ ] Error messages sanitized
|
|
35
|
-
- [ ] Security headers configured
|
|
36
|
-
- [ ] Default credentials changed
|
|
37
|
-
|
|
38
|
-
### A06: Vulnerable Components
|
|
39
|
-
- [ ] Dependencies up to date
|
|
40
|
-
- [ ] No known vulnerabilities
|
|
41
|
-
- [ ] Unused dependencies removed
|
|
42
|
-
|
|
43
|
-
### A07: Authentication Failures
|
|
44
|
-
- [ ] MFA available
|
|
45
|
-
- [ ] Session invalidation on logout
|
|
46
|
-
- [ ] Session timeout implemented
|
|
47
|
-
- [ ] Brute force protection
|
|
48
|
-
|
|
49
|
-
### A08: Integrity Failures
|
|
50
|
-
- [ ] Dependency integrity verified
|
|
51
|
-
- [ ] CI/CD pipeline secured
|
|
52
|
-
- [ ] Update mechanism secured
|
|
53
|
-
|
|
54
|
-
### A09: Logging Failures
|
|
55
|
-
- [ ] Security events logged
|
|
56
|
-
- [ ] Logs protected
|
|
57
|
-
- [ ] No sensitive data in logs
|
|
58
|
-
- [ ] Alerting configured
|
|
59
|
-
|
|
60
|
-
### A10: SSRF
|
|
61
|
-
- [ ] URL validation implemented
|
|
62
|
-
- [ ] Allow-list for external calls
|
|
63
|
-
- [ ] Network segmentation
|
|
64
|
-
|
|
65
|
-
---
|
|
66
|
-
|
|
67
|
-
## Authentication Checklist
|
|
68
|
-
|
|
69
|
-
- [ ] Strong password policy
|
|
70
|
-
- [ ] Account lockout
|
|
71
|
-
- [ ] Secure password reset
|
|
72
|
-
- [ ] Session management
|
|
73
|
-
- [ ] Token expiration
|
|
74
|
-
- [ ] Logout invalidation
|
|
75
|
-
|
|
76
|
-
---
|
|
77
|
-
|
|
78
|
-
## API Security Checklist
|
|
79
|
-
|
|
80
|
-
- [ ] Authentication required
|
|
81
|
-
- [ ] Authorization per endpoint
|
|
82
|
-
- [ ] Input validation
|
|
83
|
-
- [ ] Rate limiting
|
|
84
|
-
- [ ] Output sanitization
|
|
85
|
-
- [ ] Error handling
|
|
86
|
-
|
|
87
|
-
---
|
|
88
|
-
|
|
89
|
-
## Data Protection Checklist
|
|
90
|
-
|
|
91
|
-
- [ ] Encryption at rest
|
|
92
|
-
- [ ] Encryption in transit
|
|
93
|
-
- [ ] Key management
|
|
94
|
-
- [ ] Data minimization
|
|
95
|
-
- [ ] Secure deletion
|
|
96
|
-
|
|
97
|
-
---
|
|
98
|
-
|
|
99
|
-
## Security Headers
|
|
100
|
-
|
|
101
|
-
| Header | Purpose |
|
|
102
|
-
|--------|---------|
|
|
103
|
-
| **Content-Security-Policy** | XSS prevention |
|
|
104
|
-
| **X-Content-Type-Options** | MIME sniffing |
|
|
105
|
-
| **X-Frame-Options** | Clickjacking |
|
|
106
|
-
| **Strict-Transport-Security** | Force HTTPS |
|
|
107
|
-
| **Referrer-Policy** | Referrer control |
|
|
108
|
-
|
|
109
|
-
---
|
|
110
|
-
|
|
111
|
-
## Quick Audit Commands
|
|
112
|
-
|
|
113
|
-
| Check | What to Look For |
|
|
114
|
-
|-------|------------------|
|
|
115
|
-
| Secrets in code | password, api_key, secret |
|
|
116
|
-
| Dangerous patterns | eval, innerHTML, SQL concat |
|
|
117
|
-
| Dependency issues | npm audit, snyk |
|
|
118
|
-
|
|
119
|
-
---
|
|
120
|
-
|
|
121
|
-
> **Usage:** Copy relevant checklists into your PLAN.md or security report.
|