aios-core 2.2.1 → 2.3.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/.aios-core/.session/current-session.json +14 -14
- package/.aios-core/cli/commands/migrate/validate.js +1 -1
- package/.aios-core/core/docs/session-update-pattern.md +17 -10
- package/.aios-core/core/elicitation/elicitation-engine.js +11 -6
- package/.aios-core/core/elicitation/session-manager.js +2 -1
- package/.aios-core/core/registry/registry-schema.json +166 -166
- package/.aios-core/core/registry/service-registry.json +6585 -6585
- package/.aios-core/core-config.yaml +12 -1
- package/.aios-core/data/agent-config-requirements.yaml +5 -5
- package/.aios-core/development/agents/devops.md +12 -0
- package/.aios-core/development/scripts/squad/README.md +112 -0
- package/.aios-core/development/scripts/squad/index.js +41 -0
- package/.aios-core/development/scripts/squad/squad-loader.js +359 -0
- package/.aios-core/development/scripts/squad/squad-validator.js +685 -0
- package/.aios-core/development/tasks/add-mcp.md +11 -5
- package/.aios-core/development/tasks/search-mcp.md +309 -0
- package/.aios-core/development/tasks/setup-mcp-docker.md +11 -8
- package/.aios-core/development/tasks/squad-creator-validate.md +151 -0
- package/.aios-core/docs/standards/AGENT-PERSONALIZATION-STANDARD-V1.md +3 -3
- package/.aios-core/index.d.ts +7 -7
- package/.aios-core/index.js +1 -1
- package/.aios-core/infrastructure/scripts/batch-creator.js +1 -1
- package/.aios-core/infrastructure/scripts/component-generator.js +1 -1
- package/.aios-core/infrastructure/templates/coderabbit.yaml.template +279 -279
- package/.aios-core/infrastructure/templates/github-workflows/ci.yml.template +169 -169
- package/.aios-core/infrastructure/templates/github-workflows/pr-automation.yml.template +330 -330
- package/.aios-core/infrastructure/templates/github-workflows/release.yml.template +196 -196
- package/.aios-core/infrastructure/templates/gitignore/gitignore-aios-base.tmpl +63 -63
- package/.aios-core/infrastructure/templates/gitignore/gitignore-brownfield-merge.tmpl +18 -18
- package/.aios-core/infrastructure/templates/gitignore/gitignore-node.tmpl +85 -85
- package/.aios-core/infrastructure/templates/gitignore/gitignore-python.tmpl +145 -145
- package/.aios-core/infrastructure/tests/utilities-audit-results.json +500 -500
- package/.aios-core/infrastructure/tools/README.md +1 -1
- package/.aios-core/install-manifest.yaml +4 -1
- package/.aios-core/manifests/schema/manifest-schema.json +190 -190
- package/.aios-core/manifests/workers.csv +203 -203
- package/.aios-core/package.json +102 -102
- package/.aios-core/product/templates/activation-instructions-template.md +7 -7
- package/.aios-core/product/templates/adr.hbs +125 -125
- package/.aios-core/product/templates/component-react-tmpl.tsx +98 -98
- package/.aios-core/product/templates/dbdr.hbs +241 -241
- package/.aios-core/product/templates/engine/schemas/adr.schema.json +102 -102
- package/.aios-core/product/templates/engine/schemas/dbdr.schema.json +205 -205
- package/.aios-core/product/templates/engine/schemas/epic.schema.json +175 -175
- package/.aios-core/product/templates/engine/schemas/pmdr.schema.json +175 -175
- package/.aios-core/product/templates/engine/schemas/prd-v2.schema.json +300 -300
- package/.aios-core/product/templates/engine/schemas/prd.schema.json +152 -152
- package/.aios-core/product/templates/engine/schemas/story.schema.json +222 -222
- package/.aios-core/product/templates/engine/schemas/task.schema.json +154 -154
- package/.aios-core/product/templates/epic.hbs +212 -212
- package/.aios-core/product/templates/eslintrc-security.json +32 -32
- package/.aios-core/product/templates/github-actions-cd.yml +212 -212
- package/.aios-core/product/templates/github-actions-ci.yml +172 -172
- package/.aios-core/product/templates/pmdr.hbs +186 -186
- package/.aios-core/product/templates/prd-v2.0.hbs +216 -216
- package/.aios-core/product/templates/prd.hbs +201 -201
- package/.aios-core/product/templates/shock-report-tmpl.html +502 -502
- package/.aios-core/product/templates/story.hbs +263 -263
- package/.aios-core/product/templates/task.hbs +170 -170
- package/.aios-core/product/templates/tmpl-comment-on-examples.sql +158 -158
- package/.aios-core/product/templates/tmpl-migration-script.sql +91 -91
- package/.aios-core/product/templates/tmpl-rls-granular-policies.sql +104 -104
- package/.aios-core/product/templates/tmpl-rls-kiss-policy.sql +10 -10
- package/.aios-core/product/templates/tmpl-rls-roles.sql +135 -135
- package/.aios-core/product/templates/tmpl-rls-simple.sql +77 -77
- package/.aios-core/product/templates/tmpl-rls-tenant.sql +152 -152
- package/.aios-core/product/templates/tmpl-rollback-script.sql +77 -77
- package/.aios-core/product/templates/tmpl-seed-data.sql +140 -140
- package/.aios-core/product/templates/tmpl-smoke-test.sql +16 -16
- package/.aios-core/product/templates/tmpl-staging-copy-merge.sql +139 -139
- package/.aios-core/product/templates/tmpl-stored-proc.sql +140 -140
- package/.aios-core/product/templates/tmpl-trigger.sql +152 -152
- package/.aios-core/product/templates/tmpl-view-materialized.sql +133 -133
- package/.aios-core/product/templates/tmpl-view.sql +177 -177
- package/.aios-core/product/templates/token-exports-css-tmpl.css +240 -240
- package/.aios-core/quality/schemas/quality-metrics.schema.json +233 -233
- package/.aios-core/schemas/squad-schema.json +185 -0
- package/.aios-core/scripts/README.md +90 -322
- package/.aios-core/scripts/migrate-framework-docs.sh +300 -300
- package/.claude/rules/mcp-usage.md +116 -100
- package/LICENSE +48 -48
- package/README.md +3 -4
- package/bin/aios-init.js +11 -6
- package/bin/aios.js +2 -1
- package/package.json +2 -3
- package/packages/installer/package.json +39 -39
- package/packages/installer/tests/integration/environment-configuration.test.js +2 -2
- package/packages/installer/tests/unit/env-template.test.js +4 -3
- package/templates/squad/LICENSE +21 -21
- package/templates/squad/README.md +37 -37
- package/templates/squad/agents/example-agent.yaml +36 -36
- package/templates/squad/package.json +19 -19
- package/templates/squad/squad.yaml +25 -25
- package/templates/squad/tasks/example-task.yaml +46 -46
- package/templates/squad/templates/example-template.md +24 -24
- package/templates/squad/tests/example-agent.test.js +53 -53
- package/templates/squad/workflows/example-workflow.yaml +54 -54
- package/tools/diagnose-npx-issue.ps1 +96 -96
- package/tools/quick-diagnose.cmd +85 -85
- package/tools/quick-diagnose.ps1 +117 -117
- package/.aios-core/core/data/agent-config-requirements.yaml +0 -368
- package/.aios-core/core/data/aios-kb.md +0 -924
- package/.aios-core/core/data/workflow-patterns.yaml +0 -267
- package/.aios-core/product/templates/1mcp-config.yaml +0 -225
- package/.aios-core/scripts/context-detector.js +0 -226
- package/.aios-core/scripts/elicitation-engine.js +0 -385
- package/.aios-core/scripts/elicitation-session-manager.js +0 -300
- package/.claude/CLAUDE.md +0 -221
|
@@ -1,102 +1,102 @@
|
|
|
1
|
-
{
|
|
2
|
-
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
-
"title": "ADR Template Variables",
|
|
4
|
-
"description": "Schema for Architecture Decision Record template variables",
|
|
5
|
-
"type": "object",
|
|
6
|
-
"required": ["number", "title", "status", "deciders", "context", "decision", "positiveConsequences"],
|
|
7
|
-
"properties": {
|
|
8
|
-
"number": {
|
|
9
|
-
"type": "integer",
|
|
10
|
-
"minimum": 1,
|
|
11
|
-
"description": "ADR number for ordering and reference"
|
|
12
|
-
},
|
|
13
|
-
"title": {
|
|
14
|
-
"type": "string",
|
|
15
|
-
"minLength": 5,
|
|
16
|
-
"maxLength": 100,
|
|
17
|
-
"description": "Short title describing the decision"
|
|
18
|
-
},
|
|
19
|
-
"status": {
|
|
20
|
-
"type": "string",
|
|
21
|
-
"enum": ["Proposed", "Accepted", "Deprecated", "Superseded"],
|
|
22
|
-
"description": "Current status of the decision"
|
|
23
|
-
},
|
|
24
|
-
"deciders": {
|
|
25
|
-
"type": "string",
|
|
26
|
-
"minLength": 1,
|
|
27
|
-
"description": "Names of people involved in the decision"
|
|
28
|
-
},
|
|
29
|
-
"context": {
|
|
30
|
-
"type": "string",
|
|
31
|
-
"minLength": 20,
|
|
32
|
-
"description": "Context and background that led to this decision"
|
|
33
|
-
},
|
|
34
|
-
"decision": {
|
|
35
|
-
"type": "string",
|
|
36
|
-
"minLength": 20,
|
|
37
|
-
"description": "The decision being made"
|
|
38
|
-
},
|
|
39
|
-
"positiveConsequences": {
|
|
40
|
-
"type": "array",
|
|
41
|
-
"minItems": 1,
|
|
42
|
-
"items": { "type": "string" },
|
|
43
|
-
"description": "Positive outcomes of the decision"
|
|
44
|
-
},
|
|
45
|
-
"negativeConsequences": {
|
|
46
|
-
"type": "array",
|
|
47
|
-
"items": { "type": "string" },
|
|
48
|
-
"description": "Negative outcomes or trade-offs"
|
|
49
|
-
},
|
|
50
|
-
"alternatives": {
|
|
51
|
-
"type": "array",
|
|
52
|
-
"items": {
|
|
53
|
-
"type": "object",
|
|
54
|
-
"required": ["name", "description"],
|
|
55
|
-
"properties": {
|
|
56
|
-
"name": {
|
|
57
|
-
"type": "string",
|
|
58
|
-
"description": "Alternative option name"
|
|
59
|
-
},
|
|
60
|
-
"description": {
|
|
61
|
-
"type": "string",
|
|
62
|
-
"description": "Description of the alternative"
|
|
63
|
-
},
|
|
64
|
-
"pros": {
|
|
65
|
-
"type": "string",
|
|
66
|
-
"description": "Advantages of this alternative"
|
|
67
|
-
},
|
|
68
|
-
"cons": {
|
|
69
|
-
"type": "string",
|
|
70
|
-
"description": "Disadvantages of this alternative"
|
|
71
|
-
},
|
|
72
|
-
"whyNot": {
|
|
73
|
-
"type": "string",
|
|
74
|
-
"description": "Why this alternative was not chosen"
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
},
|
|
78
|
-
"description": "Alternative options considered"
|
|
79
|
-
},
|
|
80
|
-
"relatedADRs": {
|
|
81
|
-
"type": "array",
|
|
82
|
-
"items": {
|
|
83
|
-
"type": "object",
|
|
84
|
-
"required": ["number", "title"],
|
|
85
|
-
"properties": {
|
|
86
|
-
"number": { "type": "integer" },
|
|
87
|
-
"title": { "type": "string" }
|
|
88
|
-
}
|
|
89
|
-
},
|
|
90
|
-
"description": "Related ADR references"
|
|
91
|
-
},
|
|
92
|
-
"references": {
|
|
93
|
-
"type": "array",
|
|
94
|
-
"items": { "type": "string" },
|
|
95
|
-
"description": "External references and links"
|
|
96
|
-
},
|
|
97
|
-
"supersededBy": {
|
|
98
|
-
"type": "integer",
|
|
99
|
-
"description": "ADR number that supersedes this one"
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"title": "ADR Template Variables",
|
|
4
|
+
"description": "Schema for Architecture Decision Record template variables",
|
|
5
|
+
"type": "object",
|
|
6
|
+
"required": ["number", "title", "status", "deciders", "context", "decision", "positiveConsequences"],
|
|
7
|
+
"properties": {
|
|
8
|
+
"number": {
|
|
9
|
+
"type": "integer",
|
|
10
|
+
"minimum": 1,
|
|
11
|
+
"description": "ADR number for ordering and reference"
|
|
12
|
+
},
|
|
13
|
+
"title": {
|
|
14
|
+
"type": "string",
|
|
15
|
+
"minLength": 5,
|
|
16
|
+
"maxLength": 100,
|
|
17
|
+
"description": "Short title describing the decision"
|
|
18
|
+
},
|
|
19
|
+
"status": {
|
|
20
|
+
"type": "string",
|
|
21
|
+
"enum": ["Proposed", "Accepted", "Deprecated", "Superseded"],
|
|
22
|
+
"description": "Current status of the decision"
|
|
23
|
+
},
|
|
24
|
+
"deciders": {
|
|
25
|
+
"type": "string",
|
|
26
|
+
"minLength": 1,
|
|
27
|
+
"description": "Names of people involved in the decision"
|
|
28
|
+
},
|
|
29
|
+
"context": {
|
|
30
|
+
"type": "string",
|
|
31
|
+
"minLength": 20,
|
|
32
|
+
"description": "Context and background that led to this decision"
|
|
33
|
+
},
|
|
34
|
+
"decision": {
|
|
35
|
+
"type": "string",
|
|
36
|
+
"minLength": 20,
|
|
37
|
+
"description": "The decision being made"
|
|
38
|
+
},
|
|
39
|
+
"positiveConsequences": {
|
|
40
|
+
"type": "array",
|
|
41
|
+
"minItems": 1,
|
|
42
|
+
"items": { "type": "string" },
|
|
43
|
+
"description": "Positive outcomes of the decision"
|
|
44
|
+
},
|
|
45
|
+
"negativeConsequences": {
|
|
46
|
+
"type": "array",
|
|
47
|
+
"items": { "type": "string" },
|
|
48
|
+
"description": "Negative outcomes or trade-offs"
|
|
49
|
+
},
|
|
50
|
+
"alternatives": {
|
|
51
|
+
"type": "array",
|
|
52
|
+
"items": {
|
|
53
|
+
"type": "object",
|
|
54
|
+
"required": ["name", "description"],
|
|
55
|
+
"properties": {
|
|
56
|
+
"name": {
|
|
57
|
+
"type": "string",
|
|
58
|
+
"description": "Alternative option name"
|
|
59
|
+
},
|
|
60
|
+
"description": {
|
|
61
|
+
"type": "string",
|
|
62
|
+
"description": "Description of the alternative"
|
|
63
|
+
},
|
|
64
|
+
"pros": {
|
|
65
|
+
"type": "string",
|
|
66
|
+
"description": "Advantages of this alternative"
|
|
67
|
+
},
|
|
68
|
+
"cons": {
|
|
69
|
+
"type": "string",
|
|
70
|
+
"description": "Disadvantages of this alternative"
|
|
71
|
+
},
|
|
72
|
+
"whyNot": {
|
|
73
|
+
"type": "string",
|
|
74
|
+
"description": "Why this alternative was not chosen"
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
},
|
|
78
|
+
"description": "Alternative options considered"
|
|
79
|
+
},
|
|
80
|
+
"relatedADRs": {
|
|
81
|
+
"type": "array",
|
|
82
|
+
"items": {
|
|
83
|
+
"type": "object",
|
|
84
|
+
"required": ["number", "title"],
|
|
85
|
+
"properties": {
|
|
86
|
+
"number": { "type": "integer" },
|
|
87
|
+
"title": { "type": "string" }
|
|
88
|
+
}
|
|
89
|
+
},
|
|
90
|
+
"description": "Related ADR references"
|
|
91
|
+
},
|
|
92
|
+
"references": {
|
|
93
|
+
"type": "array",
|
|
94
|
+
"items": { "type": "string" },
|
|
95
|
+
"description": "External references and links"
|
|
96
|
+
},
|
|
97
|
+
"supersededBy": {
|
|
98
|
+
"type": "integer",
|
|
99
|
+
"description": "ADR number that supersedes this one"
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
@@ -1,205 +1,205 @@
|
|
|
1
|
-
{
|
|
2
|
-
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
-
"title": "DBDR Template Variables",
|
|
4
|
-
"description": "Schema for Database Decision Record template variables",
|
|
5
|
-
"type": "object",
|
|
6
|
-
"required": ["number", "title", "status", "dbType", "owner", "context", "decision", "migrationStrategy", "rollbackPlan"],
|
|
7
|
-
"properties": {
|
|
8
|
-
"number": {
|
|
9
|
-
"type": "integer",
|
|
10
|
-
"minimum": 1,
|
|
11
|
-
"description": "DBDR number for ordering and reference"
|
|
12
|
-
},
|
|
13
|
-
"title": {
|
|
14
|
-
"type": "string",
|
|
15
|
-
"minLength": 5,
|
|
16
|
-
"maxLength": 150,
|
|
17
|
-
"description": "Title of the database decision"
|
|
18
|
-
},
|
|
19
|
-
"status": {
|
|
20
|
-
"type": "string",
|
|
21
|
-
"enum": ["Proposed", "Approved", "Implemented", "Rolled Back"],
|
|
22
|
-
"description": "Current status of the decision"
|
|
23
|
-
},
|
|
24
|
-
"dbType": {
|
|
25
|
-
"type": "string",
|
|
26
|
-
"enum": ["PostgreSQL", "MySQL", "MongoDB", "SQLite", "Supabase", "Other"],
|
|
27
|
-
"description": "Database type"
|
|
28
|
-
},
|
|
29
|
-
"owner": {
|
|
30
|
-
"type": "string",
|
|
31
|
-
"minLength": 1,
|
|
32
|
-
"description": "Decision owner"
|
|
33
|
-
},
|
|
34
|
-
"context": {
|
|
35
|
-
"type": "string",
|
|
36
|
-
"minLength": 20,
|
|
37
|
-
"description": "Context and problem statement"
|
|
38
|
-
},
|
|
39
|
-
"currentState": {
|
|
40
|
-
"type": "string",
|
|
41
|
-
"description": "Current database state"
|
|
42
|
-
},
|
|
43
|
-
"dataVolume": {
|
|
44
|
-
"type": "object",
|
|
45
|
-
"properties": {
|
|
46
|
-
"current": { "type": "string" },
|
|
47
|
-
"projected": { "type": "string" },
|
|
48
|
-
"retention": { "type": "string" }
|
|
49
|
-
},
|
|
50
|
-
"description": "Data volume considerations"
|
|
51
|
-
},
|
|
52
|
-
"decision": {
|
|
53
|
-
"type": "string",
|
|
54
|
-
"minLength": 20,
|
|
55
|
-
"description": "The database decision being made"
|
|
56
|
-
},
|
|
57
|
-
"rationale": {
|
|
58
|
-
"type": "string",
|
|
59
|
-
"description": "Reasoning behind the decision"
|
|
60
|
-
},
|
|
61
|
-
"schemaChanges": {
|
|
62
|
-
"type": "array",
|
|
63
|
-
"items": {
|
|
64
|
-
"type": "object",
|
|
65
|
-
"required": ["table", "changeType"],
|
|
66
|
-
"properties": {
|
|
67
|
-
"table": {
|
|
68
|
-
"type": "string",
|
|
69
|
-
"description": "Table name"
|
|
70
|
-
},
|
|
71
|
-
"changeType": {
|
|
72
|
-
"type": "string",
|
|
73
|
-
"enum": ["CREATE", "ALTER", "DROP", "INDEX", "CONSTRAINT"],
|
|
74
|
-
"description": "Type of schema change"
|
|
75
|
-
},
|
|
76
|
-
"description": {
|
|
77
|
-
"type": "string",
|
|
78
|
-
"description": "Description of the change"
|
|
79
|
-
},
|
|
80
|
-
"sql": {
|
|
81
|
-
"type": "string",
|
|
82
|
-
"description": "SQL statement for the change"
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
},
|
|
86
|
-
"description": "Schema changes to be made"
|
|
87
|
-
},
|
|
88
|
-
"migrationStrategy": {
|
|
89
|
-
"type": "string",
|
|
90
|
-
"minLength": 20,
|
|
91
|
-
"description": "Strategy for migrating data"
|
|
92
|
-
},
|
|
93
|
-
"migrationPhases": {
|
|
94
|
-
"type": "array",
|
|
95
|
-
"items": {
|
|
96
|
-
"type": "object",
|
|
97
|
-
"required": ["phase"],
|
|
98
|
-
"properties": {
|
|
99
|
-
"phase": { "type": "string" },
|
|
100
|
-
"duration": { "type": "string" },
|
|
101
|
-
"description": { "type": "string" },
|
|
102
|
-
"validation": { "type": "string" }
|
|
103
|
-
}
|
|
104
|
-
},
|
|
105
|
-
"description": "Migration phases"
|
|
106
|
-
},
|
|
107
|
-
"dataMigrationScripts": {
|
|
108
|
-
"type": "string",
|
|
109
|
-
"description": "SQL scripts for data migration"
|
|
110
|
-
},
|
|
111
|
-
"performanceMetrics": {
|
|
112
|
-
"type": "array",
|
|
113
|
-
"items": {
|
|
114
|
-
"type": "object",
|
|
115
|
-
"required": ["metric"],
|
|
116
|
-
"properties": {
|
|
117
|
-
"metric": { "type": "string" },
|
|
118
|
-
"before": { "type": "string" },
|
|
119
|
-
"after": { "type": "string" },
|
|
120
|
-
"acceptable": { "type": "string" }
|
|
121
|
-
}
|
|
122
|
-
},
|
|
123
|
-
"description": "Expected performance impact"
|
|
124
|
-
},
|
|
125
|
-
"indexes": {
|
|
126
|
-
"type": "array",
|
|
127
|
-
"items": {
|
|
128
|
-
"type": "object",
|
|
129
|
-
"required": ["name", "table", "columns"],
|
|
130
|
-
"properties": {
|
|
131
|
-
"name": { "type": "string" },
|
|
132
|
-
"table": { "type": "string" },
|
|
133
|
-
"columns": { "type": "string" },
|
|
134
|
-
"reason": { "type": "string" }
|
|
135
|
-
}
|
|
136
|
-
},
|
|
137
|
-
"description": "Index strategy"
|
|
138
|
-
},
|
|
139
|
-
"rollbackPlan": {
|
|
140
|
-
"type": "string",
|
|
141
|
-
"minLength": 20,
|
|
142
|
-
"description": "Plan for rolling back changes"
|
|
143
|
-
},
|
|
144
|
-
"rollbackScripts": {
|
|
145
|
-
"type": "string",
|
|
146
|
-
"description": "SQL scripts for rollback"
|
|
147
|
-
},
|
|
148
|
-
"rollbackTriggers": {
|
|
149
|
-
"type": "array",
|
|
150
|
-
"items": {
|
|
151
|
-
"type": "object",
|
|
152
|
-
"required": ["condition", "action"],
|
|
153
|
-
"properties": {
|
|
154
|
-
"condition": { "type": "string" },
|
|
155
|
-
"action": { "type": "string" }
|
|
156
|
-
}
|
|
157
|
-
},
|
|
158
|
-
"description": "Conditions that trigger rollback"
|
|
159
|
-
},
|
|
160
|
-
"preMigrationTests": {
|
|
161
|
-
"type": "array",
|
|
162
|
-
"items": { "type": "string" },
|
|
163
|
-
"description": "Tests to run before migration"
|
|
164
|
-
},
|
|
165
|
-
"postMigrationValidation": {
|
|
166
|
-
"type": "array",
|
|
167
|
-
"items": { "type": "string" },
|
|
168
|
-
"description": "Validation steps after migration"
|
|
169
|
-
},
|
|
170
|
-
"positiveConsequences": {
|
|
171
|
-
"type": "array",
|
|
172
|
-
"items": { "type": "string" },
|
|
173
|
-
"description": "Positive outcomes"
|
|
174
|
-
},
|
|
175
|
-
"negativeConsequences": {
|
|
176
|
-
"type": "array",
|
|
177
|
-
"items": { "type": "string" },
|
|
178
|
-
"description": "Negative outcomes or trade-offs"
|
|
179
|
-
},
|
|
180
|
-
"relatedDBDRs": {
|
|
181
|
-
"type": "array",
|
|
182
|
-
"items": {
|
|
183
|
-
"type": "object",
|
|
184
|
-
"required": ["number", "title"],
|
|
185
|
-
"properties": {
|
|
186
|
-
"number": { "type": "integer" },
|
|
187
|
-
"title": { "type": "string" }
|
|
188
|
-
}
|
|
189
|
-
},
|
|
190
|
-
"description": "Related DBDR references"
|
|
191
|
-
},
|
|
192
|
-
"relatedADRs": {
|
|
193
|
-
"type": "array",
|
|
194
|
-
"items": {
|
|
195
|
-
"type": "object",
|
|
196
|
-
"required": ["number", "title"],
|
|
197
|
-
"properties": {
|
|
198
|
-
"number": { "type": "integer" },
|
|
199
|
-
"title": { "type": "string" }
|
|
200
|
-
}
|
|
201
|
-
},
|
|
202
|
-
"description": "Related ADR references"
|
|
203
|
-
}
|
|
204
|
-
}
|
|
205
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"title": "DBDR Template Variables",
|
|
4
|
+
"description": "Schema for Database Decision Record template variables",
|
|
5
|
+
"type": "object",
|
|
6
|
+
"required": ["number", "title", "status", "dbType", "owner", "context", "decision", "migrationStrategy", "rollbackPlan"],
|
|
7
|
+
"properties": {
|
|
8
|
+
"number": {
|
|
9
|
+
"type": "integer",
|
|
10
|
+
"minimum": 1,
|
|
11
|
+
"description": "DBDR number for ordering and reference"
|
|
12
|
+
},
|
|
13
|
+
"title": {
|
|
14
|
+
"type": "string",
|
|
15
|
+
"minLength": 5,
|
|
16
|
+
"maxLength": 150,
|
|
17
|
+
"description": "Title of the database decision"
|
|
18
|
+
},
|
|
19
|
+
"status": {
|
|
20
|
+
"type": "string",
|
|
21
|
+
"enum": ["Proposed", "Approved", "Implemented", "Rolled Back"],
|
|
22
|
+
"description": "Current status of the decision"
|
|
23
|
+
},
|
|
24
|
+
"dbType": {
|
|
25
|
+
"type": "string",
|
|
26
|
+
"enum": ["PostgreSQL", "MySQL", "MongoDB", "SQLite", "Supabase", "Other"],
|
|
27
|
+
"description": "Database type"
|
|
28
|
+
},
|
|
29
|
+
"owner": {
|
|
30
|
+
"type": "string",
|
|
31
|
+
"minLength": 1,
|
|
32
|
+
"description": "Decision owner"
|
|
33
|
+
},
|
|
34
|
+
"context": {
|
|
35
|
+
"type": "string",
|
|
36
|
+
"minLength": 20,
|
|
37
|
+
"description": "Context and problem statement"
|
|
38
|
+
},
|
|
39
|
+
"currentState": {
|
|
40
|
+
"type": "string",
|
|
41
|
+
"description": "Current database state"
|
|
42
|
+
},
|
|
43
|
+
"dataVolume": {
|
|
44
|
+
"type": "object",
|
|
45
|
+
"properties": {
|
|
46
|
+
"current": { "type": "string" },
|
|
47
|
+
"projected": { "type": "string" },
|
|
48
|
+
"retention": { "type": "string" }
|
|
49
|
+
},
|
|
50
|
+
"description": "Data volume considerations"
|
|
51
|
+
},
|
|
52
|
+
"decision": {
|
|
53
|
+
"type": "string",
|
|
54
|
+
"minLength": 20,
|
|
55
|
+
"description": "The database decision being made"
|
|
56
|
+
},
|
|
57
|
+
"rationale": {
|
|
58
|
+
"type": "string",
|
|
59
|
+
"description": "Reasoning behind the decision"
|
|
60
|
+
},
|
|
61
|
+
"schemaChanges": {
|
|
62
|
+
"type": "array",
|
|
63
|
+
"items": {
|
|
64
|
+
"type": "object",
|
|
65
|
+
"required": ["table", "changeType"],
|
|
66
|
+
"properties": {
|
|
67
|
+
"table": {
|
|
68
|
+
"type": "string",
|
|
69
|
+
"description": "Table name"
|
|
70
|
+
},
|
|
71
|
+
"changeType": {
|
|
72
|
+
"type": "string",
|
|
73
|
+
"enum": ["CREATE", "ALTER", "DROP", "INDEX", "CONSTRAINT"],
|
|
74
|
+
"description": "Type of schema change"
|
|
75
|
+
},
|
|
76
|
+
"description": {
|
|
77
|
+
"type": "string",
|
|
78
|
+
"description": "Description of the change"
|
|
79
|
+
},
|
|
80
|
+
"sql": {
|
|
81
|
+
"type": "string",
|
|
82
|
+
"description": "SQL statement for the change"
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
},
|
|
86
|
+
"description": "Schema changes to be made"
|
|
87
|
+
},
|
|
88
|
+
"migrationStrategy": {
|
|
89
|
+
"type": "string",
|
|
90
|
+
"minLength": 20,
|
|
91
|
+
"description": "Strategy for migrating data"
|
|
92
|
+
},
|
|
93
|
+
"migrationPhases": {
|
|
94
|
+
"type": "array",
|
|
95
|
+
"items": {
|
|
96
|
+
"type": "object",
|
|
97
|
+
"required": ["phase"],
|
|
98
|
+
"properties": {
|
|
99
|
+
"phase": { "type": "string" },
|
|
100
|
+
"duration": { "type": "string" },
|
|
101
|
+
"description": { "type": "string" },
|
|
102
|
+
"validation": { "type": "string" }
|
|
103
|
+
}
|
|
104
|
+
},
|
|
105
|
+
"description": "Migration phases"
|
|
106
|
+
},
|
|
107
|
+
"dataMigrationScripts": {
|
|
108
|
+
"type": "string",
|
|
109
|
+
"description": "SQL scripts for data migration"
|
|
110
|
+
},
|
|
111
|
+
"performanceMetrics": {
|
|
112
|
+
"type": "array",
|
|
113
|
+
"items": {
|
|
114
|
+
"type": "object",
|
|
115
|
+
"required": ["metric"],
|
|
116
|
+
"properties": {
|
|
117
|
+
"metric": { "type": "string" },
|
|
118
|
+
"before": { "type": "string" },
|
|
119
|
+
"after": { "type": "string" },
|
|
120
|
+
"acceptable": { "type": "string" }
|
|
121
|
+
}
|
|
122
|
+
},
|
|
123
|
+
"description": "Expected performance impact"
|
|
124
|
+
},
|
|
125
|
+
"indexes": {
|
|
126
|
+
"type": "array",
|
|
127
|
+
"items": {
|
|
128
|
+
"type": "object",
|
|
129
|
+
"required": ["name", "table", "columns"],
|
|
130
|
+
"properties": {
|
|
131
|
+
"name": { "type": "string" },
|
|
132
|
+
"table": { "type": "string" },
|
|
133
|
+
"columns": { "type": "string" },
|
|
134
|
+
"reason": { "type": "string" }
|
|
135
|
+
}
|
|
136
|
+
},
|
|
137
|
+
"description": "Index strategy"
|
|
138
|
+
},
|
|
139
|
+
"rollbackPlan": {
|
|
140
|
+
"type": "string",
|
|
141
|
+
"minLength": 20,
|
|
142
|
+
"description": "Plan for rolling back changes"
|
|
143
|
+
},
|
|
144
|
+
"rollbackScripts": {
|
|
145
|
+
"type": "string",
|
|
146
|
+
"description": "SQL scripts for rollback"
|
|
147
|
+
},
|
|
148
|
+
"rollbackTriggers": {
|
|
149
|
+
"type": "array",
|
|
150
|
+
"items": {
|
|
151
|
+
"type": "object",
|
|
152
|
+
"required": ["condition", "action"],
|
|
153
|
+
"properties": {
|
|
154
|
+
"condition": { "type": "string" },
|
|
155
|
+
"action": { "type": "string" }
|
|
156
|
+
}
|
|
157
|
+
},
|
|
158
|
+
"description": "Conditions that trigger rollback"
|
|
159
|
+
},
|
|
160
|
+
"preMigrationTests": {
|
|
161
|
+
"type": "array",
|
|
162
|
+
"items": { "type": "string" },
|
|
163
|
+
"description": "Tests to run before migration"
|
|
164
|
+
},
|
|
165
|
+
"postMigrationValidation": {
|
|
166
|
+
"type": "array",
|
|
167
|
+
"items": { "type": "string" },
|
|
168
|
+
"description": "Validation steps after migration"
|
|
169
|
+
},
|
|
170
|
+
"positiveConsequences": {
|
|
171
|
+
"type": "array",
|
|
172
|
+
"items": { "type": "string" },
|
|
173
|
+
"description": "Positive outcomes"
|
|
174
|
+
},
|
|
175
|
+
"negativeConsequences": {
|
|
176
|
+
"type": "array",
|
|
177
|
+
"items": { "type": "string" },
|
|
178
|
+
"description": "Negative outcomes or trade-offs"
|
|
179
|
+
},
|
|
180
|
+
"relatedDBDRs": {
|
|
181
|
+
"type": "array",
|
|
182
|
+
"items": {
|
|
183
|
+
"type": "object",
|
|
184
|
+
"required": ["number", "title"],
|
|
185
|
+
"properties": {
|
|
186
|
+
"number": { "type": "integer" },
|
|
187
|
+
"title": { "type": "string" }
|
|
188
|
+
}
|
|
189
|
+
},
|
|
190
|
+
"description": "Related DBDR references"
|
|
191
|
+
},
|
|
192
|
+
"relatedADRs": {
|
|
193
|
+
"type": "array",
|
|
194
|
+
"items": {
|
|
195
|
+
"type": "object",
|
|
196
|
+
"required": ["number", "title"],
|
|
197
|
+
"properties": {
|
|
198
|
+
"number": { "type": "integer" },
|
|
199
|
+
"title": { "type": "string" }
|
|
200
|
+
}
|
|
201
|
+
},
|
|
202
|
+
"description": "Related ADR references"
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|