aiox-core 5.0.0 → 5.0.2

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.
Files changed (91) hide show
  1. package/.aiox-core/data/entity-registry.yaml +5297 -1814
  2. package/.aiox-core/data/registry-update-log.jsonl +2 -0
  3. package/.aiox-core/development/templates/service-template/README.md.hbs +158 -158
  4. package/.aiox-core/development/templates/service-template/__tests__/index.test.ts.hbs +237 -237
  5. package/.aiox-core/development/templates/service-template/client.ts.hbs +403 -403
  6. package/.aiox-core/development/templates/service-template/errors.ts.hbs +182 -182
  7. package/.aiox-core/development/templates/service-template/index.ts.hbs +120 -120
  8. package/.aiox-core/development/templates/service-template/package.json.hbs +87 -87
  9. package/.aiox-core/development/templates/service-template/types.ts.hbs +145 -145
  10. package/.aiox-core/development/templates/squad-template/LICENSE +21 -21
  11. package/.aiox-core/infrastructure/scripts/tool-resolver.js +4 -4
  12. package/.aiox-core/infrastructure/templates/aiox-sync.yaml.template +182 -182
  13. package/.aiox-core/infrastructure/templates/coderabbit.yaml.template +279 -279
  14. package/.aiox-core/infrastructure/templates/github-workflows/ci.yml.template +169 -169
  15. package/.aiox-core/infrastructure/templates/github-workflows/pr-automation.yml.template +330 -330
  16. package/.aiox-core/infrastructure/templates/github-workflows/release.yml.template +196 -196
  17. package/.aiox-core/infrastructure/templates/gitignore/gitignore-aiox-base.tmpl +63 -63
  18. package/.aiox-core/infrastructure/templates/gitignore/gitignore-brownfield-merge.tmpl +18 -18
  19. package/.aiox-core/infrastructure/templates/gitignore/gitignore-node.tmpl +85 -85
  20. package/.aiox-core/infrastructure/templates/gitignore/gitignore-python.tmpl +145 -145
  21. package/.aiox-core/install-manifest.yaml +58 -58
  22. package/.aiox-core/local-config.yaml.template +71 -71
  23. package/.aiox-core/monitor/hooks/lib/__init__.py +1 -1
  24. package/.aiox-core/monitor/hooks/lib/enrich.py +58 -58
  25. package/.aiox-core/monitor/hooks/lib/send_event.py +47 -47
  26. package/.aiox-core/monitor/hooks/notification.py +29 -29
  27. package/.aiox-core/monitor/hooks/post_tool_use.py +45 -45
  28. package/.aiox-core/monitor/hooks/pre_compact.py +29 -29
  29. package/.aiox-core/monitor/hooks/pre_tool_use.py +40 -40
  30. package/.aiox-core/monitor/hooks/stop.py +29 -29
  31. package/.aiox-core/monitor/hooks/subagent_stop.py +29 -29
  32. package/.aiox-core/monitor/hooks/user_prompt_submit.py +38 -38
  33. package/.aiox-core/product/templates/adr.hbs +125 -125
  34. package/.aiox-core/product/templates/dbdr.hbs +241 -241
  35. package/.aiox-core/product/templates/engine/elicitation.js +2 -3
  36. package/.aiox-core/product/templates/epic.hbs +212 -212
  37. package/.aiox-core/product/templates/pmdr.hbs +186 -186
  38. package/.aiox-core/product/templates/prd-v2.0.hbs +216 -216
  39. package/.aiox-core/product/templates/prd.hbs +201 -201
  40. package/.aiox-core/product/templates/story.hbs +263 -263
  41. package/.aiox-core/product/templates/task.hbs +170 -170
  42. package/.aiox-core/product/templates/tmpl-comment-on-examples.sql +158 -158
  43. package/.aiox-core/product/templates/tmpl-migration-script.sql +91 -91
  44. package/.aiox-core/product/templates/tmpl-rls-granular-policies.sql +104 -104
  45. package/.aiox-core/product/templates/tmpl-rls-kiss-policy.sql +10 -10
  46. package/.aiox-core/product/templates/tmpl-rls-roles.sql +135 -135
  47. package/.aiox-core/product/templates/tmpl-rls-simple.sql +77 -77
  48. package/.aiox-core/product/templates/tmpl-rls-tenant.sql +152 -152
  49. package/.aiox-core/product/templates/tmpl-rollback-script.sql +77 -77
  50. package/.aiox-core/product/templates/tmpl-seed-data.sql +140 -140
  51. package/.aiox-core/product/templates/tmpl-smoke-test.sql +16 -16
  52. package/.aiox-core/product/templates/tmpl-staging-copy-merge.sql +139 -139
  53. package/.aiox-core/product/templates/tmpl-stored-proc.sql +140 -140
  54. package/.aiox-core/product/templates/tmpl-trigger.sql +152 -152
  55. package/.aiox-core/product/templates/tmpl-view-materialized.sql +133 -133
  56. package/.aiox-core/product/templates/tmpl-view.sql +177 -177
  57. package/.aiox-core/scripts/pm.sh +0 -0
  58. package/.claude/hooks/code-intel-pretool.cjs +107 -0
  59. package/.claude/hooks/enforce-architecture-first.py +196 -196
  60. package/.claude/hooks/mind-clone-governance.py +192 -192
  61. package/.claude/hooks/read-protection.py +151 -151
  62. package/.claude/hooks/slug-validation.py +176 -176
  63. package/.claude/hooks/sql-governance.py +182 -182
  64. package/.claude/hooks/write-path-validation.py +194 -194
  65. package/LICENSE +33 -33
  66. package/bin/aiox-graph.js +0 -0
  67. package/bin/aiox-minimal.js +0 -0
  68. package/bin/aiox.js +0 -0
  69. package/docs/guides/aios-workflows/README.md +247 -0
  70. package/docs/guides/aios-workflows/bob-orchestrator-workflow.md +1536 -0
  71. package/package.json +1 -1
  72. package/packages/aiox-install/bin/aiox-install.js +0 -0
  73. package/packages/aiox-install/bin/edmcp.js +0 -0
  74. package/packages/aiox-pro-cli/bin/aiox-pro.js +0 -0
  75. package/packages/installer/src/wizard/pro-setup.js +210 -123
  76. package/pro/README.md +66 -0
  77. package/pro/license/degradation.js +220 -0
  78. package/pro/license/errors.js +450 -0
  79. package/pro/license/feature-gate.js +354 -0
  80. package/pro/license/index.js +181 -0
  81. package/pro/license/license-api.js +679 -0
  82. package/pro/license/license-cache.js +523 -0
  83. package/pro/license/license-crypto.js +303 -0
  84. package/scripts/check-markdown-links.py +352 -352
  85. package/scripts/dashboard-parallel-dev.sh +0 -0
  86. package/scripts/dashboard-parallel-phase3.sh +0 -0
  87. package/scripts/dashboard-parallel-phase4.sh +0 -0
  88. package/scripts/glue/README.md +355 -0
  89. package/scripts/glue/compose-agent-prompt.cjs +362 -0
  90. package/scripts/install-monitor-hooks.sh +0 -0
  91. package/.aiox-core/lib/build.json +0 -1
