cp-toolkit 2.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/README.md +130 -0
- package/bin/cp-kit.js +72 -0
- package/package.json +46 -0
- package/src/commands/add.js +212 -0
- package/src/commands/doctor.js +149 -0
- package/src/commands/init.js +662 -0
- package/src/commands/list.js +128 -0
- package/src/index.js +13 -0
- package/templates/agents/backend-specialist.md +263 -0
- package/templates/agents/code-archaeologist.md +106 -0
- package/templates/agents/database-architect.md +226 -0
- package/templates/agents/debugger.md +225 -0
- package/templates/agents/devops-engineer.md +242 -0
- package/templates/agents/documentation-writer.md +104 -0
- package/templates/agents/explorer-agent.md +73 -0
- package/templates/agents/frontend-specialist.md +556 -0
- package/templates/agents/game-developer.md +162 -0
- package/templates/agents/mobile-developer.md +377 -0
- package/templates/agents/orchestrator.md +416 -0
- package/templates/agents/penetration-tester.md +188 -0
- package/templates/agents/performance-optimizer.md +187 -0
- package/templates/agents/product-manager.md +112 -0
- package/templates/agents/product-owner.md +95 -0
- package/templates/agents/project-planner.md +406 -0
- package/templates/agents/qa-automation-engineer.md +103 -0
- package/templates/agents/security-auditor.md +170 -0
- package/templates/agents/seo-specialist.md +111 -0
- package/templates/agents/test-engineer.md +158 -0
- package/templates/github/agents/backend-specialist.md +67 -0
- package/templates/github/agents/code-archaeologist.md +61 -0
- package/templates/github/agents/database-architect.md +73 -0
- package/templates/github/agents/debugger.md +71 -0
- package/templates/github/agents/devops-engineer.md +85 -0
- package/templates/github/agents/documentation-writer.md +107 -0
- package/templates/github/agents/explorer-agent.md +87 -0
- package/templates/github/agents/frontend-specialist.md +54 -0
- package/templates/github/agents/game-developer.md +94 -0
- package/templates/github/agents/mobile-developer.md +75 -0
- package/templates/github/agents/orchestrator.md +48 -0
- package/templates/github/agents/penetration-tester.md +87 -0
- package/templates/github/agents/performance-optimizer.md +70 -0
- package/templates/github/agents/product-manager.md +85 -0
- package/templates/github/agents/product-owner.md +77 -0
- package/templates/github/agents/project-planner.md +83 -0
- package/templates/github/agents/qa-automation-engineer.md +95 -0
- package/templates/github/agents/security-auditor.md +72 -0
- package/templates/github/agents/seo-specialist.md +78 -0
- package/templates/github/agents/test-engineer.md +79 -0
- package/templates/github/instructions/database.instructions.md +74 -0
- package/templates/github/instructions/python.instructions.md +76 -0
- package/templates/github/instructions/security.instructions.md +73 -0
- package/templates/github/instructions/typescript.instructions.md +50 -0
- package/templates/rules/GEMINI.md +273 -0
- package/templates/scripts/mcp-server.js +704 -0
- package/templates/skills/core/behavioral-modes/SKILL.md +242 -0
- package/templates/skills/core/brainstorming/SKILL.md +163 -0
- package/templates/skills/core/brainstorming/dynamic-questioning.md +350 -0
- package/templates/skills/core/clean-code/SKILL.md +201 -0
- package/templates/skills/core/intelligent-routing/SKILL.md +335 -0
- package/templates/skills/core/mcp-builder/SKILL.md +176 -0
- package/templates/skills/core/parallel-agents/SKILL.md +175 -0
- package/templates/skills/core/plan-writing/SKILL.md +152 -0
- package/templates/skills/optional/api-patterns/SKILL.md +81 -0
- package/templates/skills/optional/api-patterns/api-style.md +42 -0
- package/templates/skills/optional/api-patterns/auth.md +24 -0
- package/templates/skills/optional/api-patterns/documentation.md +26 -0
- package/templates/skills/optional/api-patterns/graphql.md +41 -0
- package/templates/skills/optional/api-patterns/rate-limiting.md +31 -0
- package/templates/skills/optional/api-patterns/response.md +37 -0
- package/templates/skills/optional/api-patterns/rest.md +40 -0
- package/templates/skills/optional/api-patterns/scripts/api_validator.py +211 -0
- package/templates/skills/optional/api-patterns/security-testing.md +122 -0
- package/templates/skills/optional/api-patterns/trpc.md +41 -0
- package/templates/skills/optional/api-patterns/versioning.md +22 -0
- package/templates/skills/optional/app-builder/SKILL.md +75 -0
- package/templates/skills/optional/app-builder/agent-coordination.md +71 -0
- package/templates/skills/optional/app-builder/feature-building.md +53 -0
- package/templates/skills/optional/app-builder/project-detection.md +34 -0
- package/templates/skills/optional/app-builder/scaffolding.md +118 -0
- package/templates/skills/optional/app-builder/tech-stack.md +40 -0
- package/templates/skills/optional/app-builder/templates/SKILL.md +39 -0
- package/templates/skills/optional/app-builder/templates/astro-static/TEMPLATE.md +76 -0
- package/templates/skills/optional/app-builder/templates/chrome-extension/TEMPLATE.md +92 -0
- package/templates/skills/optional/app-builder/templates/cli-tool/TEMPLATE.md +88 -0
- package/templates/skills/optional/app-builder/templates/electron-desktop/TEMPLATE.md +88 -0
- package/templates/skills/optional/app-builder/templates/express-api/TEMPLATE.md +83 -0
- package/templates/skills/optional/app-builder/templates/flutter-app/TEMPLATE.md +90 -0
- package/templates/skills/optional/app-builder/templates/monorepo-turborepo/TEMPLATE.md +90 -0
- package/templates/skills/optional/app-builder/templates/nextjs-fullstack/TEMPLATE.md +82 -0
- package/templates/skills/optional/app-builder/templates/nextjs-saas/TEMPLATE.md +100 -0
- package/templates/skills/optional/app-builder/templates/nextjs-static/TEMPLATE.md +106 -0
- package/templates/skills/optional/app-builder/templates/nuxt-app/TEMPLATE.md +101 -0
- package/templates/skills/optional/app-builder/templates/python-fastapi/TEMPLATE.md +83 -0
- package/templates/skills/optional/app-builder/templates/react-native-app/TEMPLATE.md +93 -0
- package/templates/skills/optional/architecture/SKILL.md +55 -0
- package/templates/skills/optional/architecture/context-discovery.md +43 -0
- package/templates/skills/optional/architecture/examples.md +94 -0
- package/templates/skills/optional/architecture/pattern-selection.md +68 -0
- package/templates/skills/optional/architecture/patterns-reference.md +50 -0
- package/templates/skills/optional/architecture/trade-off-analysis.md +77 -0
- package/templates/skills/optional/bash-linux/SKILL.md +199 -0
- package/templates/skills/optional/code-review-checklist/SKILL.md +109 -0
- package/templates/skills/optional/database-design/SKILL.md +52 -0
- package/templates/skills/optional/database-design/database-selection.md +43 -0
- package/templates/skills/optional/database-design/indexing.md +39 -0
- package/templates/skills/optional/database-design/migrations.md +48 -0
- package/templates/skills/optional/database-design/optimization.md +36 -0
- package/templates/skills/optional/database-design/orm-selection.md +30 -0
- package/templates/skills/optional/database-design/schema-design.md +56 -0
- package/templates/skills/optional/database-design/scripts/schema_validator.py +172 -0
- package/templates/skills/optional/deployment-procedures/SKILL.md +241 -0
- package/templates/skills/optional/documentation-templates/SKILL.md +194 -0
- package/templates/skills/optional/frontend-design/SKILL.md +418 -0
- package/templates/skills/optional/frontend-design/animation-guide.md +331 -0
- package/templates/skills/optional/frontend-design/color-system.md +311 -0
- package/templates/skills/optional/frontend-design/decision-trees.md +418 -0
- package/templates/skills/optional/frontend-design/motion-graphics.md +306 -0
- package/templates/skills/optional/frontend-design/scripts/accessibility_checker.py +183 -0
- package/templates/skills/optional/frontend-design/scripts/ux_audit.py +722 -0
- package/templates/skills/optional/frontend-design/typography-system.md +345 -0
- package/templates/skills/optional/frontend-design/ux-psychology.md +541 -0
- package/templates/skills/optional/frontend-design/visual-effects.md +383 -0
- package/templates/skills/optional/game-development/2d-games/SKILL.md +119 -0
- package/templates/skills/optional/game-development/3d-games/SKILL.md +135 -0
- package/templates/skills/optional/game-development/SKILL.md +167 -0
- package/templates/skills/optional/game-development/game-art/SKILL.md +185 -0
- package/templates/skills/optional/game-development/game-audio/SKILL.md +190 -0
- package/templates/skills/optional/game-development/game-design/SKILL.md +129 -0
- package/templates/skills/optional/game-development/mobile-games/SKILL.md +108 -0
- package/templates/skills/optional/game-development/multiplayer/SKILL.md +132 -0
- package/templates/skills/optional/game-development/pc-games/SKILL.md +144 -0
- package/templates/skills/optional/game-development/vr-ar/SKILL.md +123 -0
- package/templates/skills/optional/game-development/web-games/SKILL.md +150 -0
- package/templates/skills/optional/geo-fundamentals/SKILL.md +156 -0
- package/templates/skills/optional/geo-fundamentals/scripts/geo_checker.py +289 -0
- package/templates/skills/optional/i18n-localization/SKILL.md +154 -0
- package/templates/skills/optional/i18n-localization/scripts/i18n_checker.py +241 -0
- package/templates/skills/optional/lint-and-validate/SKILL.md +45 -0
- package/templates/skills/optional/lint-and-validate/scripts/lint_runner.py +172 -0
- package/templates/skills/optional/lint-and-validate/scripts/type_coverage.py +173 -0
- package/templates/skills/optional/mobile-design/SKILL.md +394 -0
- package/templates/skills/optional/mobile-design/decision-trees.md +516 -0
- package/templates/skills/optional/mobile-design/mobile-backend.md +491 -0
- package/templates/skills/optional/mobile-design/mobile-color-system.md +420 -0
- package/templates/skills/optional/mobile-design/mobile-debugging.md +122 -0
- package/templates/skills/optional/mobile-design/mobile-design-thinking.md +357 -0
- package/templates/skills/optional/mobile-design/mobile-navigation.md +458 -0
- package/templates/skills/optional/mobile-design/mobile-performance.md +767 -0
- package/templates/skills/optional/mobile-design/mobile-testing.md +356 -0
- package/templates/skills/optional/mobile-design/mobile-typography.md +433 -0
- package/templates/skills/optional/mobile-design/platform-android.md +666 -0
- package/templates/skills/optional/mobile-design/platform-ios.md +561 -0
- package/templates/skills/optional/mobile-design/scripts/mobile_audit.py +670 -0
- package/templates/skills/optional/mobile-design/touch-psychology.md +537 -0
- package/templates/skills/optional/nextjs-react-expert/1-async-eliminating-waterfalls.md +312 -0
- package/templates/skills/optional/nextjs-react-expert/2-bundle-bundle-size-optimization.md +240 -0
- package/templates/skills/optional/nextjs-react-expert/3-server-server-side-performance.md +490 -0
- package/templates/skills/optional/nextjs-react-expert/4-client-client-side-data-fetching.md +264 -0
- package/templates/skills/optional/nextjs-react-expert/5-rerender-re-render-optimization.md +581 -0
- package/templates/skills/optional/nextjs-react-expert/6-rendering-rendering-performance.md +432 -0
- package/templates/skills/optional/nextjs-react-expert/7-js-javascript-performance.md +684 -0
- package/templates/skills/optional/nextjs-react-expert/8-advanced-advanced-patterns.md +150 -0
- package/templates/skills/optional/nextjs-react-expert/SKILL.md +267 -0
- package/templates/skills/optional/nextjs-react-expert/scripts/convert_rules.py +222 -0
- package/templates/skills/optional/nextjs-react-expert/scripts/react_performance_checker.py +252 -0
- package/templates/skills/optional/nodejs-best-practices/SKILL.md +333 -0
- package/templates/skills/optional/performance-profiling/SKILL.md +143 -0
- package/templates/skills/optional/performance-profiling/scripts/lighthouse_audit.py +76 -0
- package/templates/skills/optional/powershell-windows/SKILL.md +167 -0
- package/templates/skills/optional/python-patterns/SKILL.md +441 -0
- package/templates/skills/optional/red-team-tactics/SKILL.md +199 -0
- package/templates/skills/optional/seo-fundamentals/SKILL.md +129 -0
- package/templates/skills/optional/seo-fundamentals/scripts/seo_checker.py +219 -0
- package/templates/skills/optional/server-management/SKILL.md +161 -0
- package/templates/skills/optional/systematic-debugging/SKILL.md +109 -0
- package/templates/skills/optional/tailwind-patterns/SKILL.md +269 -0
- package/templates/skills/optional/tdd-workflow/SKILL.md +149 -0
- package/templates/skills/optional/testing-patterns/SKILL.md +178 -0
- package/templates/skills/optional/testing-patterns/scripts/test_runner.py +219 -0
- package/templates/skills/optional/vulnerability-scanner/SKILL.md +276 -0
- package/templates/skills/optional/vulnerability-scanner/checklists.md +121 -0
- package/templates/skills/optional/vulnerability-scanner/scripts/security_scan.py +458 -0
- package/templates/skills/optional/web-design-guidelines/SKILL.md +57 -0
- package/templates/skills/optional/webapp-testing/SKILL.md +187 -0
- package/templates/skills/optional/webapp-testing/scripts/playwright_runner.py +173 -0
- package/templates/workflows/brainstorm.md +113 -0
- package/templates/workflows/create.md +59 -0
- package/templates/workflows/debug.md +103 -0
- package/templates/workflows/deploy.md +176 -0
- package/templates/workflows/enhance.md +63 -0
- package/templates/workflows/orchestrate.md +237 -0
- package/templates/workflows/plan.md +89 -0
- package/templates/workflows/preview.md +81 -0
- package/templates/workflows/status.md +86 -0
- package/templates/workflows/test.md +144 -0
- package/templates/workflows/ui-ux-pro-max.md +296 -0
|
@@ -0,0 +1,441 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: python-patterns
|
|
3
|
+
description: Python development principles and decision-making. Framework selection, async patterns, type hints, project structure. Teaches thinking, not copying.
|
|
4
|
+
allowed-tools: Read, Write, Edit, Glob, Grep
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Python Patterns
|
|
8
|
+
|
|
9
|
+
> Python development principles and decision-making for 2025.
|
|
10
|
+
> **Learn to THINK, not memorize patterns.**
|
|
11
|
+
|
|
12
|
+
---
|
|
13
|
+
|
|
14
|
+
## ⚠️ How to Use This Skill
|
|
15
|
+
|
|
16
|
+
This skill teaches **decision-making principles**, not fixed code to copy.
|
|
17
|
+
|
|
18
|
+
- ASK user for framework preference when unclear
|
|
19
|
+
- Choose async vs sync based on CONTEXT
|
|
20
|
+
- Don't default to same framework every time
|
|
21
|
+
|
|
22
|
+
---
|
|
23
|
+
|
|
24
|
+
## 1. Framework Selection (2025)
|
|
25
|
+
|
|
26
|
+
### Decision Tree
|
|
27
|
+
|
|
28
|
+
```
|
|
29
|
+
What are you building?
|
|
30
|
+
│
|
|
31
|
+
├── API-first / Microservices
|
|
32
|
+
│ └── FastAPI (async, modern, fast)
|
|
33
|
+
│
|
|
34
|
+
├── Full-stack web / CMS / Admin
|
|
35
|
+
│ └── Django (batteries-included)
|
|
36
|
+
│
|
|
37
|
+
├── Simple / Script / Learning
|
|
38
|
+
│ └── Flask (minimal, flexible)
|
|
39
|
+
│
|
|
40
|
+
├── AI/ML API serving
|
|
41
|
+
│ └── FastAPI (Pydantic, async, uvicorn)
|
|
42
|
+
│
|
|
43
|
+
└── Background workers
|
|
44
|
+
└── Celery + any framework
|
|
45
|
+
```
|
|
46
|
+
|
|
47
|
+
### Comparison Principles
|
|
48
|
+
|
|
49
|
+
| Factor | FastAPI | Django | Flask |
|
|
50
|
+
|--------|---------|--------|-------|
|
|
51
|
+
| **Best for** | APIs, microservices | Full-stack, CMS | Simple, learning |
|
|
52
|
+
| **Async** | Native | Django 5.0+ | Via extensions |
|
|
53
|
+
| **Admin** | Manual | Built-in | Via extensions |
|
|
54
|
+
| **ORM** | Choose your own | Django ORM | Choose your own |
|
|
55
|
+
| **Learning curve** | Low | Medium | Low |
|
|
56
|
+
|
|
57
|
+
### Selection Questions to Ask:
|
|
58
|
+
1. Is this API-only or full-stack?
|
|
59
|
+
2. Need admin interface?
|
|
60
|
+
3. Team familiar with async?
|
|
61
|
+
4. Existing infrastructure?
|
|
62
|
+
|
|
63
|
+
---
|
|
64
|
+
|
|
65
|
+
## 2. Async vs Sync Decision
|
|
66
|
+
|
|
67
|
+
### When to Use Async
|
|
68
|
+
|
|
69
|
+
```
|
|
70
|
+
async def is better when:
|
|
71
|
+
├── I/O-bound operations (database, HTTP, file)
|
|
72
|
+
├── Many concurrent connections
|
|
73
|
+
├── Real-time features
|
|
74
|
+
├── Microservices communication
|
|
75
|
+
└── FastAPI/Starlette/Django ASGI
|
|
76
|
+
|
|
77
|
+
def (sync) is better when:
|
|
78
|
+
├── CPU-bound operations
|
|
79
|
+
├── Simple scripts
|
|
80
|
+
├── Legacy codebase
|
|
81
|
+
├── Team unfamiliar with async
|
|
82
|
+
└── Blocking libraries (no async version)
|
|
83
|
+
```
|
|
84
|
+
|
|
85
|
+
### The Golden Rule
|
|
86
|
+
|
|
87
|
+
```
|
|
88
|
+
I/O-bound → async (waiting for external)
|
|
89
|
+
CPU-bound → sync + multiprocessing (computing)
|
|
90
|
+
|
|
91
|
+
Don't:
|
|
92
|
+
├── Mix sync and async carelessly
|
|
93
|
+
├── Use sync libraries in async code
|
|
94
|
+
└── Force async for CPU work
|
|
95
|
+
```
|
|
96
|
+
|
|
97
|
+
### Async Library Selection
|
|
98
|
+
|
|
99
|
+
| Need | Async Library |
|
|
100
|
+
|------|---------------|
|
|
101
|
+
| HTTP client | httpx |
|
|
102
|
+
| PostgreSQL | asyncpg |
|
|
103
|
+
| Redis | aioredis / redis-py async |
|
|
104
|
+
| File I/O | aiofiles |
|
|
105
|
+
| Database ORM | SQLAlchemy 2.0 async, Tortoise |
|
|
106
|
+
|
|
107
|
+
---
|
|
108
|
+
|
|
109
|
+
## 3. Type Hints Strategy
|
|
110
|
+
|
|
111
|
+
### When to Type
|
|
112
|
+
|
|
113
|
+
```
|
|
114
|
+
Always type:
|
|
115
|
+
├── Function parameters
|
|
116
|
+
├── Return types
|
|
117
|
+
├── Class attributes
|
|
118
|
+
├── Public APIs
|
|
119
|
+
|
|
120
|
+
Can skip:
|
|
121
|
+
├── Local variables (let inference work)
|
|
122
|
+
├── One-off scripts
|
|
123
|
+
├── Tests (usually)
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
### Common Type Patterns
|
|
127
|
+
|
|
128
|
+
```python
|
|
129
|
+
# These are patterns, understand them:
|
|
130
|
+
|
|
131
|
+
# Optional → might be None
|
|
132
|
+
from typing import Optional
|
|
133
|
+
def find_user(id: int) -> Optional[User]: ...
|
|
134
|
+
|
|
135
|
+
# Union → one of multiple types
|
|
136
|
+
def process(data: str | dict) -> None: ...
|
|
137
|
+
|
|
138
|
+
# Generic collections
|
|
139
|
+
def get_items() -> list[Item]: ...
|
|
140
|
+
def get_mapping() -> dict[str, int]: ...
|
|
141
|
+
|
|
142
|
+
# Callable
|
|
143
|
+
from typing import Callable
|
|
144
|
+
def apply(fn: Callable[[int], str]) -> str: ...
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
### Pydantic for Validation
|
|
148
|
+
|
|
149
|
+
```
|
|
150
|
+
When to use Pydantic:
|
|
151
|
+
├── API request/response models
|
|
152
|
+
├── Configuration/settings
|
|
153
|
+
├── Data validation
|
|
154
|
+
├── Serialization
|
|
155
|
+
|
|
156
|
+
Benefits:
|
|
157
|
+
├── Runtime validation
|
|
158
|
+
├── Auto-generated JSON schema
|
|
159
|
+
├── Works with FastAPI natively
|
|
160
|
+
└── Clear error messages
|
|
161
|
+
```
|
|
162
|
+
|
|
163
|
+
---
|
|
164
|
+
|
|
165
|
+
## 4. Project Structure Principles
|
|
166
|
+
|
|
167
|
+
### Structure Selection
|
|
168
|
+
|
|
169
|
+
```
|
|
170
|
+
Small project / Script:
|
|
171
|
+
├── main.py
|
|
172
|
+
├── utils.py
|
|
173
|
+
└── requirements.txt
|
|
174
|
+
|
|
175
|
+
Medium API:
|
|
176
|
+
├── app/
|
|
177
|
+
│ ├── __init__.py
|
|
178
|
+
│ ├── main.py
|
|
179
|
+
│ ├── models/
|
|
180
|
+
│ ├── routes/
|
|
181
|
+
│ ├── services/
|
|
182
|
+
│ └── schemas/
|
|
183
|
+
├── tests/
|
|
184
|
+
└── pyproject.toml
|
|
185
|
+
|
|
186
|
+
Large application:
|
|
187
|
+
├── src/
|
|
188
|
+
│ └── myapp/
|
|
189
|
+
│ ├── core/
|
|
190
|
+
│ ├── api/
|
|
191
|
+
│ ├── services/
|
|
192
|
+
│ ├── models/
|
|
193
|
+
│ └── ...
|
|
194
|
+
├── tests/
|
|
195
|
+
└── pyproject.toml
|
|
196
|
+
```
|
|
197
|
+
|
|
198
|
+
### FastAPI Structure Principles
|
|
199
|
+
|
|
200
|
+
```
|
|
201
|
+
Organize by feature or layer:
|
|
202
|
+
|
|
203
|
+
By layer:
|
|
204
|
+
├── routes/ (API endpoints)
|
|
205
|
+
├── services/ (business logic)
|
|
206
|
+
├── models/ (database models)
|
|
207
|
+
├── schemas/ (Pydantic models)
|
|
208
|
+
└── dependencies/ (shared deps)
|
|
209
|
+
|
|
210
|
+
By feature:
|
|
211
|
+
├── users/
|
|
212
|
+
│ ├── routes.py
|
|
213
|
+
│ ├── service.py
|
|
214
|
+
│ └── schemas.py
|
|
215
|
+
└── products/
|
|
216
|
+
└── ...
|
|
217
|
+
```
|
|
218
|
+
|
|
219
|
+
---
|
|
220
|
+
|
|
221
|
+
## 5. Django Principles (2025)
|
|
222
|
+
|
|
223
|
+
### Django Async (Django 5.0+)
|
|
224
|
+
|
|
225
|
+
```
|
|
226
|
+
Django supports async:
|
|
227
|
+
├── Async views
|
|
228
|
+
├── Async middleware
|
|
229
|
+
├── Async ORM (limited)
|
|
230
|
+
└── ASGI deployment
|
|
231
|
+
|
|
232
|
+
When to use async in Django:
|
|
233
|
+
├── External API calls
|
|
234
|
+
├── WebSocket (Channels)
|
|
235
|
+
├── High-concurrency views
|
|
236
|
+
└── Background task triggering
|
|
237
|
+
```
|
|
238
|
+
|
|
239
|
+
### Django Best Practices
|
|
240
|
+
|
|
241
|
+
```
|
|
242
|
+
Model design:
|
|
243
|
+
├── Fat models, thin views
|
|
244
|
+
├── Use managers for common queries
|
|
245
|
+
├── Abstract base classes for shared fields
|
|
246
|
+
|
|
247
|
+
Views:
|
|
248
|
+
├── Class-based for complex CRUD
|
|
249
|
+
├── Function-based for simple endpoints
|
|
250
|
+
├── Use viewsets with DRF
|
|
251
|
+
|
|
252
|
+
Queries:
|
|
253
|
+
├── select_related() for FKs
|
|
254
|
+
├── prefetch_related() for M2M
|
|
255
|
+
├── Avoid N+1 queries
|
|
256
|
+
└── Use .only() for specific fields
|
|
257
|
+
```
|
|
258
|
+
|
|
259
|
+
---
|
|
260
|
+
|
|
261
|
+
## 6. FastAPI Principles
|
|
262
|
+
|
|
263
|
+
### async def vs def in FastAPI
|
|
264
|
+
|
|
265
|
+
```
|
|
266
|
+
Use async def when:
|
|
267
|
+
├── Using async database drivers
|
|
268
|
+
├── Making async HTTP calls
|
|
269
|
+
├── I/O-bound operations
|
|
270
|
+
└── Want to handle concurrency
|
|
271
|
+
|
|
272
|
+
Use def when:
|
|
273
|
+
├── Blocking operations
|
|
274
|
+
├── Sync database drivers
|
|
275
|
+
├── CPU-bound work
|
|
276
|
+
└── FastAPI runs in threadpool automatically
|
|
277
|
+
```
|
|
278
|
+
|
|
279
|
+
### Dependency Injection
|
|
280
|
+
|
|
281
|
+
```
|
|
282
|
+
Use dependencies for:
|
|
283
|
+
├── Database sessions
|
|
284
|
+
├── Current user / Auth
|
|
285
|
+
├── Configuration
|
|
286
|
+
├── Shared resources
|
|
287
|
+
|
|
288
|
+
Benefits:
|
|
289
|
+
├── Testability (mock dependencies)
|
|
290
|
+
├── Clean separation
|
|
291
|
+
├── Automatic cleanup (yield)
|
|
292
|
+
```
|
|
293
|
+
|
|
294
|
+
### Pydantic v2 Integration
|
|
295
|
+
|
|
296
|
+
```python
|
|
297
|
+
# FastAPI + Pydantic are tightly integrated:
|
|
298
|
+
|
|
299
|
+
# Request validation
|
|
300
|
+
@app.post("/users")
|
|
301
|
+
async def create(user: UserCreate) -> UserResponse:
|
|
302
|
+
# user is already validated
|
|
303
|
+
...
|
|
304
|
+
|
|
305
|
+
# Response serialization
|
|
306
|
+
# Return type becomes response schema
|
|
307
|
+
```
|
|
308
|
+
|
|
309
|
+
---
|
|
310
|
+
|
|
311
|
+
## 7. Background Tasks
|
|
312
|
+
|
|
313
|
+
### Selection Guide
|
|
314
|
+
|
|
315
|
+
| Solution | Best For |
|
|
316
|
+
|----------|----------|
|
|
317
|
+
| **BackgroundTasks** | Simple, in-process tasks |
|
|
318
|
+
| **Celery** | Distributed, complex workflows |
|
|
319
|
+
| **ARQ** | Async, Redis-based |
|
|
320
|
+
| **RQ** | Simple Redis queue |
|
|
321
|
+
| **Dramatiq** | Actor-based, simpler than Celery |
|
|
322
|
+
|
|
323
|
+
### When to Use Each
|
|
324
|
+
|
|
325
|
+
```
|
|
326
|
+
FastAPI BackgroundTasks:
|
|
327
|
+
├── Quick operations
|
|
328
|
+
├── No persistence needed
|
|
329
|
+
├── Fire-and-forget
|
|
330
|
+
└── Same process
|
|
331
|
+
|
|
332
|
+
Celery/ARQ:
|
|
333
|
+
├── Long-running tasks
|
|
334
|
+
├── Need retry logic
|
|
335
|
+
├── Distributed workers
|
|
336
|
+
├── Persistent queue
|
|
337
|
+
└── Complex workflows
|
|
338
|
+
```
|
|
339
|
+
|
|
340
|
+
---
|
|
341
|
+
|
|
342
|
+
## 8. Error Handling Principles
|
|
343
|
+
|
|
344
|
+
### Exception Strategy
|
|
345
|
+
|
|
346
|
+
```
|
|
347
|
+
In FastAPI:
|
|
348
|
+
├── Create custom exception classes
|
|
349
|
+
├── Register exception handlers
|
|
350
|
+
├── Return consistent error format
|
|
351
|
+
└── Log without exposing internals
|
|
352
|
+
|
|
353
|
+
Pattern:
|
|
354
|
+
├── Raise domain exceptions in services
|
|
355
|
+
├── Catch and transform in handlers
|
|
356
|
+
└── Client gets clean error response
|
|
357
|
+
```
|
|
358
|
+
|
|
359
|
+
### Error Response Philosophy
|
|
360
|
+
|
|
361
|
+
```
|
|
362
|
+
Include:
|
|
363
|
+
├── Error code (programmatic)
|
|
364
|
+
├── Message (human readable)
|
|
365
|
+
├── Details (field-level when applicable)
|
|
366
|
+
└── NOT stack traces (security)
|
|
367
|
+
```
|
|
368
|
+
|
|
369
|
+
---
|
|
370
|
+
|
|
371
|
+
## 9. Testing Principles
|
|
372
|
+
|
|
373
|
+
### Testing Strategy
|
|
374
|
+
|
|
375
|
+
| Type | Purpose | Tools |
|
|
376
|
+
|------|---------|-------|
|
|
377
|
+
| **Unit** | Business logic | pytest |
|
|
378
|
+
| **Integration** | API endpoints | pytest + httpx/TestClient |
|
|
379
|
+
| **E2E** | Full workflows | pytest + DB |
|
|
380
|
+
|
|
381
|
+
### Async Testing
|
|
382
|
+
|
|
383
|
+
```python
|
|
384
|
+
# Use pytest-asyncio for async tests
|
|
385
|
+
|
|
386
|
+
import pytest
|
|
387
|
+
from httpx import AsyncClient
|
|
388
|
+
|
|
389
|
+
@pytest.mark.asyncio
|
|
390
|
+
async def test_endpoint():
|
|
391
|
+
async with AsyncClient(app=app, base_url="http://test") as client:
|
|
392
|
+
response = await client.get("/users")
|
|
393
|
+
assert response.status_code == 200
|
|
394
|
+
```
|
|
395
|
+
|
|
396
|
+
### Fixtures Strategy
|
|
397
|
+
|
|
398
|
+
```
|
|
399
|
+
Common fixtures:
|
|
400
|
+
├── db_session → Database connection
|
|
401
|
+
├── client → Test client
|
|
402
|
+
├── authenticated_user → User with token
|
|
403
|
+
└── sample_data → Test data setup
|
|
404
|
+
```
|
|
405
|
+
|
|
406
|
+
---
|
|
407
|
+
|
|
408
|
+
## 10. Decision Checklist
|
|
409
|
+
|
|
410
|
+
Before implementing:
|
|
411
|
+
|
|
412
|
+
- [ ] **Asked user about framework preference?**
|
|
413
|
+
- [ ] **Chosen framework for THIS context?** (not just default)
|
|
414
|
+
- [ ] **Decided async vs sync?**
|
|
415
|
+
- [ ] **Planned type hint strategy?**
|
|
416
|
+
- [ ] **Defined project structure?**
|
|
417
|
+
- [ ] **Planned error handling?**
|
|
418
|
+
- [ ] **Considered background tasks?**
|
|
419
|
+
|
|
420
|
+
---
|
|
421
|
+
|
|
422
|
+
## 11. Anti-Patterns to Avoid
|
|
423
|
+
|
|
424
|
+
### ❌ DON'T:
|
|
425
|
+
- Default to Django for simple APIs (FastAPI may be better)
|
|
426
|
+
- Use sync libraries in async code
|
|
427
|
+
- Skip type hints for public APIs
|
|
428
|
+
- Put business logic in routes/views
|
|
429
|
+
- Ignore N+1 queries
|
|
430
|
+
- Mix async and sync carelessly
|
|
431
|
+
|
|
432
|
+
### ✅ DO:
|
|
433
|
+
- Choose framework based on context
|
|
434
|
+
- Ask about async requirements
|
|
435
|
+
- Use Pydantic for validation
|
|
436
|
+
- Separate concerns (routes → services → repos)
|
|
437
|
+
- Test critical paths
|
|
438
|
+
|
|
439
|
+
---
|
|
440
|
+
|
|
441
|
+
> **Remember**: Python patterns are about decision-making for YOUR specific context. Don't copy code—think about what serves your application best.
|
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: red-team-tactics
|
|
3
|
+
description: Red team tactics principles based on MITRE ATT&CK. Attack phases, detection evasion, reporting.
|
|
4
|
+
allowed-tools: Read, Glob, Grep
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Red Team Tactics
|
|
8
|
+
|
|
9
|
+
> Adversary simulation principles based on MITRE ATT&CK framework.
|
|
10
|
+
|
|
11
|
+
---
|
|
12
|
+
|
|
13
|
+
## 1. MITRE ATT&CK Phases
|
|
14
|
+
|
|
15
|
+
### Attack Lifecycle
|
|
16
|
+
|
|
17
|
+
```
|
|
18
|
+
RECONNAISSANCE → INITIAL ACCESS → EXECUTION → PERSISTENCE
|
|
19
|
+
↓ ↓ ↓ ↓
|
|
20
|
+
PRIVILEGE ESC → DEFENSE EVASION → CRED ACCESS → DISCOVERY
|
|
21
|
+
↓ ↓ ↓ ↓
|
|
22
|
+
LATERAL MOVEMENT → COLLECTION → C2 → EXFILTRATION → IMPACT
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
### Phase Objectives
|
|
26
|
+
|
|
27
|
+
| Phase | Objective |
|
|
28
|
+
|-------|-----------|
|
|
29
|
+
| **Recon** | Map attack surface |
|
|
30
|
+
| **Initial Access** | Get first foothold |
|
|
31
|
+
| **Execution** | Run code on target |
|
|
32
|
+
| **Persistence** | Survive reboots |
|
|
33
|
+
| **Privilege Escalation** | Get admin/root |
|
|
34
|
+
| **Defense Evasion** | Avoid detection |
|
|
35
|
+
| **Credential Access** | Harvest credentials |
|
|
36
|
+
| **Discovery** | Map internal network |
|
|
37
|
+
| **Lateral Movement** | Spread to other systems |
|
|
38
|
+
| **Collection** | Gather target data |
|
|
39
|
+
| **C2** | Maintain command channel |
|
|
40
|
+
| **Exfiltration** | Extract data |
|
|
41
|
+
|
|
42
|
+
---
|
|
43
|
+
|
|
44
|
+
## 2. Reconnaissance Principles
|
|
45
|
+
|
|
46
|
+
### Passive vs Active
|
|
47
|
+
|
|
48
|
+
| Type | Trade-off |
|
|
49
|
+
|------|-----------|
|
|
50
|
+
| **Passive** | No target contact, limited info |
|
|
51
|
+
| **Active** | Direct contact, more detection risk |
|
|
52
|
+
|
|
53
|
+
### Information Targets
|
|
54
|
+
|
|
55
|
+
| Category | Value |
|
|
56
|
+
|----------|-------|
|
|
57
|
+
| Technology stack | Attack vector selection |
|
|
58
|
+
| Employee info | Social engineering |
|
|
59
|
+
| Network ranges | Scanning scope |
|
|
60
|
+
| Third parties | Supply chain attack |
|
|
61
|
+
|
|
62
|
+
---
|
|
63
|
+
|
|
64
|
+
## 3. Initial Access Vectors
|
|
65
|
+
|
|
66
|
+
### Selection Criteria
|
|
67
|
+
|
|
68
|
+
| Vector | When to Use |
|
|
69
|
+
|--------|-------------|
|
|
70
|
+
| **Phishing** | Human target, email access |
|
|
71
|
+
| **Public exploits** | Vulnerable services exposed |
|
|
72
|
+
| **Valid credentials** | Leaked or cracked |
|
|
73
|
+
| **Supply chain** | Third-party access |
|
|
74
|
+
|
|
75
|
+
---
|
|
76
|
+
|
|
77
|
+
## 4. Privilege Escalation Principles
|
|
78
|
+
|
|
79
|
+
### Windows Targets
|
|
80
|
+
|
|
81
|
+
| Check | Opportunity |
|
|
82
|
+
|-------|-------------|
|
|
83
|
+
| Unquoted service paths | Write to path |
|
|
84
|
+
| Weak service permissions | Modify service |
|
|
85
|
+
| Token privileges | Abuse SeDebug, etc. |
|
|
86
|
+
| Stored credentials | Harvest |
|
|
87
|
+
|
|
88
|
+
### Linux Targets
|
|
89
|
+
|
|
90
|
+
| Check | Opportunity |
|
|
91
|
+
|-------|-------------|
|
|
92
|
+
| SUID binaries | Execute as owner |
|
|
93
|
+
| Sudo misconfiguration | Command execution |
|
|
94
|
+
| Kernel vulnerabilities | Kernel exploits |
|
|
95
|
+
| Cron jobs | Writable scripts |
|
|
96
|
+
|
|
97
|
+
---
|
|
98
|
+
|
|
99
|
+
## 5. Defense Evasion Principles
|
|
100
|
+
|
|
101
|
+
### Key Techniques
|
|
102
|
+
|
|
103
|
+
| Technique | Purpose |
|
|
104
|
+
|-----------|---------|
|
|
105
|
+
| LOLBins | Use legitimate tools |
|
|
106
|
+
| Obfuscation | Hide malicious code |
|
|
107
|
+
| Timestomping | Hide file modifications |
|
|
108
|
+
| Log clearing | Remove evidence |
|
|
109
|
+
|
|
110
|
+
### Operational Security
|
|
111
|
+
|
|
112
|
+
- Work during business hours
|
|
113
|
+
- Mimic legitimate traffic patterns
|
|
114
|
+
- Use encrypted channels
|
|
115
|
+
- Blend with normal behavior
|
|
116
|
+
|
|
117
|
+
---
|
|
118
|
+
|
|
119
|
+
## 6. Lateral Movement Principles
|
|
120
|
+
|
|
121
|
+
### Credential Types
|
|
122
|
+
|
|
123
|
+
| Type | Use |
|
|
124
|
+
|------|-----|
|
|
125
|
+
| Password | Standard auth |
|
|
126
|
+
| Hash | Pass-the-hash |
|
|
127
|
+
| Ticket | Pass-the-ticket |
|
|
128
|
+
| Certificate | Certificate auth |
|
|
129
|
+
|
|
130
|
+
### Movement Paths
|
|
131
|
+
|
|
132
|
+
- Admin shares
|
|
133
|
+
- Remote services (RDP, SSH, WinRM)
|
|
134
|
+
- Exploitation of internal services
|
|
135
|
+
|
|
136
|
+
---
|
|
137
|
+
|
|
138
|
+
## 7. Active Directory Attacks
|
|
139
|
+
|
|
140
|
+
### Attack Categories
|
|
141
|
+
|
|
142
|
+
| Attack | Target |
|
|
143
|
+
|--------|--------|
|
|
144
|
+
| Kerberoasting | Service account passwords |
|
|
145
|
+
| AS-REP Roasting | Accounts without pre-auth |
|
|
146
|
+
| DCSync | Domain credentials |
|
|
147
|
+
| Golden Ticket | Persistent domain access |
|
|
148
|
+
|
|
149
|
+
---
|
|
150
|
+
|
|
151
|
+
## 8. Reporting Principles
|
|
152
|
+
|
|
153
|
+
### Attack Narrative
|
|
154
|
+
|
|
155
|
+
Document the full attack chain:
|
|
156
|
+
1. How initial access was gained
|
|
157
|
+
2. What techniques were used
|
|
158
|
+
3. What objectives were achieved
|
|
159
|
+
4. Where detection failed
|
|
160
|
+
|
|
161
|
+
### Detection Gaps
|
|
162
|
+
|
|
163
|
+
For each successful technique:
|
|
164
|
+
- What should have detected it?
|
|
165
|
+
- Why didn't detection work?
|
|
166
|
+
- How to improve detection
|
|
167
|
+
|
|
168
|
+
---
|
|
169
|
+
|
|
170
|
+
## 9. Ethical Boundaries
|
|
171
|
+
|
|
172
|
+
### Always
|
|
173
|
+
|
|
174
|
+
- Stay within scope
|
|
175
|
+
- Minimize impact
|
|
176
|
+
- Report immediately if real threat found
|
|
177
|
+
- Document all actions
|
|
178
|
+
|
|
179
|
+
### Never
|
|
180
|
+
|
|
181
|
+
- Destroy production data
|
|
182
|
+
- Cause denial of service (unless scoped)
|
|
183
|
+
- Access beyond proof of concept
|
|
184
|
+
- Retain sensitive data
|
|
185
|
+
|
|
186
|
+
---
|
|
187
|
+
|
|
188
|
+
## 10. Anti-Patterns
|
|
189
|
+
|
|
190
|
+
| ❌ Don't | ✅ Do |
|
|
191
|
+
|----------|-------|
|
|
192
|
+
| Rush to exploitation | Follow methodology |
|
|
193
|
+
| Cause damage | Minimize impact |
|
|
194
|
+
| Skip reporting | Document everything |
|
|
195
|
+
| Ignore scope | Stay within boundaries |
|
|
196
|
+
|
|
197
|
+
---
|
|
198
|
+
|
|
199
|
+
> **Remember:** Red team simulates attackers to improve defenses, not to cause harm.
|