create-claude-context 1.0.0 → 1.2.1
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/LICENSE +21 -21
- package/README.md +169 -146
- package/bin/create-claude-context.js +75 -61
- package/lib/ai-orchestrator.js +423 -0
- package/lib/call-tracer.js +444 -0
- package/lib/detector.js +456 -373
- package/lib/environment-detector.js +239 -0
- package/lib/index.js +271 -170
- package/lib/installer.js +371 -362
- package/lib/placeholder.js +269 -208
- package/lib/prompts.js +287 -287
- package/lib/spinner.js +60 -60
- package/lib/static-analyzer.js +729 -0
- package/lib/template-populator.js +835 -0
- package/lib/validate.js +147 -147
- package/package.json +59 -59
- package/templates/CLAUDE.md.template +235 -235
- package/templates/base/README.md +257 -257
- package/templates/base/RPI_WORKFLOW_PLAN.md +320 -320
- package/templates/base/agents/api-developer.md +76 -76
- package/templates/base/agents/context-engineer.md +525 -525
- package/templates/base/agents/core-architect.md +76 -76
- package/templates/base/agents/database-ops.md +76 -76
- package/templates/base/agents/deployment-ops.md +76 -76
- package/templates/base/agents/integration-hub.md +76 -76
- package/templates/base/analytics/README.md +114 -114
- package/templates/base/automation/config.json +58 -0
- package/templates/base/automation/generators/code-mapper.js +308 -0
- package/templates/base/automation/generators/index-builder.js +321 -0
- package/templates/base/automation/hooks/post-commit.sh +83 -0
- package/templates/base/automation/hooks/pre-commit.sh +103 -0
- package/templates/base/ci-templates/README.md +108 -108
- package/templates/base/ci-templates/github-actions/context-check.yml +144 -144
- package/templates/base/ci-templates/github-actions/validate-docs.yml +105 -105
- package/templates/base/commands/analytics.md +238 -238
- package/templates/base/commands/auto-sync.md +172 -0
- package/templates/base/commands/collab.md +194 -194
- package/templates/base/commands/help.md +450 -450
- package/templates/base/commands/rpi-implement.md +115 -115
- package/templates/base/commands/rpi-plan.md +93 -93
- package/templates/base/commands/rpi-research.md +88 -88
- package/templates/base/commands/session-resume.md +144 -0
- package/templates/base/commands/session-save.md +112 -0
- package/templates/base/commands/validate-all.md +77 -77
- package/templates/base/commands/verify-docs-current.md +86 -86
- package/templates/base/config/base.json +57 -57
- package/templates/base/config/environments/development.json +13 -13
- package/templates/base/config/environments/production.json +17 -17
- package/templates/base/config/environments/staging.json +13 -13
- package/templates/base/config/local.json.example +21 -21
- package/templates/base/context/.meta/generated-at.json +18 -0
- package/templates/base/context/ARCHITECTURE_SNAPSHOT.md +156 -156
- package/templates/base/context/CODE_TO_WORKFLOW_MAP.md +94 -94
- package/templates/base/context/FILE_OWNERSHIP.md +57 -0
- package/templates/base/context/INTEGRATION_POINTS.md +92 -0
- package/templates/base/context/KNOWN_GOTCHAS.md +195 -195
- package/templates/base/context/TESTING_MAP.md +95 -0
- package/templates/base/context/WORKFLOW_INDEX.md +129 -129
- package/templates/base/context/workflows/WORKFLOW_TEMPLATE.md +294 -294
- package/templates/base/indexes/agents/CAPABILITY_MATRIX.md +255 -255
- package/templates/base/indexes/agents/CATEGORY_INDEX.md +44 -44
- package/templates/base/indexes/code/CATEGORY_INDEX.md +38 -38
- package/templates/base/indexes/routing/CATEGORY_INDEX.md +39 -39
- package/templates/base/indexes/search/CATEGORY_INDEX.md +39 -39
- package/templates/base/indexes/workflows/CATEGORY_INDEX.md +38 -38
- package/templates/base/knowledge/README.md +98 -98
- package/templates/base/knowledge/sessions/README.md +88 -88
- package/templates/base/knowledge/sessions/TEMPLATE.md +150 -150
- package/templates/base/knowledge/shared/decisions/0001-adopt-context-engineering.md +144 -144
- package/templates/base/knowledge/shared/decisions/README.md +49 -49
- package/templates/base/knowledge/shared/decisions/TEMPLATE.md +123 -123
- package/templates/base/knowledge/shared/patterns/README.md +62 -62
- package/templates/base/knowledge/shared/patterns/TEMPLATE.md +120 -120
- package/templates/base/plans/PLAN_TEMPLATE.md +250 -250
- package/templates/base/research/RESEARCH_TEMPLATE.md +153 -153
- package/templates/base/schemas/agent.schema.json +141 -141
- package/templates/base/schemas/anchors.schema.json +54 -0
- package/templates/base/schemas/automation.schema.json +93 -0
- package/templates/base/schemas/command.schema.json +134 -134
- package/templates/base/schemas/hashes.schema.json +40 -0
- package/templates/base/schemas/manifest.schema.json +117 -117
- package/templates/base/schemas/plan.schema.json +136 -136
- package/templates/base/schemas/research.schema.json +115 -115
- package/templates/base/schemas/roles.schema.json +34 -0
- package/templates/base/schemas/session.schema.json +77 -0
- package/templates/base/schemas/settings.schema.json +244 -244
- package/templates/base/schemas/staleness.schema.json +53 -0
- package/templates/base/schemas/team-config.schema.json +42 -0
- package/templates/base/schemas/workflow.schema.json +126 -126
- package/templates/base/session/checkpoints/.gitkeep +2 -0
- package/templates/base/session/current/state.json +20 -0
- package/templates/base/session/history/.gitkeep +2 -0
- package/templates/base/settings.json +3 -57
- package/templates/base/standards/COMPATIBILITY.md +219 -219
- package/templates/base/standards/EXTENSION_GUIDELINES.md +280 -280
- package/templates/base/standards/QUALITY_CHECKLIST.md +211 -211
- package/templates/base/standards/README.md +66 -66
- package/templates/base/sync/anchors.json +6 -0
- package/templates/base/sync/hashes.json +6 -0
- package/templates/base/sync/staleness.json +10 -0
- package/templates/base/team/README.md +168 -168
- package/templates/base/team/config.json +79 -79
- package/templates/base/team/roles.json +145 -145
- package/templates/base/tools/bin/claude-context.js +151 -151
- package/templates/base/tools/lib/anchor-resolver.js +276 -0
- package/templates/base/tools/lib/config-loader.js +363 -363
- package/templates/base/tools/lib/detector.js +350 -350
- package/templates/base/tools/lib/diagnose.js +206 -206
- package/templates/base/tools/lib/drift-detector.js +373 -0
- package/templates/base/tools/lib/errors.js +199 -199
- package/templates/base/tools/lib/index.js +36 -24
- package/templates/base/tools/lib/init.js +192 -192
- package/templates/base/tools/lib/logger.js +230 -230
- package/templates/base/tools/lib/placeholder.js +201 -201
- package/templates/base/tools/lib/session-manager.js +354 -0
- package/templates/base/tools/lib/validate.js +521 -521
- package/templates/base/tools/package.json +49 -49
|
@@ -1,294 +1,294 @@
|
|
|
1
|
-
# [Workflow Name] Workflow
|
|
2
|
-
|
|
3
|
-
**Last Updated:** YYYY-MM-DD
|
|
4
|
-
**Last Verified Against Code:** YYYY-MM-DD (commit: HASH)
|
|
5
|
-
**Complexity:** HIGH / MEDIUM / LOW
|
|
6
|
-
**Token Estimate:** ~XX,XXX tokens (X% of 200k context)
|
|
7
|
-
|
|
8
|
-
---
|
|
9
|
-
|
|
10
|
-
## Quick Navigation
|
|
11
|
-
|
|
12
|
-
- [Overview](#overview)
|
|
13
|
-
- [Entry Points](#entry-points)
|
|
14
|
-
- [Sub-Workflow 1: [Name]](#sub-workflow-1-name)
|
|
15
|
-
- [Sub-Workflow 2: [Name]](#sub-workflow-2-name)
|
|
16
|
-
- [Database Schema](#database-schema)
|
|
17
|
-
- [External APIs](#external-apis)
|
|
18
|
-
- [Test Coverage](#test-coverage)
|
|
19
|
-
- [Known Gotchas](#known-gotchas)
|
|
20
|
-
- [Complete Call Chain](#complete-call-chain)
|
|
21
|
-
- [File Reference Table](#file-reference-table)
|
|
22
|
-
|
|
23
|
-
---
|
|
24
|
-
|
|
25
|
-
## Overview
|
|
26
|
-
|
|
27
|
-
**User Journey:**
|
|
28
|
-
[Describe what the user experiences from start to finish]
|
|
29
|
-
|
|
30
|
-
**Key Features:**
|
|
31
|
-
- [Feature 1]
|
|
32
|
-
- [Feature 2]
|
|
33
|
-
- [Feature 3]
|
|
34
|
-
|
|
35
|
-
**Business Logic Summary:**
|
|
36
|
-
[2-3 sentences explaining the core business rules]
|
|
37
|
-
|
|
38
|
-
---
|
|
39
|
-
|
|
40
|
-
## Entry Points
|
|
41
|
-
|
|
42
|
-
### Entry Point 1: [Name]
|
|
43
|
-
|
|
44
|
-
**File:** `path/to/file.ext` [Line XXX]
|
|
45
|
-
**Function:** `function_name()` [Lines XXX-YYY]
|
|
46
|
-
**Trigger:** [What triggers this entry point - API call, button click, scheduled job, etc.]
|
|
47
|
-
|
|
48
|
-
```
|
|
49
|
-
[Brief code snippet if helpful]
|
|
50
|
-
```
|
|
51
|
-
|
|
52
|
-
---
|
|
53
|
-
|
|
54
|
-
### Entry Point 2: [Name]
|
|
55
|
-
|
|
56
|
-
[Same structure as Entry Point 1...]
|
|
57
|
-
|
|
58
|
-
---
|
|
59
|
-
|
|
60
|
-
## Sub-Workflow 1: [Name]
|
|
61
|
-
|
|
62
|
-
**Purpose:** [What this sub-workflow accomplishes]
|
|
63
|
-
**Entry Point:** `file.ext:function_name()` [Line XXX]
|
|
64
|
-
|
|
65
|
-
### Call Chain
|
|
66
|
-
|
|
67
|
-
```
|
|
68
|
-
function_name() [file.ext:XXX]
|
|
69
|
-
├─ step_one() [file.ext:YYY]
|
|
70
|
-
│ ├─ helper_a() [helper.ext:ZZZ]
|
|
71
|
-
│ └─ helper_b() [helper.ext:AAA]
|
|
72
|
-
├─ step_two() [file.ext:BBB]
|
|
73
|
-
│ └─ database_query() [crud.ext:CCC]
|
|
74
|
-
└─ step_three() [file.ext:DDD]
|
|
75
|
-
└─ external_api() [client.ext:EEE]
|
|
76
|
-
```
|
|
77
|
-
|
|
78
|
-
### Database Operations
|
|
79
|
-
|
|
80
|
-
| Operation | Table | Purpose |
|
|
81
|
-
|-----------|-------|---------|
|
|
82
|
-
| READ | `table_name` | [Why reading] |
|
|
83
|
-
| WRITE | `table_name` | [What writing] |
|
|
84
|
-
| UPDATE | `table_name` | [What updating] |
|
|
85
|
-
|
|
86
|
-
### External APIs
|
|
87
|
-
|
|
88
|
-
| API | Endpoint | Purpose |
|
|
89
|
-
|-----|----------|---------|
|
|
90
|
-
| [API Name] | `POST /endpoint` | [What it does] |
|
|
91
|
-
|
|
92
|
-
### Error Handling
|
|
93
|
-
|
|
94
|
-
| Error | Handling | Recovery |
|
|
95
|
-
|-------|----------|----------|
|
|
96
|
-
| [Error type] | [How handled] | [How to recover] |
|
|
97
|
-
|
|
98
|
-
---
|
|
99
|
-
|
|
100
|
-
## Sub-Workflow 2: [Name]
|
|
101
|
-
|
|
102
|
-
[Same structure as Sub-Workflow 1...]
|
|
103
|
-
|
|
104
|
-
---
|
|
105
|
-
|
|
106
|
-
## Database Schema
|
|
107
|
-
|
|
108
|
-
### Tables Involved
|
|
109
|
-
|
|
110
|
-
| Table | Purpose | Key Fields |
|
|
111
|
-
|-------|---------|------------|
|
|
112
|
-
| `table_1` | [Purpose] | `field_a`, `field_b` |
|
|
113
|
-
| `table_2` | [Purpose] | `field_c`, `field_d` |
|
|
114
|
-
|
|
115
|
-
### Relationships
|
|
116
|
-
|
|
117
|
-
```
|
|
118
|
-
table_1 ─┬─< table_2 (one-to-many via foreign_key)
|
|
119
|
-
└─< table_3 (one-to-many via other_key)
|
|
120
|
-
```
|
|
121
|
-
|
|
122
|
-
### Schema Notes
|
|
123
|
-
|
|
124
|
-
[Any important schema considerations, constraints, indexes, etc.]
|
|
125
|
-
|
|
126
|
-
---
|
|
127
|
-
|
|
128
|
-
## External APIs
|
|
129
|
-
|
|
130
|
-
### [API Name 1]
|
|
131
|
-
|
|
132
|
-
**Base URL:** `https://api.example.com`
|
|
133
|
-
**Authentication:** [Method - API Key, OAuth, etc.]
|
|
134
|
-
**Rate Limits:** [If applicable]
|
|
135
|
-
|
|
136
|
-
**Endpoints Used:**
|
|
137
|
-
| Endpoint | Method | Purpose |
|
|
138
|
-
|----------|--------|---------|
|
|
139
|
-
| `/endpoint` | POST | [What it does] |
|
|
140
|
-
|
|
141
|
-
**Error Codes:**
|
|
142
|
-
| Code | Meaning | Handling |
|
|
143
|
-
|------|---------|----------|
|
|
144
|
-
| 400 | [Meaning] | [How handled] |
|
|
145
|
-
| 500 | [Meaning] | [How handled] |
|
|
146
|
-
|
|
147
|
-
---
|
|
148
|
-
|
|
149
|
-
## Test Coverage
|
|
150
|
-
|
|
151
|
-
### E2E Tests
|
|
152
|
-
|
|
153
|
-
| Test File | Test Name | Coverage |
|
|
154
|
-
|-----------|-----------|----------|
|
|
155
|
-
| `tests/e2e/test_file.ext` | `test_scenario` | Sub-workflows 1-3 |
|
|
156
|
-
|
|
157
|
-
### Unit Tests
|
|
158
|
-
|
|
159
|
-
| Test File | Coverage Area |
|
|
160
|
-
|-----------|---------------|
|
|
161
|
-
| `tests/unit/test_file.ext` | Function X, Function Y |
|
|
162
|
-
|
|
163
|
-
### Coverage Gaps
|
|
164
|
-
|
|
165
|
-
- ❌ [Missing test scenario 1]
|
|
166
|
-
- ❌ [Missing test scenario 2]
|
|
167
|
-
- ⚠️ [Edge case not covered]
|
|
168
|
-
|
|
169
|
-
### Running Tests
|
|
170
|
-
|
|
171
|
-
```bash
|
|
172
|
-
# Run all tests for this workflow
|
|
173
|
-
[test command]
|
|
174
|
-
|
|
175
|
-
# Run specific test
|
|
176
|
-
[specific test command]
|
|
177
|
-
```
|
|
178
|
-
|
|
179
|
-
---
|
|
180
|
-
|
|
181
|
-
## Known Gotchas
|
|
182
|
-
|
|
183
|
-
### Gotcha 1: [Title]
|
|
184
|
-
|
|
185
|
-
**Severity:** CRITICAL / HIGH / MEDIUM / LOW
|
|
186
|
-
**Symptom:** [What goes wrong]
|
|
187
|
-
**Root Cause:** [Why it happens]
|
|
188
|
-
|
|
189
|
-
**Fix:**
|
|
190
|
-
```
|
|
191
|
-
[Code or steps to fix]
|
|
192
|
-
```
|
|
193
|
-
|
|
194
|
-
**Prevention:**
|
|
195
|
-
- [How to avoid in future]
|
|
196
|
-
|
|
197
|
-
**Workflow Impact:** Sub-Workflow [X] is affected
|
|
198
|
-
|
|
199
|
-
---
|
|
200
|
-
|
|
201
|
-
### Gotcha 2: [Title]
|
|
202
|
-
|
|
203
|
-
[Same structure as Gotcha 1...]
|
|
204
|
-
|
|
205
|
-
---
|
|
206
|
-
|
|
207
|
-
## Complete Call Chain
|
|
208
|
-
|
|
209
|
-
### End-to-End Flow Diagram
|
|
210
|
-
|
|
211
|
-
```
|
|
212
|
-
[User Action / Trigger]
|
|
213
|
-
│
|
|
214
|
-
▼
|
|
215
|
-
┌─────────────────────┐
|
|
216
|
-
│ Entry Point │ file.ext:XXX
|
|
217
|
-
│ function_name() │
|
|
218
|
-
└─────────┬───────────┘
|
|
219
|
-
│
|
|
220
|
-
▼
|
|
221
|
-
┌─────────────────────┐
|
|
222
|
-
│ Sub-Workflow 1 │
|
|
223
|
-
│ [Name] │
|
|
224
|
-
└─────────┬───────────┘
|
|
225
|
-
│
|
|
226
|
-
▼
|
|
227
|
-
┌─────────────────────┐
|
|
228
|
-
│ Sub-Workflow 2 │ ──► [External API]
|
|
229
|
-
│ [Name] │
|
|
230
|
-
└─────────┬───────────┘
|
|
231
|
-
│
|
|
232
|
-
▼
|
|
233
|
-
┌─────────────────────┐
|
|
234
|
-
│ Database │
|
|
235
|
-
│ Operations │
|
|
236
|
-
└─────────┬───────────┘
|
|
237
|
-
│
|
|
238
|
-
▼
|
|
239
|
-
┌─────────────────────┐
|
|
240
|
-
│ Response/ │
|
|
241
|
-
│ Completion │
|
|
242
|
-
└─────────────────────┘
|
|
243
|
-
```
|
|
244
|
-
|
|
245
|
-
### State Transitions (if applicable)
|
|
246
|
-
|
|
247
|
-
```
|
|
248
|
-
[STATE_A] ──event──► [STATE_B] ──event──► [STATE_C]
|
|
249
|
-
│ │
|
|
250
|
-
└──────────── error ────────────────────►│
|
|
251
|
-
▼
|
|
252
|
-
[STATE_ERROR]
|
|
253
|
-
```
|
|
254
|
-
|
|
255
|
-
---
|
|
256
|
-
|
|
257
|
-
## File Reference Table
|
|
258
|
-
|
|
259
|
-
| File | Size | Purpose | Key Functions |
|
|
260
|
-
|------|------|---------|---------------|
|
|
261
|
-
| `path/file_1.ext` | XX KB | [What it does] | `func_a:XXX`, `func_b:YYY` |
|
|
262
|
-
| `path/file_2.ext` | XX KB | [What it does] | `func_c:ZZZ` |
|
|
263
|
-
| `path/file_3.ext` | XX KB | [What it does] | `func_d:AAA` |
|
|
264
|
-
|
|
265
|
-
---
|
|
266
|
-
|
|
267
|
-
## Maintenance Schedule
|
|
268
|
-
|
|
269
|
-
| Task | Frequency | Last Done | Next Due |
|
|
270
|
-
|------|-----------|-----------|----------|
|
|
271
|
-
| Verify line numbers | Monthly | YYYY-MM-DD | YYYY-MM-DD |
|
|
272
|
-
| Full audit | Quarterly | YYYY-MM-DD | YYYY-MM-DD |
|
|
273
|
-
|
|
274
|
-
---
|
|
275
|
-
|
|
276
|
-
## Related Documentation
|
|
277
|
-
|
|
278
|
-
- **Parent Index:** [WORKFLOW_INDEX.md](../WORKFLOW_INDEX.md)
|
|
279
|
-
- **Related Workflows:** [workflow_2.md](./workflow_2.md)
|
|
280
|
-
- **Responsible Agent:** [agent-name.md](../../agents/agent-name.md)
|
|
281
|
-
|
|
282
|
-
---
|
|
283
|
-
|
|
284
|
-
## Change Log
|
|
285
|
-
|
|
286
|
-
| Date | Change | Commit |
|
|
287
|
-
|------|--------|--------|
|
|
288
|
-
| YYYY-MM-DD | Initial documentation | `hash` |
|
|
289
|
-
|
|
290
|
-
---
|
|
291
|
-
|
|
292
|
-
**Version:** 1.0
|
|
293
|
-
**Word Count:** ~XXX words
|
|
294
|
-
**Token Estimate:** ~XX,XXX tokens
|
|
1
|
+
# [Workflow Name] Workflow
|
|
2
|
+
|
|
3
|
+
**Last Updated:** YYYY-MM-DD
|
|
4
|
+
**Last Verified Against Code:** YYYY-MM-DD (commit: HASH)
|
|
5
|
+
**Complexity:** HIGH / MEDIUM / LOW
|
|
6
|
+
**Token Estimate:** ~XX,XXX tokens (X% of 200k context)
|
|
7
|
+
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
## Quick Navigation
|
|
11
|
+
|
|
12
|
+
- [Overview](#overview)
|
|
13
|
+
- [Entry Points](#entry-points)
|
|
14
|
+
- [Sub-Workflow 1: [Name]](#sub-workflow-1-name)
|
|
15
|
+
- [Sub-Workflow 2: [Name]](#sub-workflow-2-name)
|
|
16
|
+
- [Database Schema](#database-schema)
|
|
17
|
+
- [External APIs](#external-apis)
|
|
18
|
+
- [Test Coverage](#test-coverage)
|
|
19
|
+
- [Known Gotchas](#known-gotchas)
|
|
20
|
+
- [Complete Call Chain](#complete-call-chain)
|
|
21
|
+
- [File Reference Table](#file-reference-table)
|
|
22
|
+
|
|
23
|
+
---
|
|
24
|
+
|
|
25
|
+
## Overview
|
|
26
|
+
|
|
27
|
+
**User Journey:**
|
|
28
|
+
[Describe what the user experiences from start to finish]
|
|
29
|
+
|
|
30
|
+
**Key Features:**
|
|
31
|
+
- [Feature 1]
|
|
32
|
+
- [Feature 2]
|
|
33
|
+
- [Feature 3]
|
|
34
|
+
|
|
35
|
+
**Business Logic Summary:**
|
|
36
|
+
[2-3 sentences explaining the core business rules]
|
|
37
|
+
|
|
38
|
+
---
|
|
39
|
+
|
|
40
|
+
## Entry Points
|
|
41
|
+
|
|
42
|
+
### Entry Point 1: [Name]
|
|
43
|
+
|
|
44
|
+
**File:** `path/to/file.ext` [Line XXX]
|
|
45
|
+
**Function:** `function_name()` [Lines XXX-YYY]
|
|
46
|
+
**Trigger:** [What triggers this entry point - API call, button click, scheduled job, etc.]
|
|
47
|
+
|
|
48
|
+
```
|
|
49
|
+
[Brief code snippet if helpful]
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
---
|
|
53
|
+
|
|
54
|
+
### Entry Point 2: [Name]
|
|
55
|
+
|
|
56
|
+
[Same structure as Entry Point 1...]
|
|
57
|
+
|
|
58
|
+
---
|
|
59
|
+
|
|
60
|
+
## Sub-Workflow 1: [Name]
|
|
61
|
+
|
|
62
|
+
**Purpose:** [What this sub-workflow accomplishes]
|
|
63
|
+
**Entry Point:** `file.ext:function_name()` [Line XXX]
|
|
64
|
+
|
|
65
|
+
### Call Chain
|
|
66
|
+
|
|
67
|
+
```
|
|
68
|
+
function_name() [file.ext:XXX]
|
|
69
|
+
├─ step_one() [file.ext:YYY]
|
|
70
|
+
│ ├─ helper_a() [helper.ext:ZZZ]
|
|
71
|
+
│ └─ helper_b() [helper.ext:AAA]
|
|
72
|
+
├─ step_two() [file.ext:BBB]
|
|
73
|
+
│ └─ database_query() [crud.ext:CCC]
|
|
74
|
+
└─ step_three() [file.ext:DDD]
|
|
75
|
+
└─ external_api() [client.ext:EEE]
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
### Database Operations
|
|
79
|
+
|
|
80
|
+
| Operation | Table | Purpose |
|
|
81
|
+
|-----------|-------|---------|
|
|
82
|
+
| READ | `table_name` | [Why reading] |
|
|
83
|
+
| WRITE | `table_name` | [What writing] |
|
|
84
|
+
| UPDATE | `table_name` | [What updating] |
|
|
85
|
+
|
|
86
|
+
### External APIs
|
|
87
|
+
|
|
88
|
+
| API | Endpoint | Purpose |
|
|
89
|
+
|-----|----------|---------|
|
|
90
|
+
| [API Name] | `POST /endpoint` | [What it does] |
|
|
91
|
+
|
|
92
|
+
### Error Handling
|
|
93
|
+
|
|
94
|
+
| Error | Handling | Recovery |
|
|
95
|
+
|-------|----------|----------|
|
|
96
|
+
| [Error type] | [How handled] | [How to recover] |
|
|
97
|
+
|
|
98
|
+
---
|
|
99
|
+
|
|
100
|
+
## Sub-Workflow 2: [Name]
|
|
101
|
+
|
|
102
|
+
[Same structure as Sub-Workflow 1...]
|
|
103
|
+
|
|
104
|
+
---
|
|
105
|
+
|
|
106
|
+
## Database Schema
|
|
107
|
+
|
|
108
|
+
### Tables Involved
|
|
109
|
+
|
|
110
|
+
| Table | Purpose | Key Fields |
|
|
111
|
+
|-------|---------|------------|
|
|
112
|
+
| `table_1` | [Purpose] | `field_a`, `field_b` |
|
|
113
|
+
| `table_2` | [Purpose] | `field_c`, `field_d` |
|
|
114
|
+
|
|
115
|
+
### Relationships
|
|
116
|
+
|
|
117
|
+
```
|
|
118
|
+
table_1 ─┬─< table_2 (one-to-many via foreign_key)
|
|
119
|
+
└─< table_3 (one-to-many via other_key)
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
### Schema Notes
|
|
123
|
+
|
|
124
|
+
[Any important schema considerations, constraints, indexes, etc.]
|
|
125
|
+
|
|
126
|
+
---
|
|
127
|
+
|
|
128
|
+
## External APIs
|
|
129
|
+
|
|
130
|
+
### [API Name 1]
|
|
131
|
+
|
|
132
|
+
**Base URL:** `https://api.example.com`
|
|
133
|
+
**Authentication:** [Method - API Key, OAuth, etc.]
|
|
134
|
+
**Rate Limits:** [If applicable]
|
|
135
|
+
|
|
136
|
+
**Endpoints Used:**
|
|
137
|
+
| Endpoint | Method | Purpose |
|
|
138
|
+
|----------|--------|---------|
|
|
139
|
+
| `/endpoint` | POST | [What it does] |
|
|
140
|
+
|
|
141
|
+
**Error Codes:**
|
|
142
|
+
| Code | Meaning | Handling |
|
|
143
|
+
|------|---------|----------|
|
|
144
|
+
| 400 | [Meaning] | [How handled] |
|
|
145
|
+
| 500 | [Meaning] | [How handled] |
|
|
146
|
+
|
|
147
|
+
---
|
|
148
|
+
|
|
149
|
+
## Test Coverage
|
|
150
|
+
|
|
151
|
+
### E2E Tests
|
|
152
|
+
|
|
153
|
+
| Test File | Test Name | Coverage |
|
|
154
|
+
|-----------|-----------|----------|
|
|
155
|
+
| `tests/e2e/test_file.ext` | `test_scenario` | Sub-workflows 1-3 |
|
|
156
|
+
|
|
157
|
+
### Unit Tests
|
|
158
|
+
|
|
159
|
+
| Test File | Coverage Area |
|
|
160
|
+
|-----------|---------------|
|
|
161
|
+
| `tests/unit/test_file.ext` | Function X, Function Y |
|
|
162
|
+
|
|
163
|
+
### Coverage Gaps
|
|
164
|
+
|
|
165
|
+
- ❌ [Missing test scenario 1]
|
|
166
|
+
- ❌ [Missing test scenario 2]
|
|
167
|
+
- ⚠️ [Edge case not covered]
|
|
168
|
+
|
|
169
|
+
### Running Tests
|
|
170
|
+
|
|
171
|
+
```bash
|
|
172
|
+
# Run all tests for this workflow
|
|
173
|
+
[test command]
|
|
174
|
+
|
|
175
|
+
# Run specific test
|
|
176
|
+
[specific test command]
|
|
177
|
+
```
|
|
178
|
+
|
|
179
|
+
---
|
|
180
|
+
|
|
181
|
+
## Known Gotchas
|
|
182
|
+
|
|
183
|
+
### Gotcha 1: [Title]
|
|
184
|
+
|
|
185
|
+
**Severity:** CRITICAL / HIGH / MEDIUM / LOW
|
|
186
|
+
**Symptom:** [What goes wrong]
|
|
187
|
+
**Root Cause:** [Why it happens]
|
|
188
|
+
|
|
189
|
+
**Fix:**
|
|
190
|
+
```
|
|
191
|
+
[Code or steps to fix]
|
|
192
|
+
```
|
|
193
|
+
|
|
194
|
+
**Prevention:**
|
|
195
|
+
- [How to avoid in future]
|
|
196
|
+
|
|
197
|
+
**Workflow Impact:** Sub-Workflow [X] is affected
|
|
198
|
+
|
|
199
|
+
---
|
|
200
|
+
|
|
201
|
+
### Gotcha 2: [Title]
|
|
202
|
+
|
|
203
|
+
[Same structure as Gotcha 1...]
|
|
204
|
+
|
|
205
|
+
---
|
|
206
|
+
|
|
207
|
+
## Complete Call Chain
|
|
208
|
+
|
|
209
|
+
### End-to-End Flow Diagram
|
|
210
|
+
|
|
211
|
+
```
|
|
212
|
+
[User Action / Trigger]
|
|
213
|
+
│
|
|
214
|
+
▼
|
|
215
|
+
┌─────────────────────┐
|
|
216
|
+
│ Entry Point │ file.ext:XXX
|
|
217
|
+
│ function_name() │
|
|
218
|
+
└─────────┬───────────┘
|
|
219
|
+
│
|
|
220
|
+
▼
|
|
221
|
+
┌─────────────────────┐
|
|
222
|
+
│ Sub-Workflow 1 │
|
|
223
|
+
│ [Name] │
|
|
224
|
+
└─────────┬───────────┘
|
|
225
|
+
│
|
|
226
|
+
▼
|
|
227
|
+
┌─────────────────────┐
|
|
228
|
+
│ Sub-Workflow 2 │ ──► [External API]
|
|
229
|
+
│ [Name] │
|
|
230
|
+
└─────────┬───────────┘
|
|
231
|
+
│
|
|
232
|
+
▼
|
|
233
|
+
┌─────────────────────┐
|
|
234
|
+
│ Database │
|
|
235
|
+
│ Operations │
|
|
236
|
+
└─────────┬───────────┘
|
|
237
|
+
│
|
|
238
|
+
▼
|
|
239
|
+
┌─────────────────────┐
|
|
240
|
+
│ Response/ │
|
|
241
|
+
│ Completion │
|
|
242
|
+
└─────────────────────┘
|
|
243
|
+
```
|
|
244
|
+
|
|
245
|
+
### State Transitions (if applicable)
|
|
246
|
+
|
|
247
|
+
```
|
|
248
|
+
[STATE_A] ──event──► [STATE_B] ──event──► [STATE_C]
|
|
249
|
+
│ │
|
|
250
|
+
└──────────── error ────────────────────►│
|
|
251
|
+
▼
|
|
252
|
+
[STATE_ERROR]
|
|
253
|
+
```
|
|
254
|
+
|
|
255
|
+
---
|
|
256
|
+
|
|
257
|
+
## File Reference Table
|
|
258
|
+
|
|
259
|
+
| File | Size | Purpose | Key Functions |
|
|
260
|
+
|------|------|---------|---------------|
|
|
261
|
+
| `path/file_1.ext` | XX KB | [What it does] | `func_a:XXX`, `func_b:YYY` |
|
|
262
|
+
| `path/file_2.ext` | XX KB | [What it does] | `func_c:ZZZ` |
|
|
263
|
+
| `path/file_3.ext` | XX KB | [What it does] | `func_d:AAA` |
|
|
264
|
+
|
|
265
|
+
---
|
|
266
|
+
|
|
267
|
+
## Maintenance Schedule
|
|
268
|
+
|
|
269
|
+
| Task | Frequency | Last Done | Next Due |
|
|
270
|
+
|------|-----------|-----------|----------|
|
|
271
|
+
| Verify line numbers | Monthly | YYYY-MM-DD | YYYY-MM-DD |
|
|
272
|
+
| Full audit | Quarterly | YYYY-MM-DD | YYYY-MM-DD |
|
|
273
|
+
|
|
274
|
+
---
|
|
275
|
+
|
|
276
|
+
## Related Documentation
|
|
277
|
+
|
|
278
|
+
- **Parent Index:** [WORKFLOW_INDEX.md](../WORKFLOW_INDEX.md)
|
|
279
|
+
- **Related Workflows:** [workflow_2.md](./workflow_2.md)
|
|
280
|
+
- **Responsible Agent:** [agent-name.md](../../agents/agent-name.md)
|
|
281
|
+
|
|
282
|
+
---
|
|
283
|
+
|
|
284
|
+
## Change Log
|
|
285
|
+
|
|
286
|
+
| Date | Change | Commit |
|
|
287
|
+
|------|--------|--------|
|
|
288
|
+
| YYYY-MM-DD | Initial documentation | `hash` |
|
|
289
|
+
|
|
290
|
+
---
|
|
291
|
+
|
|
292
|
+
**Version:** 1.0
|
|
293
|
+
**Word Count:** ~XXX words
|
|
294
|
+
**Token Estimate:** ~XX,XXX tokens
|