@@ -1,330 +1,330 @@
1
- # =============================================================================
2
- # AIOX PR Automation Template
3
- # =============================================================================
4
- # Template for user projects created with AIOX-FULLSTACK
5
- # Generated by: *setup-github task (Story 5.10)
6
- #
7
- # Features:
8
- # - Required status checks (blocking)
9
- # - Coverage report posted as PR comment
10
- # - Quality gate summary comment
11
- # - CodeRabbit integration status
12
- # =============================================================================
13
-
14
- name: PR Automation
15
-
16
- on:
17
- pull_request:
18
- branches:
19
- - main
20
- - develop
21
- types: [opened, synchronize, reopened]
22
-
23
- permissions:
24
- contents: read
25
- pull-requests: write
26
- checks: write
27
-
28
- env:
29
- NODE_VERSION: '{{NODE_VERSION}}'
30
-
31
- jobs:
32
- # ===========================================================================
33
- # REQUIRED STATUS CHECKS (Blocking)
34
- # ===========================================================================
35
-
36
- lint:
37
- name: Lint
38
- runs-on: ubuntu-latest
39
- timeout-minutes: 5
40
- steps:
41
- - name: Checkout code
42
- uses: actions/checkout@v4
43
-
44
- - name: Setup Node.js
45
- uses: actions/setup-node@v4
46
- with:
47
- node-version: ${{ env.NODE_VERSION }}
48
- cache: 'npm'
49
-
50
- - name: Install dependencies
51
- run: npm ci
52
-
53
- - name: Run ESLint
54
- run: {{LINT_COMMAND}}
55
-
56
- typecheck:
57
- name: TypeCheck
58
- runs-on: ubuntu-latest
59
- timeout-minutes: 5
60
- steps:
61
- - name: Checkout code
62
- uses: actions/checkout@v4
63
-
64
- - name: Setup Node.js
65
- uses: actions/setup-node@v4
66
- with:
67
- node-version: ${{ env.NODE_VERSION }}
68
- cache: 'npm'
69
-
70
- - name: Install dependencies
71
- run: npm ci
72
-
73
- - name: Run TypeScript type checking
74
- run: {{TYPECHECK_COMMAND}}
75
-
76
- test:
77
- name: Test
78
- runs-on: ubuntu-latest
79
- timeout-minutes: 10
80
- outputs:
81
- coverage-summary: ${{ steps.coverage.outputs.summary }}
82
- steps:
83
- - name: Checkout code
84
- uses: actions/checkout@v4
85
-
86
- - name: Setup Node.js
87
- uses: actions/setup-node@v4
88
- with:
89
- node-version: ${{ env.NODE_VERSION }}
90
- cache: 'npm'
91
-
92
- - name: Install dependencies
93
- run: npm ci
94
-
95
- - name: Run tests with coverage
96
- id: test-run
97
- run: {{TEST_COMMAND}}
98
-
99
- - name: Upload coverage to Codecov
100
- uses: codecov/codecov-action@v4
101
- with:
102
- files: ./coverage/lcov.info
103
- flags: unittests
104
- fail_ci_if_error: false
105
-
106
- - name: Extract coverage summary
107
- id: coverage
108
- run: |
109
- if [ -f coverage/coverage-summary.json ]; then
110
- LINES=$(jq '.total.lines.pct' coverage/coverage-summary.json)
111
- STATEMENTS=$(jq '.total.statements.pct' coverage/coverage-summary.json)
112
- BRANCHES=$(jq '.total.branches.pct' coverage/coverage-summary.json)
113
- FUNCTIONS=$(jq '.total.functions.pct' coverage/coverage-summary.json)
114
- echo "summary=Lines: ${LINES}% | Statements: ${STATEMENTS}% | Branches: ${BRANCHES}% | Functions: ${FUNCTIONS}%" >> $GITHUB_OUTPUT
115
- else
116
- echo "summary=Coverage report not available" >> $GITHUB_OUTPUT
117
- fi
118
-
119
- - name: Upload coverage artifact
120
- uses: actions/upload-artifact@v4
121
- with:
122
- name: coverage-report
123
- path: coverage/
124
- retention-days: 7
125
-
126
- # ===========================================================================
127
- # COVERAGE COMMENT
128
- # ===========================================================================
129
-
130
- coverage-comment:
131
- name: Coverage Comment
132
- runs-on: ubuntu-latest
133
- needs: [test]
134
- if: always() && needs.test.result != 'cancelled'
135
- steps:
136
- - name: Post coverage comment
137
- uses: actions/github-script@v7
138
- with:
139
- script: |
140
- const coverageSummary = '${{ needs.test.outputs.coverage-summary }}' || 'Coverage data not available';
141
-
142
- const body = `## 📊 Coverage Report
143
-
144
- ${coverageSummary}
145
-
146
- <details>
147
- <summary>Coverage Details</summary>
148
-
149
- | Metric | Coverage |
150
- |--------|----------|
151
- | Lines | See Codecov |
152
- | Branches | See Codecov |
153
- | Functions | See Codecov |
154
- | Statements | See Codecov |
155
-
156
- </details>
157
-
158
- > 📈 Full coverage report available in [Codecov](https://codecov.io/gh/${{ github.repository }}/pull/${{ github.event.pull_request.number }})
159
- `;
160
-
161
- // Find existing comment
162
- const { data: comments } = await github.rest.issues.listComments({
163
- owner: context.repo.owner,
164
- repo: context.repo.repo,
165
- issue_number: context.issue.number,
166
- });
167
-
168
- const botComment = comments.find(comment =>
169
- comment.user.type === 'Bot' &&
170
- comment.body.includes('📊 Coverage Report')
171
- );
172
-
173
- if (botComment) {
174
- await github.rest.issues.updateComment({
175
- owner: context.repo.owner,
176
- repo: context.repo.repo,
177
- comment_id: botComment.id,
178
- body: body
179
- });
180
- } else {
181
- await github.rest.issues.createComment({
182
- owner: context.repo.owner,
183
- repo: context.repo.repo,
184
- issue_number: context.issue.number,
185
- body: body
186
- });
187
- }
188
-
189
- # ===========================================================================
190
- # QUALITY SUMMARY
191
- # ===========================================================================
192
-
193
- quality-summary:
194
- name: Quality Summary
195
- runs-on: ubuntu-latest
196
- needs: [lint, typecheck, test]
197
- if: always()
198
- steps:
199
- - name: Generate quality summary
200
- uses: actions/github-script@v7
201
- with:
202
- script: |
203
- const lintResult = '${{ needs.lint.result }}';
204
- const typecheckResult = '${{ needs.typecheck.result }}';
205
- const testResult = '${{ needs.test.result }}';
206
-
207
- const getEmoji = (result) => {
208
- switch(result) {
209
- case 'success': return '✅';
210
- case 'failure': return '❌';
211
- case 'cancelled': return 'âšī¸';
212
- case 'skipped': return 'â­ī¸';
213
- default: return 'âŗ';
214
- }
215
- };
216
-
217
- const allPassed = lintResult === 'success' &&
218
- typecheckResult === 'success' &&
219
- testResult === 'success';
220
-
221
- const overallStatus = allPassed ? '✅ All checks passed' : '❌ Some checks failed';
222
-
223
- const body = `## 📋 Quality Gate Summary
224
-
225
- **Overall Status:** ${overallStatus}
226
-
227
- | Check | Status | Result |
228
- |-------|--------|--------|
229
- | Lint | ${getEmoji(lintResult)} | ${lintResult} |
230
- | TypeCheck | ${getEmoji(typecheckResult)} | ${typecheckResult} |
231
- | Tests | ${getEmoji(testResult)} | ${testResult} |
232
-
233
- ### Required for Merge
234
- - ${getEmoji(lintResult)} ESLint validation
235
- - ${getEmoji(typecheckResult)} TypeScript type checking
236
- - ${getEmoji(testResult)} Test suite passing
237
-
238
- ### CodeRabbit Review
239
- 🐰 CodeRabbit will provide automated code review comments separately.
240
- - **CRITICAL** issues must be resolved before merge
241
- - **HIGH** issues should be addressed or documented
242
-
243
- ---
244
- *Generated by AIOX PR Automation*
245
- `;
246
-
247
- // Find existing comment
248
- const { data: comments } = await github.rest.issues.listComments({
249
- owner: context.repo.owner,
250
- repo: context.repo.repo,
251
- issue_number: context.issue.number,
252
- });
253
-
254
- const botComment = comments.find(comment =>
255
- comment.user.type === 'Bot' &&
256
- comment.body.includes('📋 Quality Gate Summary')
257
- );
258
-
259
- if (botComment) {
260
- await github.rest.issues.updateComment({
261
- owner: context.repo.owner,
262
- repo: context.repo.repo,
263
- comment_id: botComment.id,
264
- body: body
265
- });
266
- } else {
267
- await github.rest.issues.createComment({
268
- owner: context.repo.owner,
269
- repo: context.repo.repo,
270
- issue_number: context.issue.number,
271
- body: body
272
- });
273
- }
274
-
275
- - name: Set final status
276
- if: always()
277
- run: |
278
- LINT="${{ needs.lint.result }}"
279
- TYPE="${{ needs.typecheck.result }}"
280
- TEST="${{ needs.test.result }}"
281
-
282
- echo "=== PR Quality Gate Summary ==="
283
- echo "Lint: $LINT"
284
- echo "TypeCheck: $TYPE"
285
- echo "Tests: $TEST"
286
-
287
- if [ "$LINT" != "success" ] || [ "$TYPE" != "success" ] || [ "$TEST" != "success" ]; then
288
- echo "❌ Quality gate failed - merge will be blocked"
289
- exit 1
290
- fi
291
-
292
- echo "✅ All quality gates passed - ready for review"
293
-
294
- # ===========================================================================
295
- # CODERABBIT STATUS CHECK
296
- # ===========================================================================
297
-
298
- coderabbit-check:
299
- name: CodeRabbit Status
300
- runs-on: ubuntu-latest
301
- needs: [lint, typecheck, test]
302
- if: always()
303
- steps:
304
- - name: Check CodeRabbit configuration
305
- run: |
306
- echo "🐰 CodeRabbit Integration Status"
307
- echo "================================"
308
- echo ""
309
- echo "CodeRabbit is configured via .coderabbit.yaml"
310
- echo "Review will be posted as PR comments automatically"
311
- echo ""
312
- echo "Severity Handling:"
313
- echo " - CRITICAL: Must fix before merge"
314
- echo " - HIGH: Should address or document"
315
- echo " - MEDIUM/LOW: Optional"
316
-
317
- - name: Checkout for config check
318
- uses: actions/checkout@v4
319
- with:
320
- sparse-checkout: .coderabbit.yaml
321
- sparse-checkout-cone-mode: false
322
-
323
- - name: Validate config
324
- run: |
325
- if [ -f ".coderabbit.yaml" ]; then
326
- echo "✅ CodeRabbit configuration found"
327
- else
328
- echo "âš ī¸ CodeRabbit configuration not found"
329
- echo "Create .coderabbit.yaml to customize review behavior"
330
- fi
1
+ # =============================================================================
2
+ # AIOX PR Automation Template
3
+ # =============================================================================
4
+ # Template for user projects created with AIOX-FULLSTACK
5
+ # Generated by: *setup-github task (Story 5.10)
6
+ #
7
+ # Features:
8
+ # - Required status checks (blocking)
9
+ # - Coverage report posted as PR comment
10
+ # - Quality gate summary comment
11
+ # - CodeRabbit integration status
12
+ # =============================================================================
13
+
14
+ name: PR Automation
15
+
16
+ on:
17
+ pull_request:
18
+ branches:
19
+ - main
20
+ - develop
21
+ types: [opened, synchronize, reopened]
22
+
23
+ permissions:
24
+ contents: read
25
+ pull-requests: write
26
+ checks: write
27
+
28
+ env:
29
+ NODE_VERSION: '{{NODE_VERSION}}'
30
+
31
+ jobs:
32
+ # ===========================================================================
33
+ # REQUIRED STATUS CHECKS (Blocking)
34
+ # ===========================================================================
35
+
36
+ lint:
37
+ name: Lint
38
+ runs-on: ubuntu-latest
39
+ timeout-minutes: 5
40
+ steps:
41
+ - name: Checkout code
42
+ uses: actions/checkout@v4
43
+
44
+ - name: Setup Node.js
45
+ uses: actions/setup-node@v4
46
+ with:
47
+ node-version: ${{ env.NODE_VERSION }}
48
+ cache: 'npm'
49
+
50
+ - name: Install dependencies
51
+ run: npm ci
52
+
53
+ - name: Run ESLint
54
+ run: {{LINT_COMMAND}}
55
+
56
+ typecheck:
57
+ name: TypeCheck
58
+ runs-on: ubuntu-latest
59
+ timeout-minutes: 5
60
+ steps:
61
+ - name: Checkout code
62
+ uses: actions/checkout@v4
63
+
64
+ - name: Setup Node.js
65
+ uses: actions/setup-node@v4
66
+ with:
67
+ node-version: ${{ env.NODE_VERSION }}
68
+ cache: 'npm'
69
+
70
+ - name: Install dependencies
71
+ run: npm ci
72
+
73
+ - name: Run TypeScript type checking
74
+ run: {{TYPECHECK_COMMAND}}
75
+
76
+ test:
77
+ name: Test
78
+ runs-on: ubuntu-latest
79
+ timeout-minutes: 10
80
+ outputs:
81
+ coverage-summary: ${{ steps.coverage.outputs.summary }}
82
+ steps:
83
+ - name: Checkout code
84
+ uses: actions/checkout@v4
85
+
86
+ - name: Setup Node.js
87
+ uses: actions/setup-node@v4
88
+ with:
89
+ node-version: ${{ env.NODE_VERSION }}
90
+ cache: 'npm'
91
+
92
+ - name: Install dependencies
93
+ run: npm ci
94
+
95
+ - name: Run tests with coverage
96
+ id: test-run
97
+ run: {{TEST_COMMAND}}
98
+
99
+ - name: Upload coverage to Codecov
100
+ uses: codecov/codecov-action@v4
101
+ with:
102
+ files: ./coverage/lcov.info
103
+ flags: unittests
104
+ fail_ci_if_error: false
105
+
106
+ - name: Extract coverage summary
107
+ id: coverage
108
+ run: |
109
+ if [ -f coverage/coverage-summary.json ]; then
110
+ LINES=$(jq '.total.lines.pct' coverage/coverage-summary.json)
111
+ STATEMENTS=$(jq '.total.statements.pct' coverage/coverage-summary.json)
112
+ BRANCHES=$(jq '.total.branches.pct' coverage/coverage-summary.json)
113
+ FUNCTIONS=$(jq '.total.functions.pct' coverage/coverage-summary.json)
114
+ echo "summary=Lines: ${LINES}% | Statements: ${STATEMENTS}% | Branches: ${BRANCHES}% | Functions: ${FUNCTIONS}%" >> $GITHUB_OUTPUT
115
+ else
116
+ echo "summary=Coverage report not available" >> $GITHUB_OUTPUT
117
+ fi
118
+
119
+ - name: Upload coverage artifact
120
+ uses: actions/upload-artifact@v4
121
+ with:
122
+ name: coverage-report
123
+ path: coverage/
124
+ retention-days: 7
125
+
126
+ # ===========================================================================
127
+ # COVERAGE COMMENT
128
+ # ===========================================================================
129
+
130
+ coverage-comment:
131
+ name: Coverage Comment
132
+ runs-on: ubuntu-latest
133
+ needs: [test]
134
+ if: always() && needs.test.result != 'cancelled'
135
+ steps:
136
+ - name: Post coverage comment
137
+ uses: actions/github-script@v7
138
+ with:
139
+ script: |
140
+ const coverageSummary = '${{ needs.test.outputs.coverage-summary }}' || 'Coverage data not available';
141
+
142
+ const body = `## 📊 Coverage Report
143
+
144
+ ${coverageSummary}
145
+
146
+ <details>
147
+ <summary>Coverage Details</summary>
148
+
149
+ | Metric | Coverage |
150
+ |--------|----------|
151
+ | Lines | See Codecov |
152
+ | Branches | See Codecov |
153
+ | Functions | See Codecov |
154
+ | Statements | See Codecov |
155
+
156
+ </details>
157
+
158
+ > 📈 Full coverage report available in [Codecov](https://codecov.io/gh/${{ github.repository }}/pull/${{ github.event.pull_request.number }})
159
+ `;
160
+
161
+ // Find existing comment
162
+ const { data: comments } = await github.rest.issues.listComments({
163
+ owner: context.repo.owner,
164
+ repo: context.repo.repo,
165
+ issue_number: context.issue.number,
166
+ });
167
+
168
+ const botComment = comments.find(comment =>
169
+ comment.user.type === 'Bot' &&
170
+ comment.body.includes('📊 Coverage Report')
171
+ );
172
+
173
+ if (botComment) {
174
+ await github.rest.issues.updateComment({
175
+ owner: context.repo.owner,
176
+ repo: context.repo.repo,
177
+ comment_id: botComment.id,
178
+ body: body
179
+ });
180
+ } else {
181
+ await github.rest.issues.createComment({
182
+ owner: context.repo.owner,
183
+ repo: context.repo.repo,
184
+ issue_number: context.issue.number,
185
+ body: body
186
+ });
187
+ }
188
+
189
+ # ===========================================================================
190
+ # QUALITY SUMMARY
191
+ # ===========================================================================
192
+
193
+ quality-summary:
194
+ name: Quality Summary
195
+ runs-on: ubuntu-latest
196
+ needs: [lint, typecheck, test]
197
+ if: always()
198
+ steps:
199
+ - name: Generate quality summary
200
+ uses: actions/github-script@v7
201
+ with:
202
+ script: |
203
+ const lintResult = '${{ needs.lint.result }}';
204
+ const typecheckResult = '${{ needs.typecheck.result }}';
205
+ const testResult = '${{ needs.test.result }}';
206
+
207
+ const getEmoji = (result) => {
208
+ switch(result) {
209
+ case 'success': return '✅';
210
+ case 'failure': return '❌';
211
+ case 'cancelled': return 'âšī¸';
212
+ case 'skipped': return 'â­ī¸';
213
+ default: return 'âŗ';
214
+ }
215
+ };
216
+
217
+ const allPassed = lintResult === 'success' &&
218
+ typecheckResult === 'success' &&
219
+ testResult === 'success';
220
+
221
+ const overallStatus = allPassed ? '✅ All checks passed' : '❌ Some checks failed';
222
+
223
+ const body = `## 📋 Quality Gate Summary
224
+
225
+ **Overall Status:** ${overallStatus}
226
+
227
+ | Check | Status | Result |
228
+ |-------|--------|--------|
229
+ | Lint | ${getEmoji(lintResult)} | ${lintResult} |
230
+ | TypeCheck | ${getEmoji(typecheckResult)} | ${typecheckResult} |
231
+ | Tests | ${getEmoji(testResult)} | ${testResult} |
232
+
233
+ ### Required for Merge
234
+ - ${getEmoji(lintResult)} ESLint validation
235
+ - ${getEmoji(typecheckResult)} TypeScript type checking
236
+ - ${getEmoji(testResult)} Test suite passing
237
+
238
+ ### CodeRabbit Review
239
+ 🐰 CodeRabbit will provide automated code review comments separately.
240
+ - **CRITICAL** issues must be resolved before merge
241
+ - **HIGH** issues should be addressed or documented
242
+
243
+ ---
244
+ *Generated by AIOX PR Automation*
245
+ `;
246
+
247
+ // Find existing comment
248
+ const { data: comments } = await github.rest.issues.listComments({
249
+ owner: context.repo.owner,
250
+ repo: context.repo.repo,
251
+ issue_number: context.issue.number,
252
+ });
253
+
254
+ const botComment = comments.find(comment =>
255
+ comment.user.type === 'Bot' &&
256
+ comment.body.includes('📋 Quality Gate Summary')
257
+ );
258
+
259
+ if (botComment) {
260
+ await github.rest.issues.updateComment({
261
+ owner: context.repo.owner,
262
+ repo: context.repo.repo,
263
+ comment_id: botComment.id,
264
+ body: body
265
+ });
266
+ } else {
267
+ await github.rest.issues.createComment({
268
+ owner: context.repo.owner,
269
+ repo: context.repo.repo,
270
+ issue_number: context.issue.number,
271
+ body: body
272
+ });
273
+ }
274
+
275
+ - name: Set final status
276
+ if: always()
277
+ run: |
278
+ LINT="${{ needs.lint.result }}"
279
+ TYPE="${{ needs.typecheck.result }}"
280
+ TEST="${{ needs.test.result }}"
281
+
282
+ echo "=== PR Quality Gate Summary ==="
283
+ echo "Lint: $LINT"
284
+ echo "TypeCheck: $TYPE"
285
+ echo "Tests: $TEST"
286
+
287
+ if [ "$LINT" != "success" ] || [ "$TYPE" != "success" ] || [ "$TEST" != "success" ]; then
288
+ echo "❌ Quality gate failed - merge will be blocked"
289
+ exit 1
290
+ fi
291
+
292
+ echo "✅ All quality gates passed - ready for review"
293
+
294
+ # ===========================================================================
295
+ # CODERABBIT STATUS CHECK
296
+ # ===========================================================================
297
+
298
+ coderabbit-check:
299
+ name: CodeRabbit Status
300
+ runs-on: ubuntu-latest
301
+ needs: [lint, typecheck, test]
302
+ if: always()
303
+ steps:
304
+ - name: Check CodeRabbit configuration
305
+ run: |
306
+ echo "🐰 CodeRabbit Integration Status"
307
+ echo "================================"
308
+ echo ""
309
+ echo "CodeRabbit is configured via .coderabbit.yaml"
310
+ echo "Review will be posted as PR comments automatically"
311
+ echo ""
312
+ echo "Severity Handling:"
313
+ echo " - CRITICAL: Must fix before merge"
314
+ echo " - HIGH: Should address or document"
315
+ echo " - MEDIUM/LOW: Optional"
316
+
317
+ - name: Checkout for config check
318
+ uses: actions/checkout@v4
319
+ with:
320
+ sparse-checkout: .coderabbit.yaml
321
+ sparse-checkout-cone-mode: false
322
+
323
+ - name: Validate config
324
+ run: |
325
+ if [ -f ".coderabbit.yaml" ]; then
326
+ echo "✅ CodeRabbit configuration found"
327
+ else
328
+ echo "âš ī¸ CodeRabbit configuration not found"
329
+ echo "Create .coderabbit.yaml to customize review behavior"
330
+ fi