aiox-core 5.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/.aiox-core/cli/commands/config/index.js +607 -0
- package/.aiox-core/cli/commands/generate/index.js +222 -0
- package/.aiox-core/cli/commands/manifest/index.js +46 -0
- package/.aiox-core/cli/commands/manifest/regenerate.js +96 -0
- package/.aiox-core/cli/commands/manifest/validate.js +66 -0
- package/.aiox-core/cli/commands/mcp/add.js +234 -0
- package/.aiox-core/cli/commands/mcp/index.js +76 -0
- package/.aiox-core/cli/commands/mcp/link.js +217 -0
- package/.aiox-core/cli/commands/mcp/setup.js +164 -0
- package/.aiox-core/cli/commands/mcp/status.js +183 -0
- package/.aiox-core/cli/commands/metrics/cleanup.js +91 -0
- package/.aiox-core/cli/commands/metrics/index.js +65 -0
- package/.aiox-core/cli/commands/metrics/record.js +154 -0
- package/.aiox-core/cli/commands/metrics/seed.js +126 -0
- package/.aiox-core/cli/commands/metrics/show.js +209 -0
- package/.aiox-core/cli/commands/migrate/analyze.js +353 -0
- package/.aiox-core/cli/commands/migrate/backup.js +352 -0
- package/.aiox-core/cli/commands/migrate/execute.js +292 -0
- package/.aiox-core/cli/commands/migrate/index.js +441 -0
- package/.aiox-core/cli/commands/migrate/rollback.js +323 -0
- package/.aiox-core/cli/commands/migrate/update-imports.js +396 -0
- package/.aiox-core/cli/commands/migrate/validate.js +452 -0
- package/.aiox-core/cli/commands/pro/index.js +703 -0
- package/.aiox-core/cli/commands/qa/index.js +56 -0
- package/.aiox-core/cli/commands/qa/run.js +163 -0
- package/.aiox-core/cli/commands/qa/status.js +195 -0
- package/.aiox-core/cli/commands/validate/index.js +429 -0
- package/.aiox-core/cli/commands/workers/formatters/info-formatter.js +274 -0
- package/.aiox-core/cli/commands/workers/formatters/list-table.js +265 -0
- package/.aiox-core/cli/commands/workers/formatters/list-tree.js +159 -0
- package/.aiox-core/cli/commands/workers/index.js +56 -0
- package/.aiox-core/cli/commands/workers/info.js +194 -0
- package/.aiox-core/cli/commands/workers/list.js +214 -0
- package/.aiox-core/cli/commands/workers/search-filters.js +185 -0
- package/.aiox-core/cli/commands/workers/search-keyword.js +310 -0
- package/.aiox-core/cli/commands/workers/search-semantic.js +293 -0
- package/.aiox-core/cli/commands/workers/search.js +154 -0
- package/.aiox-core/cli/commands/workers/utils/pagination.js +102 -0
- package/.aiox-core/cli/index.js +149 -0
- package/.aiox-core/cli/utils/output-formatter-cli.js +232 -0
- package/.aiox-core/cli/utils/score-calculator.js +221 -0
- package/.aiox-core/constitution.md +171 -0
- package/.aiox-core/core/README.md +229 -0
- package/.aiox-core/core/code-intel/code-intel-client.js +294 -0
- package/.aiox-core/core/code-intel/code-intel-enricher.js +159 -0
- package/.aiox-core/core/code-intel/helpers/creation-helper.js +183 -0
- package/.aiox-core/core/code-intel/helpers/dev-helper.js +206 -0
- package/.aiox-core/core/code-intel/helpers/devops-helper.js +166 -0
- package/.aiox-core/core/code-intel/helpers/planning-helper.js +248 -0
- package/.aiox-core/core/code-intel/helpers/qa-helper.js +187 -0
- package/.aiox-core/core/code-intel/helpers/story-helper.js +146 -0
- package/.aiox-core/core/code-intel/hook-runtime.js +186 -0
- package/.aiox-core/core/code-intel/index.js +139 -0
- package/.aiox-core/core/code-intel/providers/code-graph-provider.js +209 -0
- package/.aiox-core/core/code-intel/providers/provider-interface.js +117 -0
- package/.aiox-core/core/code-intel/providers/registry-provider.js +515 -0
- package/.aiox-core/core/code-intel/registry-syncer.js +331 -0
- package/.aiox-core/core/config/config-cache.js +233 -0
- package/.aiox-core/core/config/config-loader.js +279 -0
- package/.aiox-core/core/config/config-resolver.js +607 -0
- package/.aiox-core/core/config/env-interpolator.js +122 -0
- package/.aiox-core/core/config/merge-utils.js +101 -0
- package/.aiox-core/core/config/migrate-config.js +291 -0
- package/.aiox-core/core/config/schemas/framework-config.schema.json +166 -0
- package/.aiox-core/core/config/schemas/local-config.schema.json +18 -0
- package/.aiox-core/core/config/schemas/project-config.schema.json +344 -0
- package/.aiox-core/core/config/schemas/user-config.schema.json +32 -0
- package/.aiox-core/core/config/template-overrides.js +84 -0
- package/.aiox-core/core/config/templates/user-config.yaml +23 -0
- package/.aiox-core/core/docs/SHARD-TRANSLATION-GUIDE.md +335 -0
- package/.aiox-core/core/docs/component-creation-guide.md +458 -0
- package/.aiox-core/core/docs/session-update-pattern.md +314 -0
- package/.aiox-core/core/docs/template-syntax.md +267 -0
- package/.aiox-core/core/docs/troubleshooting-guide.md +625 -0
- package/.aiox-core/core/doctor/checks/agent-memory.js +63 -0
- package/.aiox-core/core/doctor/checks/claude-md.js +56 -0
- package/.aiox-core/core/doctor/checks/code-intel.js +131 -0
- package/.aiox-core/core/doctor/checks/commands-count.js +81 -0
- package/.aiox-core/core/doctor/checks/core-config.js +53 -0
- package/.aiox-core/core/doctor/checks/entity-registry.js +53 -0
- package/.aiox-core/core/doctor/checks/git-hooks.js +50 -0
- package/.aiox-core/core/doctor/checks/graph-dashboard.js +48 -0
- package/.aiox-core/core/doctor/checks/hooks-claude-count.js +118 -0
- package/.aiox-core/core/doctor/checks/ide-sync.js +85 -0
- package/.aiox-core/core/doctor/checks/index.js +46 -0
- package/.aiox-core/core/doctor/checks/node-version.js +33 -0
- package/.aiox-core/core/doctor/checks/npm-packages.js +78 -0
- package/.aiox-core/core/doctor/checks/rules-files.js +61 -0
- package/.aiox-core/core/doctor/checks/settings-json.js +121 -0
- package/.aiox-core/core/doctor/checks/skills-count.js +72 -0
- package/.aiox-core/core/doctor/fix-handler.js +165 -0
- package/.aiox-core/core/doctor/formatters/json.js +14 -0
- package/.aiox-core/core/doctor/formatters/text.js +59 -0
- package/.aiox-core/core/doctor/index.js +94 -0
- package/.aiox-core/core/elicitation/agent-elicitation.js +272 -0
- package/.aiox-core/core/elicitation/elicitation-engine.js +484 -0
- package/.aiox-core/core/elicitation/session-manager.js +321 -0
- package/.aiox-core/core/elicitation/task-elicitation.js +281 -0
- package/.aiox-core/core/elicitation/workflow-elicitation.js +349 -0
- package/.aiox-core/core/events/dashboard-emitter.js +368 -0
- package/.aiox-core/core/events/index.js +16 -0
- package/.aiox-core/core/events/types.js +51 -0
- package/.aiox-core/core/execution/autonomous-build-loop.js +1066 -0
- package/.aiox-core/core/execution/build-orchestrator.js +1054 -0
- package/.aiox-core/core/execution/build-state-manager.js +1529 -0
- package/.aiox-core/core/execution/context-injector.js +536 -0
- package/.aiox-core/core/execution/parallel-executor.js +292 -0
- package/.aiox-core/core/execution/parallel-monitor.js +429 -0
- package/.aiox-core/core/execution/rate-limit-manager.js +314 -0
- package/.aiox-core/core/execution/result-aggregator.js +485 -0
- package/.aiox-core/core/execution/semantic-merge-engine.js +1735 -0
- package/.aiox-core/core/execution/subagent-dispatcher.js +846 -0
- package/.aiox-core/core/execution/wave-executor.js +397 -0
- package/.aiox-core/core/graph-dashboard/cli.js +361 -0
- package/.aiox-core/core/graph-dashboard/data-sources/code-intel-source.js +234 -0
- package/.aiox-core/core/graph-dashboard/data-sources/metrics-source.js +95 -0
- package/.aiox-core/core/graph-dashboard/data-sources/registry-source.js +106 -0
- package/.aiox-core/core/graph-dashboard/formatters/dot-formatter.js +45 -0
- package/.aiox-core/core/graph-dashboard/formatters/html-formatter.js +1437 -0
- package/.aiox-core/core/graph-dashboard/formatters/json-formatter.js +13 -0
- package/.aiox-core/core/graph-dashboard/formatters/mermaid-formatter.js +59 -0
- package/.aiox-core/core/graph-dashboard/index.js +21 -0
- package/.aiox-core/core/graph-dashboard/renderers/stats-renderer.js +217 -0
- package/.aiox-core/core/graph-dashboard/renderers/status-renderer.js +125 -0
- package/.aiox-core/core/graph-dashboard/renderers/tree-renderer.js +119 -0
- package/.aiox-core/core/health-check/base-check.js +222 -0
- package/.aiox-core/core/health-check/check-registry.js +251 -0
- package/.aiox-core/core/health-check/checks/deployment/build-config.js +109 -0
- package/.aiox-core/core/health-check/checks/deployment/ci-config.js +123 -0
- package/.aiox-core/core/health-check/checks/deployment/deployment-readiness.js +150 -0
- package/.aiox-core/core/health-check/checks/deployment/docker-config.js +120 -0
- package/.aiox-core/core/health-check/checks/deployment/env-file.js +109 -0
- package/.aiox-core/core/health-check/checks/deployment/index.js +27 -0
- package/.aiox-core/core/health-check/checks/index.js +54 -0
- package/.aiox-core/core/health-check/checks/local/disk-space.js +212 -0
- package/.aiox-core/core/health-check/checks/local/environment-vars.js +134 -0
- package/.aiox-core/core/health-check/checks/local/git-install.js +156 -0
- package/.aiox-core/core/health-check/checks/local/ide-detection.js +146 -0
- package/.aiox-core/core/health-check/checks/local/index.js +33 -0
- package/.aiox-core/core/health-check/checks/local/memory.js +136 -0
- package/.aiox-core/core/health-check/checks/local/network.js +168 -0
- package/.aiox-core/core/health-check/checks/local/npm-install.js +147 -0
- package/.aiox-core/core/health-check/checks/local/shell-environment.js +118 -0
- package/.aiox-core/core/health-check/checks/project/agent-config.js +165 -0
- package/.aiox-core/core/health-check/checks/project/aiox-directory.js +141 -0
- package/.aiox-core/core/health-check/checks/project/dependencies.js +148 -0
- package/.aiox-core/core/health-check/checks/project/framework-config.js +131 -0
- package/.aiox-core/core/health-check/checks/project/index.js +33 -0
- package/.aiox-core/core/health-check/checks/project/node-version.js +161 -0
- package/.aiox-core/core/health-check/checks/project/package-json.js +105 -0
- package/.aiox-core/core/health-check/checks/project/task-definitions.js +190 -0
- package/.aiox-core/core/health-check/checks/project/workflow-dependencies.js +212 -0
- package/.aiox-core/core/health-check/checks/repository/branch-protection.js +105 -0
- package/.aiox-core/core/health-check/checks/repository/commit-history.js +142 -0
- package/.aiox-core/core/health-check/checks/repository/conflicts.js +150 -0
- package/.aiox-core/core/health-check/checks/repository/git-repo.js +157 -0
- package/.aiox-core/core/health-check/checks/repository/git-status.js +147 -0
- package/.aiox-core/core/health-check/checks/repository/gitignore.js +192 -0
- package/.aiox-core/core/health-check/checks/repository/index.js +33 -0
- package/.aiox-core/core/health-check/checks/repository/large-files.js +181 -0
- package/.aiox-core/core/health-check/checks/repository/lockfile-integrity.js +142 -0
- package/.aiox-core/core/health-check/checks/services/api-endpoints.js +166 -0
- package/.aiox-core/core/health-check/checks/services/claude-code.js +137 -0
- package/.aiox-core/core/health-check/checks/services/gemini-cli.js +239 -0
- package/.aiox-core/core/health-check/checks/services/github-cli.js +115 -0
- package/.aiox-core/core/health-check/checks/services/index.js +27 -0
- package/.aiox-core/core/health-check/checks/services/mcp-integration.js +123 -0
- package/.aiox-core/core/health-check/engine.js +405 -0
- package/.aiox-core/core/health-check/healers/backup-manager.js +338 -0
- package/.aiox-core/core/health-check/healers/index.js +328 -0
- package/.aiox-core/core/health-check/index.js +375 -0
- package/.aiox-core/core/health-check/reporters/console.js +329 -0
- package/.aiox-core/core/health-check/reporters/index.js +115 -0
- package/.aiox-core/core/health-check/reporters/json.js +299 -0
- package/.aiox-core/core/health-check/reporters/markdown.js +321 -0
- package/.aiox-core/core/ideation/ideation-engine.js +832 -0
- package/.aiox-core/core/ids/README.md +121 -0
- package/.aiox-core/core/ids/circuit-breaker.js +156 -0
- package/.aiox-core/core/ids/framework-governor.js +565 -0
- package/.aiox-core/core/ids/gates/g1-epic-creation.js +101 -0
- package/.aiox-core/core/ids/gates/g2-story-creation.js +133 -0
- package/.aiox-core/core/ids/gates/g3-story-validation.js +166 -0
- package/.aiox-core/core/ids/gates/g4-dev-context.js +155 -0
- package/.aiox-core/core/ids/incremental-decision-engine.js +651 -0
- package/.aiox-core/core/ids/index.js +156 -0
- package/.aiox-core/core/ids/layer-classifier.js +65 -0
- package/.aiox-core/core/ids/registry-healer.js +866 -0
- package/.aiox-core/core/ids/registry-loader.js +310 -0
- package/.aiox-core/core/ids/registry-updater.js +751 -0
- package/.aiox-core/core/ids/verification-gate.js +306 -0
- package/.aiox-core/core/index.esm.js +42 -0
- package/.aiox-core/core/index.js +88 -0
- package/.aiox-core/core/manifest/manifest-generator.js +386 -0
- package/.aiox-core/core/manifest/manifest-validator.js +429 -0
- package/.aiox-core/core/mcp/config-migrator.js +340 -0
- package/.aiox-core/core/mcp/global-config-manager.js +369 -0
- package/.aiox-core/core/mcp/index.js +34 -0
- package/.aiox-core/core/mcp/os-detector.js +188 -0
- package/.aiox-core/core/mcp/symlink-manager.js +413 -0
- package/.aiox-core/core/memory/__tests__/active-modules.verify.js +253 -0
- package/.aiox-core/core/memory/gotchas-memory.js +1152 -0
- package/.aiox-core/core/migration/migration-config.yaml +83 -0
- package/.aiox-core/core/migration/module-mapping.yaml +89 -0
- package/.aiox-core/core/orchestration/agent-invoker.js +611 -0
- package/.aiox-core/core/orchestration/bob-orchestrator.js +1031 -0
- package/.aiox-core/core/orchestration/bob-status-writer.js +481 -0
- package/.aiox-core/core/orchestration/bob-surface-criteria.yaml +271 -0
- package/.aiox-core/core/orchestration/brownfield-handler.js +739 -0
- package/.aiox-core/core/orchestration/checklist-runner.js +327 -0
- package/.aiox-core/core/orchestration/cli-commands.js +580 -0
- package/.aiox-core/core/orchestration/condition-evaluator.js +379 -0
- package/.aiox-core/core/orchestration/context-manager.js +615 -0
- package/.aiox-core/core/orchestration/dashboard-integration.js +519 -0
- package/.aiox-core/core/orchestration/data-lifecycle-manager.js +356 -0
- package/.aiox-core/core/orchestration/epic-context-accumulator.js +396 -0
- package/.aiox-core/core/orchestration/execution-profile-resolver.js +107 -0
- package/.aiox-core/core/orchestration/executor-assignment.js +412 -0
- package/.aiox-core/core/orchestration/executors/epic-3-executor.js +221 -0
- package/.aiox-core/core/orchestration/executors/epic-4-executor.js +268 -0
- package/.aiox-core/core/orchestration/executors/epic-5-executor.js +328 -0
- package/.aiox-core/core/orchestration/executors/epic-6-executor.js +264 -0
- package/.aiox-core/core/orchestration/executors/epic-executor.js +237 -0
- package/.aiox-core/core/orchestration/executors/index.js +86 -0
- package/.aiox-core/core/orchestration/gate-evaluator.js +494 -0
- package/.aiox-core/core/orchestration/gemini-model-selector.js +161 -0
- package/.aiox-core/core/orchestration/greenfield-handler.js +888 -0
- package/.aiox-core/core/orchestration/index.js +322 -0
- package/.aiox-core/core/orchestration/lock-manager.js +326 -0
- package/.aiox-core/core/orchestration/master-orchestrator.js +1542 -0
- package/.aiox-core/core/orchestration/message-formatter.js +279 -0
- package/.aiox-core/core/orchestration/parallel-executor.js +225 -0
- package/.aiox-core/core/orchestration/recovery-handler.js +720 -0
- package/.aiox-core/core/orchestration/session-state.js +877 -0
- package/.aiox-core/core/orchestration/skill-dispatcher.js +363 -0
- package/.aiox-core/core/orchestration/subagent-prompt-builder.js +368 -0
- package/.aiox-core/core/orchestration/surface-checker.js +403 -0
- package/.aiox-core/core/orchestration/task-complexity-classifier.js +123 -0
- package/.aiox-core/core/orchestration/tech-stack-detector.js +599 -0
- package/.aiox-core/core/orchestration/terminal-spawner.js +1043 -0
- package/.aiox-core/core/orchestration/workflow-executor.js +1180 -0
- package/.aiox-core/core/orchestration/workflow-orchestrator.js +906 -0
- package/.aiox-core/core/permissions/__tests__/permission-mode.test.js +292 -0
- package/.aiox-core/core/permissions/index.js +139 -0
- package/.aiox-core/core/permissions/operation-guard.js +395 -0
- package/.aiox-core/core/permissions/permission-mode.js +270 -0
- package/.aiox-core/core/quality-gates/base-layer.js +134 -0
- package/.aiox-core/core/quality-gates/checklist-generator.js +329 -0
- package/.aiox-core/core/quality-gates/focus-area-recommender.js +359 -0
- package/.aiox-core/core/quality-gates/human-review-orchestrator.js +529 -0
- package/.aiox-core/core/quality-gates/layer1-precommit.js +336 -0
- package/.aiox-core/core/quality-gates/layer2-pr-automation.js +331 -0
- package/.aiox-core/core/quality-gates/layer3-human-review.js +348 -0
- package/.aiox-core/core/quality-gates/notification-manager.js +550 -0
- package/.aiox-core/core/quality-gates/quality-gate-config.yaml +86 -0
- package/.aiox-core/core/quality-gates/quality-gate-manager.js +601 -0
- package/.aiox-core/core/registry/README.md +179 -0
- package/.aiox-core/core/registry/build-registry.js +452 -0
- package/.aiox-core/core/registry/registry-loader.js +330 -0
- package/.aiox-core/core/registry/registry-schema.json +166 -0
- package/.aiox-core/core/registry/service-registry.json +6466 -0
- package/.aiox-core/core/registry/validate-registry.js +340 -0
- package/.aiox-core/core/session/context-detector.js +227 -0
- package/.aiox-core/core/session/context-loader.js +442 -0
- package/.aiox-core/core/synapse/context/context-builder.js +34 -0
- package/.aiox-core/core/synapse/context/context-tracker.js +198 -0
- package/.aiox-core/core/synapse/diagnostics/collectors/consistency-collector.js +168 -0
- package/.aiox-core/core/synapse/diagnostics/collectors/hook-collector.js +129 -0
- package/.aiox-core/core/synapse/diagnostics/collectors/manifest-collector.js +82 -0
- package/.aiox-core/core/synapse/diagnostics/collectors/output-analyzer.js +134 -0
- package/.aiox-core/core/synapse/diagnostics/collectors/pipeline-collector.js +75 -0
- package/.aiox-core/core/synapse/diagnostics/collectors/quality-collector.js +252 -0
- package/.aiox-core/core/synapse/diagnostics/collectors/relevance-matrix.js +174 -0
- package/.aiox-core/core/synapse/diagnostics/collectors/safe-read-json.js +31 -0
- package/.aiox-core/core/synapse/diagnostics/collectors/session-collector.js +102 -0
- package/.aiox-core/core/synapse/diagnostics/collectors/timing-collector.js +126 -0
- package/.aiox-core/core/synapse/diagnostics/collectors/uap-collector.js +83 -0
- package/.aiox-core/core/synapse/diagnostics/report-formatter.js +484 -0
- package/.aiox-core/core/synapse/diagnostics/synapse-diagnostics.js +95 -0
- package/.aiox-core/core/synapse/domain/domain-loader.js +322 -0
- package/.aiox-core/core/synapse/engine.js +400 -0
- package/.aiox-core/core/synapse/layers/l0-constitution.js +80 -0
- package/.aiox-core/core/synapse/layers/l1-global.js +102 -0
- package/.aiox-core/core/synapse/layers/l2-agent.js +94 -0
- package/.aiox-core/core/synapse/layers/l3-workflow.js +94 -0
- package/.aiox-core/core/synapse/layers/l4-task.js +83 -0
- package/.aiox-core/core/synapse/layers/l5-squad.js +244 -0
- package/.aiox-core/core/synapse/layers/l6-keyword.js +154 -0
- package/.aiox-core/core/synapse/layers/l7-star-command.js +169 -0
- package/.aiox-core/core/synapse/layers/layer-processor.js +82 -0
- package/.aiox-core/core/synapse/memory/memory-bridge.js +220 -0
- package/.aiox-core/core/synapse/memory/synapse-memory-provider.js +201 -0
- package/.aiox-core/core/synapse/output/formatter.js +561 -0
- package/.aiox-core/core/synapse/runtime/hook-runtime.js +103 -0
- package/.aiox-core/core/synapse/scripts/generate-constitution.js +204 -0
- package/.aiox-core/core/synapse/session/session-manager.js +404 -0
- package/.aiox-core/core/synapse/utils/atomic-write.js +79 -0
- package/.aiox-core/core/synapse/utils/paths.js +57 -0
- package/.aiox-core/core/synapse/utils/tokens.js +25 -0
- package/.aiox-core/core/ui/index.js +42 -0
- package/.aiox-core/core/ui/observability-panel.js +394 -0
- package/.aiox-core/core/ui/panel-renderer.js +337 -0
- package/.aiox-core/core/utils/output-formatter.js +298 -0
- package/.aiox-core/core/utils/security-utils.js +335 -0
- package/.aiox-core/core/utils/yaml-validator.js +415 -0
- package/.aiox-core/core-config.yaml +388 -0
- package/.aiox-core/data/agent-config-requirements.yaml +407 -0
- package/.aiox-core/data/aiox-kb.md +916 -0
- package/.aiox-core/data/capability-detection.js +290 -0
- package/.aiox-core/data/entity-registry.yaml +14299 -0
- package/.aiox-core/data/learned-patterns.yaml +3 -0
- package/.aiox-core/data/mcp-discipline.js +166 -0
- package/.aiox-core/data/mcp-tool-examples.yaml +215 -0
- package/.aiox-core/data/tech-presets/_template.md +257 -0
- package/.aiox-core/data/tech-presets/csharp.md +468 -0
- package/.aiox-core/data/tech-presets/go.md +515 -0
- package/.aiox-core/data/tech-presets/java.md +499 -0
- package/.aiox-core/data/tech-presets/nextjs-react.md +931 -0
- package/.aiox-core/data/tech-presets/php.md +484 -0
- package/.aiox-core/data/tech-presets/rust.md +477 -0
- package/.aiox-core/data/technical-preferences.md +88 -0
- package/.aiox-core/data/tok2-validation.js +168 -0
- package/.aiox-core/data/tok3-token-comparison.js +123 -0
- package/.aiox-core/data/tool-registry.yaml +648 -0
- package/.aiox-core/data/tool-search-validation.js +174 -0
- package/.aiox-core/data/workflow-chains.yaml +156 -0
- package/.aiox-core/data/workflow-patterns.yaml +834 -0
- package/.aiox-core/data/workflow-state-schema.yaml +202 -0
- package/.aiox-core/development/README.md +142 -0
- package/.aiox-core/development/agent-teams/team-all.yaml +15 -0
- package/.aiox-core/development/agent-teams/team-fullstack.yaml +18 -0
- package/.aiox-core/development/agent-teams/team-ide-minimal.yaml +10 -0
- package/.aiox-core/development/agent-teams/team-no-ui.yaml +13 -0
- package/.aiox-core/development/agent-teams/team-qa-focused.yaml +155 -0
- package/.aiox-core/development/agents/aiox-master.md +463 -0
- package/.aiox-core/development/agents/analyst/MEMORY.md +33 -0
- package/.aiox-core/development/agents/analyst.md +271 -0
- package/.aiox-core/development/agents/architect/MEMORY.md +39 -0
- package/.aiox-core/development/agents/architect.md +472 -0
- package/.aiox-core/development/agents/data-engineer/MEMORY.md +32 -0
- package/.aiox-core/development/agents/data-engineer.md +493 -0
- package/.aiox-core/development/agents/dev/MEMORY.md +46 -0
- package/.aiox-core/development/agents/dev.md +558 -0
- package/.aiox-core/development/agents/devops/MEMORY.md +39 -0
- package/.aiox-core/development/agents/devops.md +537 -0
- package/.aiox-core/development/agents/pm/MEMORY.md +38 -0
- package/.aiox-core/development/agents/pm.md +375 -0
- package/.aiox-core/development/agents/po/MEMORY.md +45 -0
- package/.aiox-core/development/agents/po.md +333 -0
- package/.aiox-core/development/agents/qa/MEMORY.md +42 -0
- package/.aiox-core/development/agents/qa.md +447 -0
- package/.aiox-core/development/agents/sm/MEMORY.md +31 -0
- package/.aiox-core/development/agents/sm.md +285 -0
- package/.aiox-core/development/agents/squad-creator.md +342 -0
- package/.aiox-core/development/agents/ux/MEMORY.md +31 -0
- package/.aiox-core/development/agents/ux-design-expert.md +493 -0
- package/.aiox-core/development/checklists/agent-quality-gate.md +559 -0
- package/.aiox-core/development/checklists/brownfield-compatibility-checklist.md +114 -0
- package/.aiox-core/development/checklists/issue-triage-checklist.md +35 -0
- package/.aiox-core/development/checklists/memory-audit-checklist.md +53 -0
- package/.aiox-core/development/checklists/self-critique-checklist.md +273 -0
- package/.aiox-core/development/data/decision-heuristics-framework.md +621 -0
- package/.aiox-core/development/data/quality-dimensions-framework.md +426 -0
- package/.aiox-core/development/data/tier-system-framework.md +475 -0
- package/.aiox-core/development/scripts/activation-runtime.js +63 -0
- package/.aiox-core/development/scripts/agent-assignment-resolver.js +231 -0
- package/.aiox-core/development/scripts/agent-config-loader.js +626 -0
- package/.aiox-core/development/scripts/agent-exit-hooks.js +96 -0
- package/.aiox-core/development/scripts/apply-inline-greeting-all-agents.js +146 -0
- package/.aiox-core/development/scripts/approval-workflow.js +643 -0
- package/.aiox-core/development/scripts/audit-agent-config.js +380 -0
- package/.aiox-core/development/scripts/backlog-manager.js +407 -0
- package/.aiox-core/development/scripts/backup-manager.js +607 -0
- package/.aiox-core/development/scripts/batch-update-agents-session-context.js +95 -0
- package/.aiox-core/development/scripts/branch-manager.js +390 -0
- package/.aiox-core/development/scripts/code-quality-improver.js +1329 -0
- package/.aiox-core/development/scripts/commit-message-generator.js +850 -0
- package/.aiox-core/development/scripts/conflict-resolver.js +675 -0
- package/.aiox-core/development/scripts/decision-context.js +228 -0
- package/.aiox-core/development/scripts/decision-log-generator.js +293 -0
- package/.aiox-core/development/scripts/decision-log-indexer.js +284 -0
- package/.aiox-core/development/scripts/decision-recorder.js +168 -0
- package/.aiox-core/development/scripts/dependency-analyzer.js +638 -0
- package/.aiox-core/development/scripts/dev-context-loader.js +296 -0
- package/.aiox-core/development/scripts/diff-generator.js +352 -0
- package/.aiox-core/development/scripts/elicitation-engine.js +385 -0
- package/.aiox-core/development/scripts/elicitation-session-manager.js +300 -0
- package/.aiox-core/development/scripts/generate-greeting.js +109 -0
- package/.aiox-core/development/scripts/git-wrapper.js +462 -0
- package/.aiox-core/development/scripts/greeting-builder.js +1404 -0
- package/.aiox-core/development/scripts/greeting-config-cli.js +85 -0
- package/.aiox-core/development/scripts/greeting-preference-manager.js +169 -0
- package/.aiox-core/development/scripts/issue-triage.js +171 -0
- package/.aiox-core/development/scripts/manifest-preview.js +245 -0
- package/.aiox-core/development/scripts/metrics-tracker.js +776 -0
- package/.aiox-core/development/scripts/migrate-task-to-v2.js +377 -0
- package/.aiox-core/development/scripts/modification-validator.js +555 -0
- package/.aiox-core/development/scripts/pattern-learner.js +1225 -0
- package/.aiox-core/development/scripts/performance-analyzer.js +758 -0
- package/.aiox-core/development/scripts/populate-entity-registry.js +673 -0
- package/.aiox-core/development/scripts/refactoring-suggester.js +1148 -0
- package/.aiox-core/development/scripts/rollback-handler.js +531 -0
- package/.aiox-core/development/scripts/security-checker.js +359 -0
- package/.aiox-core/development/scripts/skill-validator.js +341 -0
- package/.aiox-core/development/scripts/squad/README.md +112 -0
- package/.aiox-core/development/scripts/squad/index.js +123 -0
- package/.aiox-core/development/scripts/squad/squad-analyzer.js +637 -0
- package/.aiox-core/development/scripts/squad/squad-designer.js +1010 -0
- package/.aiox-core/development/scripts/squad/squad-downloader.js +510 -0
- package/.aiox-core/development/scripts/squad/squad-extender.js +871 -0
- package/.aiox-core/development/scripts/squad/squad-generator.js +1405 -0
- package/.aiox-core/development/scripts/squad/squad-loader.js +359 -0
- package/.aiox-core/development/scripts/squad/squad-migrator.js +627 -0
- package/.aiox-core/development/scripts/squad/squad-publisher.js +629 -0
- package/.aiox-core/development/scripts/squad/squad-validator.js +855 -0
- package/.aiox-core/development/scripts/story-index-generator.js +337 -0
- package/.aiox-core/development/scripts/story-manager.js +375 -0
- package/.aiox-core/development/scripts/story-update-hook.js +259 -0
- package/.aiox-core/development/scripts/task-identifier-resolver.js +145 -0
- package/.aiox-core/development/scripts/template-engine.js +240 -0
- package/.aiox-core/development/scripts/template-validator.js +279 -0
- package/.aiox-core/development/scripts/test-generator.js +844 -0
- package/.aiox-core/development/scripts/test-greeting-system.js +142 -0
- package/.aiox-core/development/scripts/transaction-manager.js +590 -0
- package/.aiox-core/development/scripts/unified-activation-pipeline.js +815 -0
- package/.aiox-core/development/scripts/usage-tracker.js +674 -0
- package/.aiox-core/development/scripts/validate-filenames.js +226 -0
- package/.aiox-core/development/scripts/validate-task-v2.js +319 -0
- package/.aiox-core/development/scripts/verify-workflow-gaps.js +1032 -0
- package/.aiox-core/development/scripts/version-tracker.js +527 -0
- package/.aiox-core/development/scripts/workflow-navigator.js +327 -0
- package/.aiox-core/development/scripts/workflow-state-manager.js +650 -0
- package/.aiox-core/development/scripts/workflow-validator.js +695 -0
- package/.aiox-core/development/scripts/yaml-validator.js +397 -0
- package/.aiox-core/development/tasks/add-mcp.md +436 -0
- package/.aiox-core/development/tasks/advanced-elicitation.md +319 -0
- package/.aiox-core/development/tasks/analyst-facilitate-brainstorming.md +342 -0
- package/.aiox-core/development/tasks/analyze-brownfield.md +456 -0
- package/.aiox-core/development/tasks/analyze-cross-artifact.md +357 -0
- package/.aiox-core/development/tasks/analyze-framework.md +697 -0
- package/.aiox-core/development/tasks/analyze-performance.md +637 -0
- package/.aiox-core/development/tasks/analyze-project-structure.md +669 -0
- package/.aiox-core/development/tasks/apply-qa-fixes.md +347 -0
- package/.aiox-core/development/tasks/architect-analyze-impact.md +834 -0
- package/.aiox-core/development/tasks/audit-codebase.md +429 -0
- package/.aiox-core/development/tasks/audit-tailwind-config.md +270 -0
- package/.aiox-core/development/tasks/audit-utilities.md +358 -0
- package/.aiox-core/development/tasks/blocks/README.md +178 -0
- package/.aiox-core/development/tasks/blocks/agent-prompt-template.md +115 -0
- package/.aiox-core/development/tasks/blocks/context-loading.md +108 -0
- package/.aiox-core/development/tasks/blocks/execution-pattern.md +121 -0
- package/.aiox-core/development/tasks/blocks/finalization.md +123 -0
- package/.aiox-core/development/tasks/bootstrap-shadcn-library.md +286 -0
- package/.aiox-core/development/tasks/brownfield-create-epic.md +573 -0
- package/.aiox-core/development/tasks/brownfield-create-story.md +364 -0
- package/.aiox-core/development/tasks/build-autonomous.md +199 -0
- package/.aiox-core/development/tasks/build-component.md +478 -0
- package/.aiox-core/development/tasks/build-resume.md +125 -0
- package/.aiox-core/development/tasks/build-status.md +155 -0
- package/.aiox-core/development/tasks/build.md +141 -0
- package/.aiox-core/development/tasks/calculate-roi.md +455 -0
- package/.aiox-core/development/tasks/check-docs-links.md +114 -0
- package/.aiox-core/development/tasks/ci-cd-configuration.md +764 -0
- package/.aiox-core/development/tasks/cleanup-utilities.md +670 -0
- package/.aiox-core/development/tasks/cleanup-worktrees.md +39 -0
- package/.aiox-core/development/tasks/collaborative-edit.md +1109 -0
- package/.aiox-core/development/tasks/compose-molecule.md +284 -0
- package/.aiox-core/development/tasks/consolidate-patterns.md +414 -0
- package/.aiox-core/development/tasks/correct-course.md +280 -0
- package/.aiox-core/development/tasks/create-agent.md +1198 -0
- package/.aiox-core/development/tasks/create-brownfield-story.md +727 -0
- package/.aiox-core/development/tasks/create-deep-research-prompt.md +506 -0
- package/.aiox-core/development/tasks/create-doc.md +360 -0
- package/.aiox-core/development/tasks/create-next-story.md +791 -0
- package/.aiox-core/development/tasks/create-service.md +414 -0
- package/.aiox-core/development/tasks/create-suite.md +291 -0
- package/.aiox-core/development/tasks/create-task.md +390 -0
- package/.aiox-core/development/tasks/create-workflow.md +428 -0
- package/.aiox-core/development/tasks/create-worktree.md +437 -0
- package/.aiox-core/development/tasks/db-analyze-hotpaths.md +572 -0
- package/.aiox-core/development/tasks/db-apply-migration.md +381 -0
- package/.aiox-core/development/tasks/db-bootstrap.md +642 -0
- package/.aiox-core/development/tasks/db-domain-modeling.md +693 -0
- package/.aiox-core/development/tasks/db-dry-run.md +293 -0
- package/.aiox-core/development/tasks/db-env-check.md +260 -0
- package/.aiox-core/development/tasks/db-explain.md +631 -0
- package/.aiox-core/development/tasks/db-impersonate.md +495 -0
- package/.aiox-core/development/tasks/db-load-csv.md +593 -0
- package/.aiox-core/development/tasks/db-policy-apply.md +653 -0
- package/.aiox-core/development/tasks/db-rls-audit.md +411 -0
- package/.aiox-core/development/tasks/db-rollback.md +739 -0
- package/.aiox-core/development/tasks/db-run-sql.md +613 -0
- package/.aiox-core/development/tasks/db-schema-audit.md +1011 -0
- package/.aiox-core/development/tasks/db-seed.md +390 -0
- package/.aiox-core/development/tasks/db-smoke-test.md +351 -0
- package/.aiox-core/development/tasks/db-snapshot.md +569 -0
- package/.aiox-core/development/tasks/db-squad-integration.md +663 -0
- package/.aiox-core/development/tasks/db-supabase-setup.md +712 -0
- package/.aiox-core/development/tasks/db-verify-order.md +515 -0
- package/.aiox-core/development/tasks/deprecate-component.md +957 -0
- package/.aiox-core/development/tasks/dev-apply-qa-fixes.md +318 -0
- package/.aiox-core/development/tasks/dev-backlog-debt.md +469 -0
- package/.aiox-core/development/tasks/dev-develop-story.md +924 -0
- package/.aiox-core/development/tasks/dev-improve-code-quality.md +873 -0
- package/.aiox-core/development/tasks/dev-optimize-performance.md +1034 -0
- package/.aiox-core/development/tasks/dev-suggest-refactoring.md +877 -0
- package/.aiox-core/development/tasks/dev-validate-next-story.md +349 -0
- package/.aiox-core/development/tasks/document-gotchas.md +477 -0
- package/.aiox-core/development/tasks/document-project.md +553 -0
- package/.aiox-core/development/tasks/environment-bootstrap.md +1389 -0
- package/.aiox-core/development/tasks/execute-checklist.md +308 -0
- package/.aiox-core/development/tasks/execute-epic-plan.md +885 -0
- package/.aiox-core/development/tasks/export-design-tokens-dtcg.md +274 -0
- package/.aiox-core/development/tasks/extend-pattern.md +269 -0
- package/.aiox-core/development/tasks/extract-patterns.md +397 -0
- package/.aiox-core/development/tasks/extract-tokens.md +467 -0
- package/.aiox-core/development/tasks/facilitate-brainstorming-session.md +518 -0
- package/.aiox-core/development/tasks/generate-ai-frontend-prompt.md +261 -0
- package/.aiox-core/development/tasks/generate-documentation.md +284 -0
- package/.aiox-core/development/tasks/generate-migration-strategy.md +522 -0
- package/.aiox-core/development/tasks/generate-shock-report.md +501 -0
- package/.aiox-core/development/tasks/github-devops-github-pr-automation.md +720 -0
- package/.aiox-core/development/tasks/github-devops-pre-push-quality-gate.md +860 -0
- package/.aiox-core/development/tasks/github-devops-repository-cleanup.md +374 -0
- package/.aiox-core/development/tasks/github-devops-version-management.md +483 -0
- package/.aiox-core/development/tasks/github-issue-triage.md +118 -0
- package/.aiox-core/development/tasks/gotcha.md +136 -0
- package/.aiox-core/development/tasks/gotchas.md +153 -0
- package/.aiox-core/development/tasks/health-check.yaml +265 -0
- package/.aiox-core/development/tasks/ids-governor.md +94 -0
- package/.aiox-core/development/tasks/ids-health.md +89 -0
- package/.aiox-core/development/tasks/ids-query.md +154 -0
- package/.aiox-core/development/tasks/improve-self.md +823 -0
- package/.aiox-core/development/tasks/index-docs.md +388 -0
- package/.aiox-core/development/tasks/init-project-status.md +506 -0
- package/.aiox-core/development/tasks/integrate-squad.md +314 -0
- package/.aiox-core/development/tasks/kb-mode-interaction.md +284 -0
- package/.aiox-core/development/tasks/learn-patterns.md +901 -0
- package/.aiox-core/development/tasks/list-mcps.md +33 -0
- package/.aiox-core/development/tasks/list-worktrees.md +342 -0
- package/.aiox-core/development/tasks/mcp-workflow.md +437 -0
- package/.aiox-core/development/tasks/merge-worktree.md +42 -0
- package/.aiox-core/development/tasks/modify-agent.md +398 -0
- package/.aiox-core/development/tasks/modify-task.md +441 -0
- package/.aiox-core/development/tasks/modify-workflow.md +510 -0
- package/.aiox-core/development/tasks/next.md +325 -0
- package/.aiox-core/development/tasks/orchestrate-resume.md +59 -0
- package/.aiox-core/development/tasks/orchestrate-status.md +63 -0
- package/.aiox-core/development/tasks/orchestrate-stop.md +54 -0
- package/.aiox-core/development/tasks/orchestrate.md +65 -0
- package/.aiox-core/development/tasks/patterns.md +334 -0
- package/.aiox-core/development/tasks/plan-create-context.md +856 -0
- package/.aiox-core/development/tasks/plan-create-implementation.md +852 -0
- package/.aiox-core/development/tasks/plan-execute-subtask.md +960 -0
- package/.aiox-core/development/tasks/po-backlog-add.md +370 -0
- package/.aiox-core/development/tasks/po-close-story.md +434 -0
- package/.aiox-core/development/tasks/po-manage-story-backlog.md +523 -0
- package/.aiox-core/development/tasks/po-pull-story-from-clickup.md +540 -0
- package/.aiox-core/development/tasks/po-pull-story.md +316 -0
- package/.aiox-core/development/tasks/po-stories-index.md +351 -0
- package/.aiox-core/development/tasks/po-sync-story-to-clickup.md +457 -0
- package/.aiox-core/development/tasks/po-sync-story.md +303 -0
- package/.aiox-core/development/tasks/pr-automation.md +701 -0
- package/.aiox-core/development/tasks/propose-modification.md +843 -0
- package/.aiox-core/development/tasks/publish-npm.md +257 -0
- package/.aiox-core/development/tasks/qa-after-creation.md +519 -0
- package/.aiox-core/development/tasks/qa-backlog-add-followup.md +425 -0
- package/.aiox-core/development/tasks/qa-browser-console-check.md +343 -0
- package/.aiox-core/development/tasks/qa-create-fix-request.md +630 -0
- package/.aiox-core/development/tasks/qa-evidence-requirements.md +314 -0
- package/.aiox-core/development/tasks/qa-false-positive-detection.md +374 -0
- package/.aiox-core/development/tasks/qa-fix-issues.md +692 -0
- package/.aiox-core/development/tasks/qa-gate.md +430 -0
- package/.aiox-core/development/tasks/qa-generate-tests.md +1175 -0
- package/.aiox-core/development/tasks/qa-library-validation.md +496 -0
- package/.aiox-core/development/tasks/qa-migration-validation.md +583 -0
- package/.aiox-core/development/tasks/qa-nfr-assess.md +558 -0
- package/.aiox-core/development/tasks/qa-review-build.md +1224 -0
- package/.aiox-core/development/tasks/qa-review-proposal.md +1158 -0
- package/.aiox-core/development/tasks/qa-review-story.md +714 -0
- package/.aiox-core/development/tasks/qa-risk-profile.md +567 -0
- package/.aiox-core/development/tasks/qa-run-tests.md +277 -0
- package/.aiox-core/development/tasks/qa-security-checklist.md +551 -0
- package/.aiox-core/development/tasks/qa-test-design.md +388 -0
- package/.aiox-core/development/tasks/qa-trace-requirements.md +477 -0
- package/.aiox-core/development/tasks/release-management.md +759 -0
- package/.aiox-core/development/tasks/remove-mcp.md +35 -0
- package/.aiox-core/development/tasks/remove-worktree.md +433 -0
- package/.aiox-core/development/tasks/resolve-github-issue.md +608 -0
- package/.aiox-core/development/tasks/review-contributor-pr.md +152 -0
- package/.aiox-core/development/tasks/run-design-system-pipeline.md +640 -0
- package/.aiox-core/development/tasks/run-workflow-engine.md +859 -0
- package/.aiox-core/development/tasks/run-workflow.md +387 -0
- package/.aiox-core/development/tasks/search-mcp.md +309 -0
- package/.aiox-core/development/tasks/security-audit.md +554 -0
- package/.aiox-core/development/tasks/security-scan.md +790 -0
- package/.aiox-core/development/tasks/session-resume.md +192 -0
- package/.aiox-core/development/tasks/setup-database.md +741 -0
- package/.aiox-core/development/tasks/setup-design-system.md +462 -0
- package/.aiox-core/development/tasks/setup-github.md +874 -0
- package/.aiox-core/development/tasks/setup-llm-routing.md +229 -0
- package/.aiox-core/development/tasks/setup-mcp-docker.md +627 -0
- package/.aiox-core/development/tasks/setup-project-docs.md +440 -0
- package/.aiox-core/development/tasks/shard-doc.md +538 -0
- package/.aiox-core/development/tasks/sm-create-next-story.md +480 -0
- package/.aiox-core/development/tasks/spec-assess-complexity.md +461 -0
- package/.aiox-core/development/tasks/spec-critique.md +603 -0
- package/.aiox-core/development/tasks/spec-gather-requirements.md +552 -0
- package/.aiox-core/development/tasks/spec-research-dependencies.md +449 -0
- package/.aiox-core/development/tasks/spec-write-spec.md +536 -0
- package/.aiox-core/development/tasks/squad-creator-analyze.md +315 -0
- package/.aiox-core/development/tasks/squad-creator-create.md +312 -0
- package/.aiox-core/development/tasks/squad-creator-design.md +334 -0
- package/.aiox-core/development/tasks/squad-creator-download.md +167 -0
- package/.aiox-core/development/tasks/squad-creator-extend.md +411 -0
- package/.aiox-core/development/tasks/squad-creator-list.md +225 -0
- package/.aiox-core/development/tasks/squad-creator-migrate.md +243 -0
- package/.aiox-core/development/tasks/squad-creator-publish.md +229 -0
- package/.aiox-core/development/tasks/squad-creator-sync-ide-command.md +402 -0
- package/.aiox-core/development/tasks/squad-creator-sync-synkra.md +315 -0
- package/.aiox-core/development/tasks/squad-creator-validate.md +159 -0
- package/.aiox-core/development/tasks/story-checkpoint.md +360 -0
- package/.aiox-core/development/tasks/sync-documentation.md +865 -0
- package/.aiox-core/development/tasks/sync-registry-intel.md +79 -0
- package/.aiox-core/development/tasks/tailwind-upgrade.md +294 -0
- package/.aiox-core/development/tasks/test-as-user.md +621 -0
- package/.aiox-core/development/tasks/test-validation-task.md +171 -0
- package/.aiox-core/development/tasks/triage-github-issues.md +356 -0
- package/.aiox-core/development/tasks/undo-last.md +347 -0
- package/.aiox-core/development/tasks/update-aiox.md +151 -0
- package/.aiox-core/development/tasks/update-manifest.md +410 -0
- package/.aiox-core/development/tasks/update-source-tree.md +137 -0
- package/.aiox-core/development/tasks/ux-create-wireframe.md +617 -0
- package/.aiox-core/development/tasks/ux-ds-scan-artifact.md +672 -0
- package/.aiox-core/development/tasks/ux-user-research.md +559 -0
- package/.aiox-core/development/tasks/validate-agents.md +119 -0
- package/.aiox-core/development/tasks/validate-next-story.md +472 -0
- package/.aiox-core/development/tasks/validate-tech-preset.md +186 -0
- package/.aiox-core/development/tasks/validate-workflow.md +321 -0
- package/.aiox-core/development/tasks/verify-subtask.md +235 -0
- package/.aiox-core/development/tasks/waves.md +205 -0
- package/.aiox-core/development/tasks/yolo-toggle.md +113 -0
- package/.aiox-core/development/templates/agent-handoff-tmpl.yaml +48 -0
- package/.aiox-core/development/templates/aiox-doc-template.md +494 -0
- package/.aiox-core/development/templates/code-intel-integration-pattern.md +199 -0
- package/.aiox-core/development/templates/ptc-entity-validation.md +113 -0
- package/.aiox-core/development/templates/ptc-qa-gate.md +100 -0
- package/.aiox-core/development/templates/ptc-research-aggregation.md +94 -0
- package/.aiox-core/development/templates/research-prompt-tmpl.md +486 -0
- package/.aiox-core/development/templates/service-template/README.md.hbs +158 -0
- package/.aiox-core/development/templates/service-template/__tests__/index.test.ts.hbs +237 -0
- package/.aiox-core/development/templates/service-template/client.ts.hbs +403 -0
- package/.aiox-core/development/templates/service-template/errors.ts.hbs +182 -0
- package/.aiox-core/development/templates/service-template/index.ts.hbs +120 -0
- package/.aiox-core/development/templates/service-template/jest.config.js +89 -0
- package/.aiox-core/development/templates/service-template/package.json.hbs +87 -0
- package/.aiox-core/development/templates/service-template/tsconfig.json +45 -0
- package/.aiox-core/development/templates/service-template/types.ts.hbs +145 -0
- package/.aiox-core/development/templates/squad/agent-template.md +80 -0
- package/.aiox-core/development/templates/squad/checklist-template.md +82 -0
- package/.aiox-core/development/templates/squad/data-template.yaml +105 -0
- package/.aiox-core/development/templates/squad/script-template.js +179 -0
- package/.aiox-core/development/templates/squad/task-template.md +146 -0
- package/.aiox-core/development/templates/squad/template-template.md +97 -0
- package/.aiox-core/development/templates/squad/tool-template.js +103 -0
- package/.aiox-core/development/templates/squad/workflow-template.yaml +108 -0
- package/.aiox-core/development/templates/squad-template/LICENSE +21 -0
- package/.aiox-core/development/templates/squad-template/README.md +37 -0
- package/.aiox-core/development/templates/squad-template/agents/example-agent.yaml +36 -0
- package/.aiox-core/development/templates/squad-template/package.json +19 -0
- package/.aiox-core/development/templates/squad-template/squad.yaml +25 -0
- package/.aiox-core/development/templates/squad-template/tasks/example-task.yaml +46 -0
- package/.aiox-core/development/templates/squad-template/templates/example-template.md +24 -0
- package/.aiox-core/development/templates/squad-template/tests/example-agent.test.js +53 -0
- package/.aiox-core/development/templates/squad-template/workflows/example-workflow.yaml +54 -0
- package/.aiox-core/development/templates/subagent-step-prompt.md +120 -0
- package/.aiox-core/development/workflows/README.md +81 -0
- package/.aiox-core/development/workflows/auto-worktree.yaml +421 -0
- package/.aiox-core/development/workflows/brownfield-discovery.yaml +932 -0
- package/.aiox-core/development/workflows/brownfield-fullstack.yaml +367 -0
- package/.aiox-core/development/workflows/brownfield-service.yaml +244 -0
- package/.aiox-core/development/workflows/brownfield-ui.yaml +258 -0
- package/.aiox-core/development/workflows/design-system-build-quality.yaml +227 -0
- package/.aiox-core/development/workflows/development-cycle.yaml +425 -0
- package/.aiox-core/development/workflows/epic-orchestration.yaml +326 -0
- package/.aiox-core/development/workflows/greenfield-fullstack.yaml +384 -0
- package/.aiox-core/development/workflows/greenfield-service.yaml +276 -0
- package/.aiox-core/development/workflows/greenfield-ui.yaml +282 -0
- package/.aiox-core/development/workflows/qa-loop.yaml +443 -0
- package/.aiox-core/development/workflows/spec-pipeline.yaml +576 -0
- package/.aiox-core/development/workflows/story-development-cycle.yaml +284 -0
- package/.aiox-core/docs/standards/AGENT-PERSONALIZATION-STANDARD-V1.md +572 -0
- package/.aiox-core/docs/standards/AIOX-COLOR-PALETTE-QUICK-REFERENCE.md +185 -0
- package/.aiox-core/docs/standards/AIOX-COLOR-PALETTE-V2.1.md +353 -0
- package/.aiox-core/docs/standards/AIOX-LIVRO-DE-OURO-V2.1-COMPLETE.md +837 -0
- package/.aiox-core/docs/standards/AIOX-LIVRO-DE-OURO-V2.2-SUMMARY.md +1339 -0
- package/.aiox-core/docs/standards/EXECUTOR-DECISION-TREE.md +697 -0
- package/.aiox-core/docs/standards/OPEN-SOURCE-VS-SERVICE-DIFFERENCES.md +511 -0
- package/.aiox-core/docs/standards/QUALITY-GATES-SPECIFICATION.md +556 -0
- package/.aiox-core/docs/standards/STANDARDS-INDEX.md +210 -0
- package/.aiox-core/docs/standards/STORY-TEMPLATE-V2-SPECIFICATION.md +550 -0
- package/.aiox-core/docs/standards/TASK-FORMAT-SPECIFICATION-V1.md +1414 -0
- package/.aiox-core/elicitation/agent-elicitation.js +272 -0
- package/.aiox-core/elicitation/task-elicitation.js +281 -0
- package/.aiox-core/elicitation/workflow-elicitation.js +315 -0
- package/.aiox-core/framework-config.yaml +158 -0
- package/.aiox-core/hooks/gemini/after-tool.js +77 -0
- package/.aiox-core/hooks/gemini/before-agent.js +79 -0
- package/.aiox-core/hooks/gemini/before-tool.js +114 -0
- package/.aiox-core/hooks/gemini/rewind-handler.js +68 -0
- package/.aiox-core/hooks/gemini/session-end.js +90 -0
- package/.aiox-core/hooks/gemini/session-start.js +90 -0
- package/.aiox-core/hooks/ids-post-commit.js +116 -0
- package/.aiox-core/hooks/ids-pre-push.js +123 -0
- package/.aiox-core/hooks/unified/README.md +338 -0
- package/.aiox-core/hooks/unified/hook-interface.js +159 -0
- package/.aiox-core/hooks/unified/hook-registry.js +143 -0
- package/.aiox-core/hooks/unified/index.js +36 -0
- package/.aiox-core/hooks/unified/runners/precompact-runner.js +96 -0
- package/.aiox-core/index.esm.js +16 -0
- package/.aiox-core/index.js +16 -0
- package/.aiox-core/infrastructure/README.md +126 -0
- package/.aiox-core/infrastructure/contracts/compatibility/aiox-4.0.4.yaml +44 -0
- package/.aiox-core/infrastructure/index.js +199 -0
- package/.aiox-core/infrastructure/integrations/ai-providers/README.md +102 -0
- package/.aiox-core/infrastructure/integrations/ai-providers/ai-provider-factory.js +285 -0
- package/.aiox-core/infrastructure/integrations/ai-providers/ai-provider.js +145 -0
- package/.aiox-core/infrastructure/integrations/ai-providers/claude-provider.js +170 -0
- package/.aiox-core/infrastructure/integrations/ai-providers/gemini-provider.js +365 -0
- package/.aiox-core/infrastructure/integrations/ai-providers/index.js +43 -0
- package/.aiox-core/infrastructure/integrations/gemini-extensions/cloudrun-adapter.js +128 -0
- package/.aiox-core/infrastructure/integrations/gemini-extensions/index.js +41 -0
- package/.aiox-core/infrastructure/integrations/gemini-extensions/policy-sync.js +73 -0
- package/.aiox-core/infrastructure/integrations/gemini-extensions/security-adapter.js +159 -0
- package/.aiox-core/infrastructure/integrations/gemini-extensions/supabase-adapter.js +88 -0
- package/.aiox-core/infrastructure/integrations/gemini-extensions/workspace-adapter.js +99 -0
- package/.aiox-core/infrastructure/integrations/pm-adapters/README.md +59 -0
- package/.aiox-core/infrastructure/integrations/pm-adapters/clickup-adapter.js +345 -0
- package/.aiox-core/infrastructure/integrations/pm-adapters/github-adapter.js +392 -0
- package/.aiox-core/infrastructure/integrations/pm-adapters/jira-adapter.js +448 -0
- package/.aiox-core/infrastructure/integrations/pm-adapters/local-adapter.js +175 -0
- package/.aiox-core/infrastructure/schemas/agent-v3-schema.json +159 -0
- package/.aiox-core/infrastructure/schemas/build-state.schema.json +157 -0
- package/.aiox-core/infrastructure/schemas/task-v3-schema.json +157 -0
- package/.aiox-core/infrastructure/scripts/aiox-validator.js +294 -0
- package/.aiox-core/infrastructure/scripts/approach-manager.js +1003 -0
- package/.aiox-core/infrastructure/scripts/approval-workflow.js +643 -0
- package/.aiox-core/infrastructure/scripts/asset-inventory.js +620 -0
- package/.aiox-core/infrastructure/scripts/atomic-layer-classifier.js +308 -0
- package/.aiox-core/infrastructure/scripts/backup-manager.js +607 -0
- package/.aiox-core/infrastructure/scripts/batch-creator.js +608 -0
- package/.aiox-core/infrastructure/scripts/branch-manager.js +391 -0
- package/.aiox-core/infrastructure/scripts/capability-analyzer.js +535 -0
- package/.aiox-core/infrastructure/scripts/changelog-generator.js +553 -0
- package/.aiox-core/infrastructure/scripts/cicd-discovery.js +1268 -0
- package/.aiox-core/infrastructure/scripts/clickup-helpers.js +226 -0
- package/.aiox-core/infrastructure/scripts/code-quality-improver.js +1312 -0
- package/.aiox-core/infrastructure/scripts/codebase-mapper.js +1286 -0
- package/.aiox-core/infrastructure/scripts/codex-skills-sync/index.js +182 -0
- package/.aiox-core/infrastructure/scripts/codex-skills-sync/validate.js +172 -0
- package/.aiox-core/infrastructure/scripts/collect-tool-usage.js +311 -0
- package/.aiox-core/infrastructure/scripts/commit-message-generator.js +850 -0
- package/.aiox-core/infrastructure/scripts/component-generator.js +738 -0
- package/.aiox-core/infrastructure/scripts/component-metadata.js +627 -0
- package/.aiox-core/infrastructure/scripts/component-search.js +277 -0
- package/.aiox-core/infrastructure/scripts/config-cache.js +322 -0
- package/.aiox-core/infrastructure/scripts/config-loader.js +349 -0
- package/.aiox-core/infrastructure/scripts/conflict-resolver.js +675 -0
- package/.aiox-core/infrastructure/scripts/coverage-analyzer.js +882 -0
- package/.aiox-core/infrastructure/scripts/dashboard-status-writer.js +309 -0
- package/.aiox-core/infrastructure/scripts/dependency-analyzer.js +638 -0
- package/.aiox-core/infrastructure/scripts/dependency-impact-analyzer.js +703 -0
- package/.aiox-core/infrastructure/scripts/diff-generator.js +129 -0
- package/.aiox-core/infrastructure/scripts/documentation-integrity/brownfield-analyzer.js +501 -0
- package/.aiox-core/infrastructure/scripts/documentation-integrity/config-generator.js +368 -0
- package/.aiox-core/infrastructure/scripts/documentation-integrity/deployment-config-loader.js +308 -0
- package/.aiox-core/infrastructure/scripts/documentation-integrity/doc-generator.js +331 -0
- package/.aiox-core/infrastructure/scripts/documentation-integrity/gitignore-generator.js +312 -0
- package/.aiox-core/infrastructure/scripts/documentation-integrity/index.js +74 -0
- package/.aiox-core/infrastructure/scripts/documentation-integrity/mode-detector.js +389 -0
- package/.aiox-core/infrastructure/scripts/documentation-synchronizer.js +1432 -0
- package/.aiox-core/infrastructure/scripts/framework-analyzer.js +762 -0
- package/.aiox-core/infrastructure/scripts/generate-optimization-report.js +497 -0
- package/.aiox-core/infrastructure/scripts/generate-settings-json.js +300 -0
- package/.aiox-core/infrastructure/scripts/git-config-detector.js +349 -0
- package/.aiox-core/infrastructure/scripts/git-hooks/post-commit.js +73 -0
- package/.aiox-core/infrastructure/scripts/git-wrapper.js +443 -0
- package/.aiox-core/infrastructure/scripts/gotchas-documenter.js +1295 -0
- package/.aiox-core/infrastructure/scripts/ide-sync/README.md +218 -0
- package/.aiox-core/infrastructure/scripts/ide-sync/agent-parser.js +295 -0
- package/.aiox-core/infrastructure/scripts/ide-sync/gemini-commands.js +205 -0
- package/.aiox-core/infrastructure/scripts/ide-sync/index.js +540 -0
- package/.aiox-core/infrastructure/scripts/ide-sync/redirect-generator.js +178 -0
- package/.aiox-core/infrastructure/scripts/ide-sync/transformers/antigravity.js +105 -0
- package/.aiox-core/infrastructure/scripts/ide-sync/transformers/claude-code.js +84 -0
- package/.aiox-core/infrastructure/scripts/ide-sync/transformers/cursor.js +94 -0
- package/.aiox-core/infrastructure/scripts/ide-sync/transformers/github-copilot.js +184 -0
- package/.aiox-core/infrastructure/scripts/ide-sync/validator.js +273 -0
- package/.aiox-core/infrastructure/scripts/improvement-engine.js +758 -0
- package/.aiox-core/infrastructure/scripts/improvement-validator.js +710 -0
- package/.aiox-core/infrastructure/scripts/llm-routing/install-llm-routing.js +280 -0
- package/.aiox-core/infrastructure/scripts/llm-routing/templates/claude-free-tracked.cmd +127 -0
- package/.aiox-core/infrastructure/scripts/llm-routing/templates/claude-free-tracked.sh +108 -0
- package/.aiox-core/infrastructure/scripts/llm-routing/templates/claude-free.cmd +80 -0
- package/.aiox-core/infrastructure/scripts/llm-routing/templates/claude-free.sh +62 -0
- package/.aiox-core/infrastructure/scripts/llm-routing/templates/claude-max.cmd +26 -0
- package/.aiox-core/infrastructure/scripts/llm-routing/templates/claude-max.sh +18 -0
- package/.aiox-core/infrastructure/scripts/llm-routing/templates/deepseek-proxy.cmd +71 -0
- package/.aiox-core/infrastructure/scripts/llm-routing/templates/deepseek-proxy.sh +65 -0
- package/.aiox-core/infrastructure/scripts/llm-routing/templates/deepseek-usage.cmd +51 -0
- package/.aiox-core/infrastructure/scripts/llm-routing/templates/deepseek-usage.sh +16 -0
- package/.aiox-core/infrastructure/scripts/llm-routing/usage-tracker/index.js +549 -0
- package/.aiox-core/infrastructure/scripts/migrate-agent.js +526 -0
- package/.aiox-core/infrastructure/scripts/modification-risk-assessment.js +970 -0
- package/.aiox-core/infrastructure/scripts/modification-validator.js +555 -0
- package/.aiox-core/infrastructure/scripts/output-formatter.js +297 -0
- package/.aiox-core/infrastructure/scripts/path-analyzer.js +474 -0
- package/.aiox-core/infrastructure/scripts/pattern-extractor.js +1561 -0
- package/.aiox-core/infrastructure/scripts/performance-analyzer.js +758 -0
- package/.aiox-core/infrastructure/scripts/performance-and-error-resolver.js +258 -0
- package/.aiox-core/infrastructure/scripts/performance-optimizer.js +1902 -0
- package/.aiox-core/infrastructure/scripts/performance-tracker.js +452 -0
- package/.aiox-core/infrastructure/scripts/plan-tracker.js +920 -0
- package/.aiox-core/infrastructure/scripts/pm-adapter-factory.js +181 -0
- package/.aiox-core/infrastructure/scripts/pm-adapter.js +134 -0
- package/.aiox-core/infrastructure/scripts/pr-review-ai.js +1061 -0
- package/.aiox-core/infrastructure/scripts/project-status-loader.js +848 -0
- package/.aiox-core/infrastructure/scripts/qa-loop-orchestrator.js +1262 -0
- package/.aiox-core/infrastructure/scripts/qa-report-generator.js +1152 -0
- package/.aiox-core/infrastructure/scripts/recovery-tracker.js +963 -0
- package/.aiox-core/infrastructure/scripts/refactoring-suggester.js +1139 -0
- package/.aiox-core/infrastructure/scripts/repository-detector.js +64 -0
- package/.aiox-core/infrastructure/scripts/rollback-manager.js +732 -0
- package/.aiox-core/infrastructure/scripts/sandbox-tester.js +618 -0
- package/.aiox-core/infrastructure/scripts/security-checker.js +359 -0
- package/.aiox-core/infrastructure/scripts/spot-check-validator.js +149 -0
- package/.aiox-core/infrastructure/scripts/status-mapper.js +115 -0
- package/.aiox-core/infrastructure/scripts/story-worktree-hooks.js +425 -0
- package/.aiox-core/infrastructure/scripts/stuck-detector.js +1249 -0
- package/.aiox-core/infrastructure/scripts/subtask-verifier.js +793 -0
- package/.aiox-core/infrastructure/scripts/template-engine.js +240 -0
- package/.aiox-core/infrastructure/scripts/template-validator.js +279 -0
- package/.aiox-core/infrastructure/scripts/test-discovery.js +1259 -0
- package/.aiox-core/infrastructure/scripts/test-generator.js +844 -0
- package/.aiox-core/infrastructure/scripts/test-quality-assessment.js +1081 -0
- package/.aiox-core/infrastructure/scripts/test-utilities-fast.js +126 -0
- package/.aiox-core/infrastructure/scripts/test-utilities.js +200 -0
- package/.aiox-core/infrastructure/scripts/tool-resolver.js +360 -0
- package/.aiox-core/infrastructure/scripts/transaction-manager.js +590 -0
- package/.aiox-core/infrastructure/scripts/usage-analytics.js +634 -0
- package/.aiox-core/infrastructure/scripts/validate-agents.js +526 -0
- package/.aiox-core/infrastructure/scripts/validate-claude-integration.js +101 -0
- package/.aiox-core/infrastructure/scripts/validate-codex-integration.js +141 -0
- package/.aiox-core/infrastructure/scripts/validate-gemini-integration.js +151 -0
- package/.aiox-core/infrastructure/scripts/validate-output-pattern.js +213 -0
- package/.aiox-core/infrastructure/scripts/validate-parity.js +355 -0
- package/.aiox-core/infrastructure/scripts/validate-paths.js +142 -0
- package/.aiox-core/infrastructure/scripts/validate-user-profile.js +249 -0
- package/.aiox-core/infrastructure/scripts/visual-impact-generator.js +1056 -0
- package/.aiox-core/infrastructure/scripts/worktree-manager.js +703 -0
- package/.aiox-core/infrastructure/scripts/yaml-validator.js +397 -0
- package/.aiox-core/infrastructure/templates/aiox-sync.yaml.template +182 -0
- package/.aiox-core/infrastructure/templates/coderabbit.yaml.template +279 -0
- package/.aiox-core/infrastructure/templates/core-config/core-config-brownfield.tmpl.yaml +176 -0
- package/.aiox-core/infrastructure/templates/core-config/core-config-greenfield.tmpl.yaml +168 -0
- package/.aiox-core/infrastructure/templates/github-workflows/README.md +109 -0
- package/.aiox-core/infrastructure/templates/github-workflows/ci.yml.template +169 -0
- package/.aiox-core/infrastructure/templates/github-workflows/pr-automation.yml.template +330 -0
- package/.aiox-core/infrastructure/templates/github-workflows/release.yml.template +196 -0
- package/.aiox-core/infrastructure/templates/gitignore/gitignore-aiox-base.tmpl +63 -0
- package/.aiox-core/infrastructure/templates/gitignore/gitignore-brownfield-merge.tmpl +18 -0
- package/.aiox-core/infrastructure/templates/gitignore/gitignore-node.tmpl +85 -0
- package/.aiox-core/infrastructure/templates/gitignore/gitignore-python.tmpl +145 -0
- package/.aiox-core/infrastructure/templates/project-docs/coding-standards-tmpl.md +346 -0
- package/.aiox-core/infrastructure/templates/project-docs/source-tree-tmpl.md +177 -0
- package/.aiox-core/infrastructure/templates/project-docs/tech-stack-tmpl.md +267 -0
- package/.aiox-core/infrastructure/tests/project-status-loader.test.js +568 -0
- package/.aiox-core/infrastructure/tests/regression-suite-v2.md +621 -0
- package/.aiox-core/infrastructure/tests/validate-module.js +97 -0
- package/.aiox-core/infrastructure/tests/worktree-manager.test.js +619 -0
- package/.aiox-core/infrastructure/tools/README.md +222 -0
- package/.aiox-core/infrastructure/tools/cli/github-cli.yaml +200 -0
- package/.aiox-core/infrastructure/tools/cli/llm-routing.yaml +126 -0
- package/.aiox-core/infrastructure/tools/cli/railway-cli.yaml +260 -0
- package/.aiox-core/infrastructure/tools/cli/supabase-cli.yaml +224 -0
- package/.aiox-core/infrastructure/tools/local/ffmpeg.yaml +261 -0
- package/.aiox-core/infrastructure/tools/mcp/21st-dev-magic.yaml +127 -0
- package/.aiox-core/infrastructure/tools/mcp/browser.yaml +103 -0
- package/.aiox-core/infrastructure/tools/mcp/clickup.yaml +534 -0
- package/.aiox-core/infrastructure/tools/mcp/context7.yaml +78 -0
- package/.aiox-core/infrastructure/tools/mcp/desktop-commander.yaml +180 -0
- package/.aiox-core/infrastructure/tools/mcp/exa.yaml +103 -0
- package/.aiox-core/infrastructure/tools/mcp/google-workspace.yaml +930 -0
- package/.aiox-core/infrastructure/tools/mcp/n8n.yaml +551 -0
- package/.aiox-core/infrastructure/tools/mcp/supabase.yaml +808 -0
- package/.aiox-core/install-manifest.yaml +4370 -0
- package/.aiox-core/lib/build.json +1 -0
- package/.aiox-core/local-config.yaml.template +71 -0
- package/.aiox-core/manifests/schema/manifest-schema.json +190 -0
- package/.aiox-core/monitor/hooks/lib/__init__.py +1 -0
- package/.aiox-core/monitor/hooks/lib/enrich.py +58 -0
- package/.aiox-core/monitor/hooks/lib/send_event.py +47 -0
- package/.aiox-core/monitor/hooks/notification.py +29 -0
- package/.aiox-core/monitor/hooks/post_tool_use.py +45 -0
- package/.aiox-core/monitor/hooks/pre_compact.py +29 -0
- package/.aiox-core/monitor/hooks/pre_tool_use.py +40 -0
- package/.aiox-core/monitor/hooks/stop.py +29 -0
- package/.aiox-core/monitor/hooks/subagent_stop.py +29 -0
- package/.aiox-core/monitor/hooks/user_prompt_submit.py +38 -0
- package/.aiox-core/package.json +107 -0
- package/.aiox-core/presets/README.md +358 -0
- package/.aiox-core/product/README.md +56 -0
- package/.aiox-core/product/checklists/accessibility-wcag-checklist.md +80 -0
- package/.aiox-core/product/checklists/architect-checklist.md +444 -0
- package/.aiox-core/product/checklists/change-checklist.md +183 -0
- package/.aiox-core/product/checklists/component-quality-checklist.md +74 -0
- package/.aiox-core/product/checklists/database-design-checklist.md +119 -0
- package/.aiox-core/product/checklists/dba-predeploy-checklist.md +97 -0
- package/.aiox-core/product/checklists/dba-rollback-checklist.md +99 -0
- package/.aiox-core/product/checklists/migration-readiness-checklist.md +75 -0
- package/.aiox-core/product/checklists/pattern-audit-checklist.md +88 -0
- package/.aiox-core/product/checklists/pm-checklist.md +376 -0
- package/.aiox-core/product/checklists/po-master-checklist.md +442 -0
- package/.aiox-core/product/checklists/pre-push-checklist.md +108 -0
- package/.aiox-core/product/checklists/release-checklist.md +122 -0
- package/.aiox-core/product/checklists/self-critique-checklist.md +386 -0
- package/.aiox-core/product/checklists/story-dod-checklist.md +102 -0
- package/.aiox-core/product/checklists/story-draft-checklist.md +216 -0
- package/.aiox-core/product/data/atomic-design-principles.md +108 -0
- package/.aiox-core/product/data/brainstorming-techniques.md +37 -0
- package/.aiox-core/product/data/consolidation-algorithms.md +142 -0
- package/.aiox-core/product/data/database-best-practices.md +182 -0
- package/.aiox-core/product/data/design-token-best-practices.md +107 -0
- package/.aiox-core/product/data/elicitation-methods.md +135 -0
- package/.aiox-core/product/data/integration-patterns.md +207 -0
- package/.aiox-core/product/data/migration-safety-guide.md +329 -0
- package/.aiox-core/product/data/mode-selection-best-practices.md +471 -0
- package/.aiox-core/product/data/postgres-tuning-guide.md +300 -0
- package/.aiox-core/product/data/rls-security-patterns.md +333 -0
- package/.aiox-core/product/data/roi-calculation-guide.md +142 -0
- package/.aiox-core/product/data/supabase-patterns.md +330 -0
- package/.aiox-core/product/data/test-levels-framework.md +149 -0
- package/.aiox-core/product/data/test-priorities-matrix.md +175 -0
- package/.aiox-core/product/data/wcag-compliance-guide.md +267 -0
- package/.aiox-core/product/templates/activation-instructions-inline-greeting.yaml +63 -0
- package/.aiox-core/product/templates/activation-instructions-template.md +258 -0
- package/.aiox-core/product/templates/adr.hbs +125 -0
- package/.aiox-core/product/templates/agent-template.yaml +121 -0
- package/.aiox-core/product/templates/aiox-ai-config.yaml +106 -0
- package/.aiox-core/product/templates/architecture-tmpl.yaml +651 -0
- package/.aiox-core/product/templates/brainstorming-output-tmpl.yaml +156 -0
- package/.aiox-core/product/templates/brownfield-architecture-tmpl.yaml +476 -0
- package/.aiox-core/product/templates/brownfield-prd-tmpl.yaml +280 -0
- package/.aiox-core/product/templates/brownfield-risk-report-tmpl.yaml +277 -0
- package/.aiox-core/product/templates/changelog-template.md +134 -0
- package/.aiox-core/product/templates/command-rationalization-matrix.md +152 -0
- package/.aiox-core/product/templates/competitor-analysis-tmpl.yaml +293 -0
- package/.aiox-core/product/templates/component-react-tmpl.tsx +98 -0
- package/.aiox-core/product/templates/current-approach-tmpl.md +56 -0
- package/.aiox-core/product/templates/dbdr.hbs +241 -0
- package/.aiox-core/product/templates/design-story-tmpl.yaml +587 -0
- package/.aiox-core/product/templates/ds-artifact-analysis.md +70 -0
- package/.aiox-core/product/templates/engine/elicitation.js +298 -0
- package/.aiox-core/product/templates/engine/index.js +308 -0
- package/.aiox-core/product/templates/engine/loader.js +231 -0
- package/.aiox-core/product/templates/engine/renderer.js +343 -0
- package/.aiox-core/product/templates/engine/schemas/adr.schema.json +102 -0
- package/.aiox-core/product/templates/engine/schemas/dbdr.schema.json +205 -0
- package/.aiox-core/product/templates/engine/schemas/epic.schema.json +175 -0
- package/.aiox-core/product/templates/engine/schemas/pmdr.schema.json +175 -0
- package/.aiox-core/product/templates/engine/schemas/prd-v2.schema.json +300 -0
- package/.aiox-core/product/templates/engine/schemas/prd.schema.json +152 -0
- package/.aiox-core/product/templates/engine/schemas/story.schema.json +222 -0
- package/.aiox-core/product/templates/engine/schemas/task.schema.json +154 -0
- package/.aiox-core/product/templates/engine/validator.js +294 -0
- package/.aiox-core/product/templates/epic.hbs +212 -0
- package/.aiox-core/product/templates/eslintrc-security.json +32 -0
- package/.aiox-core/product/templates/front-end-architecture-tmpl.yaml +206 -0
- package/.aiox-core/product/templates/front-end-spec-tmpl.yaml +349 -0
- package/.aiox-core/product/templates/fullstack-architecture-tmpl.yaml +805 -0
- package/.aiox-core/product/templates/gemini/settings.json +79 -0
- package/.aiox-core/product/templates/github-actions-cd.yml +212 -0
- package/.aiox-core/product/templates/github-actions-ci.yml +172 -0
- package/.aiox-core/product/templates/github-pr-template.md +67 -0
- package/.aiox-core/product/templates/gordon-mcp.yaml +140 -0
- package/.aiox-core/product/templates/ide-rules/antigravity-rules.md +115 -0
- package/.aiox-core/product/templates/ide-rules/claude-rules.md +356 -0
- package/.aiox-core/product/templates/ide-rules/codex-rules.md +65 -0
- package/.aiox-core/product/templates/ide-rules/copilot-rules.md +92 -0
- package/.aiox-core/product/templates/ide-rules/cursor-rules.md +115 -0
- package/.aiox-core/product/templates/ide-rules/gemini-rules.md +87 -0
- package/.aiox-core/product/templates/index-strategy-tmpl.yaml +53 -0
- package/.aiox-core/product/templates/market-research-tmpl.yaml +252 -0
- package/.aiox-core/product/templates/mcp-workflow.js +271 -0
- package/.aiox-core/product/templates/migration-plan-tmpl.yaml +1022 -0
- package/.aiox-core/product/templates/migration-strategy-tmpl.md +524 -0
- package/.aiox-core/product/templates/personalized-agent-template.md +258 -0
- package/.aiox-core/product/templates/personalized-checklist-template.md +340 -0
- package/.aiox-core/product/templates/personalized-task-template-v2.md +905 -0
- package/.aiox-core/product/templates/personalized-task-template.md +344 -0
- package/.aiox-core/product/templates/personalized-template-file.yaml +322 -0
- package/.aiox-core/product/templates/personalized-workflow-template.yaml +460 -0
- package/.aiox-core/product/templates/pmdr.hbs +186 -0
- package/.aiox-core/product/templates/prd-tmpl.yaml +202 -0
- package/.aiox-core/product/templates/prd-v2.0.hbs +216 -0
- package/.aiox-core/product/templates/prd.hbs +201 -0
- package/.aiox-core/product/templates/project-brief-tmpl.yaml +221 -0
- package/.aiox-core/product/templates/qa-gate-tmpl.yaml +240 -0
- package/.aiox-core/product/templates/qa-report-tmpl.md +234 -0
- package/.aiox-core/product/templates/rls-policies-tmpl.yaml +1203 -0
- package/.aiox-core/product/templates/schema-design-tmpl.yaml +428 -0
- package/.aiox-core/product/templates/shock-report-tmpl.html +502 -0
- package/.aiox-core/product/templates/spec-tmpl.md +234 -0
- package/.aiox-core/product/templates/state-persistence-tmpl.yaml +219 -0
- package/.aiox-core/product/templates/statusline/statusline-script.js +188 -0
- package/.aiox-core/product/templates/statusline/track-agent.sh +68 -0
- package/.aiox-core/product/templates/story-tmpl.yaml +368 -0
- package/.aiox-core/product/templates/story.hbs +263 -0
- package/.aiox-core/product/templates/task-execution-report.md +495 -0
- package/.aiox-core/product/templates/task-template.md +123 -0
- package/.aiox-core/product/templates/task.hbs +170 -0
- package/.aiox-core/product/templates/tmpl-comment-on-examples.sql +158 -0
- package/.aiox-core/product/templates/tmpl-migration-script.sql +91 -0
- package/.aiox-core/product/templates/tmpl-rls-granular-policies.sql +104 -0
- package/.aiox-core/product/templates/tmpl-rls-kiss-policy.sql +10 -0
- package/.aiox-core/product/templates/tmpl-rls-roles.sql +135 -0
- package/.aiox-core/product/templates/tmpl-rls-simple.sql +77 -0
- package/.aiox-core/product/templates/tmpl-rls-tenant.sql +152 -0
- package/.aiox-core/product/templates/tmpl-rollback-script.sql +77 -0
- package/.aiox-core/product/templates/tmpl-seed-data.sql +140 -0
- package/.aiox-core/product/templates/tmpl-smoke-test.sql +16 -0
- package/.aiox-core/product/templates/tmpl-staging-copy-merge.sql +139 -0
- package/.aiox-core/product/templates/tmpl-stored-proc.sql +140 -0
- package/.aiox-core/product/templates/tmpl-trigger.sql +152 -0
- package/.aiox-core/product/templates/tmpl-view-materialized.sql +133 -0
- package/.aiox-core/product/templates/tmpl-view.sql +177 -0
- package/.aiox-core/product/templates/token-exports-css-tmpl.css +240 -0
- package/.aiox-core/product/templates/token-exports-tailwind-tmpl.js +395 -0
- package/.aiox-core/product/templates/tokens-schema-tmpl.yaml +305 -0
- package/.aiox-core/product/templates/workflow-template.yaml +151 -0
- package/.aiox-core/project-config.yaml +166 -0
- package/.aiox-core/quality/metrics-collector.js +599 -0
- package/.aiox-core/quality/metrics-hook.js +260 -0
- package/.aiox-core/quality/schemas/quality-metrics.schema.json +233 -0
- package/.aiox-core/quality/seed-metrics.js +336 -0
- package/.aiox-core/schemas/README.md +403 -0
- package/.aiox-core/schemas/agent-v3-schema.json +394 -0
- package/.aiox-core/schemas/squad-design-schema.json +299 -0
- package/.aiox-core/schemas/squad-schema.json +185 -0
- package/.aiox-core/schemas/task-v3-schema.json +353 -0
- package/.aiox-core/schemas/validate-v3-schema.js +430 -0
- package/.aiox-core/scripts/README.md +122 -0
- package/.aiox-core/scripts/aiox-doc-template.md +325 -0
- package/.aiox-core/scripts/batch-migrate-phase1.ps1 +36 -0
- package/.aiox-core/scripts/batch-migrate-phase2.ps1 +88 -0
- package/.aiox-core/scripts/batch-migrate-phase3.ps1 +45 -0
- package/.aiox-core/scripts/command-execution-hook.js +201 -0
- package/.aiox-core/scripts/diagnostics/diagnose-installation.js +274 -0
- package/.aiox-core/scripts/diagnostics/diagnose-npx-issue.ps1 +96 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/README.md +121 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/index.html +13 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/package-lock.json +5261 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/package.json +24 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/public/favicon.svg +10 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/App.jsx +22 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/AutoFixLog.css +122 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/AutoFixLog.jsx +72 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/DomainCard.css +121 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/DomainCard.jsx +116 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/HealthScore.css +80 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/HealthScore.jsx +81 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/IssuesList.css +184 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/IssuesList.jsx +145 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/TechDebtList.css +114 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/TechDebtList.jsx +72 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/index.js +9 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/shared/Card.css +44 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/shared/Card.jsx +25 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/shared/Chart.css +14 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/shared/Chart.jsx +138 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/shared/Header.css +54 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/shared/Header.jsx +21 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/shared/StatusBadge.css +77 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/shared/StatusBadge.jsx +45 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/components/shared/index.js +4 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/hooks/index.js +2 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/hooks/useAutoRefresh.js +89 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/hooks/useHealthData.js +307 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/main.jsx +13 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/pages/Dashboard.css +238 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/pages/Dashboard.jsx +153 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/pages/DomainDetail.css +259 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/pages/DomainDetail.jsx +163 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/pages/index.js +2 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/styles/App.css +19 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/src/styles/index.css +67 -0
- package/.aiox-core/scripts/diagnostics/health-dashboard/vite.config.js +23 -0
- package/.aiox-core/scripts/diagnostics/quick-diagnose.cmd +85 -0
- package/.aiox-core/scripts/diagnostics/quick-diagnose.ps1 +117 -0
- package/.aiox-core/scripts/migrate-framework-docs.sh +300 -0
- package/.aiox-core/scripts/pm.sh +453 -0
- package/.aiox-core/scripts/session-context-loader.js +45 -0
- package/.aiox-core/scripts/test-template-system.js +941 -0
- package/.aiox-core/scripts/update-aiox.sh +174 -0
- package/.aiox-core/scripts/validate-phase1.ps1 +35 -0
- package/.aiox-core/scripts/workflow-management.md +69 -0
- package/.aiox-core/user-guide.md +1409 -0
- package/.aiox-core/utils/aiox-validator.js +25 -0
- package/.aiox-core/utils/filters/constants.js +10 -0
- package/.aiox-core/utils/filters/content-filter.js +223 -0
- package/.aiox-core/utils/filters/field-filter.js +126 -0
- package/.aiox-core/utils/filters/index.js +180 -0
- package/.aiox-core/utils/filters/schema-filter.js +157 -0
- package/.aiox-core/utils/format-duration.js +95 -0
- package/.aiox-core/workflow-intelligence/__tests__/confidence-scorer.test.js +334 -0
- package/.aiox-core/workflow-intelligence/__tests__/integration.test.js +339 -0
- package/.aiox-core/workflow-intelligence/__tests__/suggestion-engine.test.js +437 -0
- package/.aiox-core/workflow-intelligence/__tests__/wave-analyzer.test.js +447 -0
- package/.aiox-core/workflow-intelligence/__tests__/workflow-registry.test.js +302 -0
- package/.aiox-core/workflow-intelligence/engine/confidence-scorer.js +306 -0
- package/.aiox-core/workflow-intelligence/engine/output-formatter.js +299 -0
- package/.aiox-core/workflow-intelligence/engine/suggestion-engine.js +797 -0
- package/.aiox-core/workflow-intelligence/engine/wave-analyzer.js +683 -0
- package/.aiox-core/workflow-intelligence/index.js +329 -0
- package/.aiox-core/workflow-intelligence/learning/capture-hook.js +147 -0
- package/.aiox-core/workflow-intelligence/learning/gotcha-registry.js +653 -0
- package/.aiox-core/workflow-intelligence/learning/index.js +305 -0
- package/.aiox-core/workflow-intelligence/learning/pattern-capture.js +329 -0
- package/.aiox-core/workflow-intelligence/learning/pattern-store.js +497 -0
- package/.aiox-core/workflow-intelligence/learning/pattern-validator.js +309 -0
- package/.aiox-core/workflow-intelligence/learning/qa-feedback.js +585 -0
- package/.aiox-core/workflow-intelligence/learning/semantic-search.js +521 -0
- package/.aiox-core/workflow-intelligence/registry/workflow-registry.js +357 -0
- package/.aiox-core/working-in-the-brownfield.md +361 -0
- package/.claude/CLAUDE.md +378 -0
- package/.claude/hooks/README.md +194 -0
- package/.claude/hooks/enforce-architecture-first.py +196 -0
- package/.claude/hooks/enforce-git-push-authority.sh +33 -0
- package/.claude/hooks/install-hooks.sh +41 -0
- package/.claude/hooks/mind-clone-governance.py +192 -0
- package/.claude/hooks/pre-commit-version-check.sh +156 -0
- package/.claude/hooks/precompact-session-digest.cjs +106 -0
- package/.claude/hooks/precompact-wrapper.cjs +46 -0
- package/.claude/hooks/read-protection.py +151 -0
- package/.claude/hooks/slug-validation.py +176 -0
- package/.claude/hooks/sql-governance.py +182 -0
- package/.claude/hooks/synapse-engine.cjs +113 -0
- package/.claude/hooks/synapse-wrapper.cjs +57 -0
- package/.claude/hooks/write-path-validation.py +194 -0
- package/.claude/rules/agent-authority.md +105 -0
- package/.claude/rules/agent-handoff.md +97 -0
- package/.claude/rules/agent-memory-imports.md +15 -0
- package/.claude/rules/coderabbit-integration.md +101 -0
- package/.claude/rules/ids-principles.md +119 -0
- package/.claude/rules/mcp-usage.md +176 -0
- package/.claude/rules/story-lifecycle.md +145 -0
- package/.claude/rules/tool-examples.md +64 -0
- package/.claude/rules/tool-response-filtering.md +57 -0
- package/.claude/rules/workflow-execution.md +150 -0
- package/LICENSE +33 -0
- package/README.en.md +747 -0
- package/README.md +758 -0
- package/bin/aiox-graph.js +9 -0
- package/bin/aiox-ids.js +558 -0
- package/bin/aiox-init.js +1230 -0
- package/bin/aiox-minimal.js +39 -0
- package/bin/aiox.js +940 -0
- package/bin/modules/env-config.js +434 -0
- package/bin/modules/mcp-installer.js +383 -0
- package/bin/utils/detect-fsmonitor.js +70 -0
- package/bin/utils/framework-guard.js +244 -0
- package/bin/utils/install-errors.js +339 -0
- package/bin/utils/install-transaction.js +445 -0
- package/bin/utils/pro-detector.js +113 -0
- package/bin/utils/validate-publish.js +131 -0
- package/docs/00-shared-activation-pipeline.md +691 -0
- package/docs/CHANGELOG.md +184 -0
- package/docs/FEATURE_PROCESS.md +93 -0
- package/docs/GUIDING-PRINCIPLES.md +95 -0
- package/docs/README.md +132 -0
- package/docs/aiox-agent-flows/README.md +190 -0
- package/docs/aiox-agent-flows/aiox-master-system.md +575 -0
- package/docs/aiox-agent-flows/analyst-system.md +673 -0
- package/docs/aiox-agent-flows/architect-system.md +735 -0
- package/docs/aiox-agent-flows/data-engineer-system.md +801 -0
- package/docs/aiox-agent-flows/dev-system.md +579 -0
- package/docs/aiox-agent-flows/devops-system.md +637 -0
- package/docs/aiox-agent-flows/pm-system.md +727 -0
- package/docs/aiox-agent-flows/qa-system.md +654 -0
- package/docs/aiox-agent-flows/sm-system.md +495 -0
- package/docs/aiox-agent-flows/squad-creator-system.md +698 -0
- package/docs/aiox-agent-flows/ux-design-expert-system.md +834 -0
- package/docs/aiox-workflows/README.md +247 -0
- package/docs/aiox-workflows/auto-worktree-workflow.md +789 -0
- package/docs/aiox-workflows/brownfield-discovery-workflow.md +921 -0
- package/docs/aiox-workflows/brownfield-fullstack-workflow.md +838 -0
- package/docs/aiox-workflows/brownfield-service-workflow.md +812 -0
- package/docs/aiox-workflows/brownfield-ui-workflow.md +891 -0
- package/docs/aiox-workflows/design-system-build-quality-workflow.md +845 -0
- package/docs/aiox-workflows/greenfield-fullstack-workflow.md +796 -0
- package/docs/aiox-workflows/greenfield-service-workflow.md +784 -0
- package/docs/aiox-workflows/greenfield-ui-workflow.md +922 -0
- package/docs/aiox-workflows/qa-loop-workflow.md +1111 -0
- package/docs/aiox-workflows/spec-pipeline-workflow.md +1031 -0
- package/docs/aiox-workflows/story-development-cycle-workflow.md +843 -0
- package/docs/codex-integration-process.md +170 -0
- package/docs/community/README-community-snippet-core.md +57 -0
- package/docs/community/README-community-snippet-mcp.md +49 -0
- package/docs/community/README-community-snippet-squads.md +40 -0
- package/docs/community.md +227 -0
- package/docs/core-architecture.md +223 -0
- package/docs/docker-mcp-setup.md +426 -0
- package/docs/en/aiox-agent-flows/README.md +190 -0
- package/docs/en/aiox-agent-flows/aiox-master-system.md +26 -0
- package/docs/en/aiox-agent-flows/analyst-system.md +26 -0
- package/docs/en/aiox-agent-flows/architect-system.md +26 -0
- package/docs/en/aiox-agent-flows/data-engineer-system.md +26 -0
- package/docs/en/aiox-agent-flows/dev-system.md +26 -0
- package/docs/en/aiox-agent-flows/devops-system.md +26 -0
- package/docs/en/aiox-agent-flows/pm-system.md +26 -0
- package/docs/en/aiox-agent-flows/qa-system.md +26 -0
- package/docs/en/aiox-agent-flows/sm-system.md +26 -0
- package/docs/en/aiox-agent-flows/squad-creator-system.md +26 -0
- package/docs/en/aiox-agent-flows/ux-design-expert-system.md +26 -0
- package/docs/en/aiox-workflows/README.md +247 -0
- package/docs/en/aiox-workflows/auto-worktree-workflow.md +62 -0
- package/docs/en/aiox-workflows/brownfield-discovery-workflow.md +50 -0
- package/docs/en/aiox-workflows/brownfield-fullstack-workflow.md +50 -0
- package/docs/en/aiox-workflows/brownfield-service-workflow.md +51 -0
- package/docs/en/aiox-workflows/brownfield-ui-workflow.md +51 -0
- package/docs/en/aiox-workflows/design-system-build-quality-workflow.md +53 -0
- package/docs/en/aiox-workflows/greenfield-fullstack-workflow.md +45 -0
- package/docs/en/aiox-workflows/greenfield-service-workflow.md +45 -0
- package/docs/en/aiox-workflows/greenfield-ui-workflow.md +45 -0
- package/docs/en/aiox-workflows/qa-loop-workflow.md +50 -0
- package/docs/en/aiox-workflows/spec-pipeline-workflow.md +48 -0
- package/docs/en/aiox-workflows/story-development-cycle-workflow.md +50 -0
- package/docs/es/CHANGELOG.md +117 -0
- package/docs/es/DOCUMENTATION-ROADMAP.md +216 -0
- package/docs/es/ENVIRONMENT.md +140 -0
- package/docs/es/FEATURE_PROCESS.md +99 -0
- package/docs/es/GUIDING-PRINCIPLES.md +101 -0
- package/docs/es/README.md +134 -0
- package/docs/es/agent-reference-guide.md +570 -0
- package/docs/es/agents/archetype-rationale.md +566 -0
- package/docs/es/agents/persona-definitions.md +501 -0
- package/docs/es/aiox-agent-flows/README.md +190 -0
- package/docs/es/aiox-agent-flows/aiox-master-system.md +36 -0
- package/docs/es/aiox-agent-flows/analyst-system.md +36 -0
- package/docs/es/aiox-agent-flows/architect-system.md +36 -0
- package/docs/es/aiox-agent-flows/data-engineer-system.md +36 -0
- package/docs/es/aiox-agent-flows/dev-system.md +36 -0
- package/docs/es/aiox-agent-flows/devops-system.md +36 -0
- package/docs/es/aiox-agent-flows/pm-system.md +36 -0
- package/docs/es/aiox-agent-flows/qa-system.md +36 -0
- package/docs/es/aiox-agent-flows/sm-system.md +36 -0
- package/docs/es/aiox-agent-flows/squad-creator-system.md +36 -0
- package/docs/es/aiox-agent-flows/ux-design-expert-system.md +36 -0
- package/docs/es/aiox-nomenclature-specification.md +673 -0
- package/docs/es/aiox-workflows/README.md +247 -0
- package/docs/es/aiox-workflows/auto-worktree-workflow.md +39 -0
- package/docs/es/aiox-workflows/brownfield-discovery-workflow.md +41 -0
- package/docs/es/aiox-workflows/brownfield-fullstack-workflow.md +42 -0
- package/docs/es/aiox-workflows/brownfield-service-workflow.md +43 -0
- package/docs/es/aiox-workflows/brownfield-ui-workflow.md +42 -0
- package/docs/es/aiox-workflows/design-system-build-quality-workflow.md +40 -0
- package/docs/es/aiox-workflows/greenfield-fullstack-workflow.md +44 -0
- package/docs/es/aiox-workflows/greenfield-service-workflow.md +43 -0
- package/docs/es/aiox-workflows/greenfield-ui-workflow.md +43 -0
- package/docs/es/aiox-workflows/qa-loop-workflow.md +39 -0
- package/docs/es/aiox-workflows/spec-pipeline-workflow.md +40 -0
- package/docs/es/aiox-workflows/story-development-cycle-workflow.md +42 -0
- package/docs/es/api/squads-api.md +753 -0
- package/docs/es/architecture/ADE-AGENT-CHANGES.md +469 -0
- package/docs/es/architecture/ADE-ARCHITECT-HANDOFF.md +338 -0
- package/docs/es/architecture/ADE-EPIC1-HANDOFF.md +85 -0
- package/docs/es/architecture/ADE-EPIC2-HANDOFF.md +106 -0
- package/docs/es/architecture/ADE-EPIC3-HANDOFF.md +327 -0
- package/docs/es/architecture/ARCHITECTURE-INDEX.md +188 -0
- package/docs/es/architecture/ade-architecture.md +586 -0
- package/docs/es/architecture/adr/ADR-COLLAB-1-current-state-audit.md +259 -0
- package/docs/es/architecture/adr/ADR-COLLAB-2-proposed-configuration.md +518 -0
- package/docs/es/architecture/adr/adr-hcs-health-check-system.md +489 -0
- package/docs/es/architecture/adr/adr-isolated-vm-decision.md +70 -0
- package/docs/es/architecture/agent-config-audit.md +222 -0
- package/docs/es/architecture/agent-responsibility-matrix.md +444 -0
- package/docs/es/architecture/agent-tool-integration-guide.md +334 -0
- package/docs/es/architecture/ci-cd.md +151 -0
- package/docs/es/architecture/coding-standards.md +896 -0
- package/docs/es/architecture/contribution-workflow-research.md +376 -0
- package/docs/es/architecture/dashboard-architecture.md +926 -0
- package/docs/es/architecture/dashboard-realtime.md +1253 -0
- package/docs/es/architecture/hcs-check-specifications.md +897 -0
- package/docs/es/architecture/hcs-execution-modes.md +519 -0
- package/docs/es/architecture/hcs-self-healing-spec.md +695 -0
- package/docs/es/architecture/high-level-architecture.md +357 -0
- package/docs/es/architecture/introduction.md +21 -0
- package/docs/es/architecture/mcp-api-keys-management.md +246 -0
- package/docs/es/architecture/mcp-system-diagrams.md +113 -0
- package/docs/es/architecture/module-system.md +382 -0
- package/docs/es/architecture/multi-repo-strategy.md +390 -0
- package/docs/es/architecture/source-tree.md +710 -0
- package/docs/es/architecture/squad-improvement-analysis.md +204 -0
- package/docs/es/architecture/squad-improvement-recommended-approach.md +390 -0
- package/docs/es/architecture/tech-stack.md +806 -0
- package/docs/es/architecture/utility-integration-guide.md +358 -0
- package/docs/es/community/README-community-snippet-core.md +57 -0
- package/docs/es/community/README-community-snippet-mcp.md +49 -0
- package/docs/es/community/README-community-snippet-squads.md +40 -0
- package/docs/es/community.md +227 -0
- package/docs/es/core-architecture.md +229 -0
- package/docs/es/docker-mcp-setup.md +426 -0
- package/docs/es/framework/README.md +99 -0
- package/docs/es/framework/coding-standards.md +892 -0
- package/docs/es/framework/source-tree.md +727 -0
- package/docs/es/framework/tech-stack.md +802 -0
- package/docs/es/getting-started.md +572 -0
- package/docs/es/git-workflow-guide.md +995 -0
- package/docs/es/guides/README.md +133 -0
- package/docs/es/guides/ade-guide.md +452 -0
- package/docs/es/guides/agent-selection-guide.md +295 -0
- package/docs/es/guides/api-reference.md +899 -0
- package/docs/es/guides/build-recovery-guide.md +270 -0
- package/docs/es/guides/contextual-greeting-system-guide.md +387 -0
- package/docs/es/guides/contributing-squads.md +256 -0
- package/docs/es/guides/development-setup.md +1111 -0
- package/docs/es/guides/ide-sync-guide.md +194 -0
- package/docs/es/guides/installation-troubleshooting.md +327 -0
- package/docs/es/guides/llm-routing.md +312 -0
- package/docs/es/guides/mcp/desktop-commander.md +368 -0
- package/docs/es/guides/mcp/docker-gateway-tutorial.md +336 -0
- package/docs/es/guides/mcp-global-setup.md +663 -0
- package/docs/es/guides/permission-modes.md +313 -0
- package/docs/es/guides/project-status-feature.md +473 -0
- package/docs/es/guides/quality-dashboard.md +367 -0
- package/docs/es/guides/quality-gates.md +614 -0
- package/docs/es/guides/security-hardening.md +1359 -0
- package/docs/es/guides/service-discovery.md +524 -0
- package/docs/es/guides/squad-examples/README.md +64 -0
- package/docs/es/guides/squad-migration.md +356 -0
- package/docs/es/guides/squads-guide.md +836 -0
- package/docs/es/guides/squads-overview.md +332 -0
- package/docs/es/guides/template-engine-v2.md +484 -0
- package/docs/es/guides/testing-guide.md +1215 -0
- package/docs/es/guides/user-guide.md +452 -0
- package/docs/es/guides/workflows-guide.md +400 -0
- package/docs/es/how-to-contribute-with-pull-requests.md +160 -0
- package/docs/es/ide-integration.md +425 -0
- package/docs/es/installation/README.md +108 -0
- package/docs/es/installation/faq.md +616 -0
- package/docs/es/installation/linux.md +311 -0
- package/docs/es/installation/macos.md +189 -0
- package/docs/es/installation/troubleshooting.md +735 -0
- package/docs/es/installation/v4-quick-start.md +269 -0
- package/docs/es/installation/windows.md +342 -0
- package/docs/es/meta-agent-commands.md +990 -0
- package/docs/es/migration-guide.md +310 -0
- package/docs/es/npx-install.md +193 -0
- package/docs/es/performance-tuning-guide.md +707 -0
- package/docs/es/platforms/README.md +283 -0
- package/docs/es/platforms/antigravity.md +510 -0
- package/docs/es/platforms/claude-code.md +650 -0
- package/docs/es/platforms/cursor.md +635 -0
- package/docs/es/platforms/gemini-cli.md +483 -0
- package/docs/es/platforms/github-copilot.md +480 -0
- package/docs/es/roadmap.md +119 -0
- package/docs/es/security-best-practices.md +613 -0
- package/docs/es/security.md +124 -0
- package/docs/es/specifications/docs-agent-technical-specification.md +2161 -0
- package/docs/es/troubleshooting.md +887 -0
- package/docs/es/uninstallation.md +556 -0
- package/docs/es/versioning-and-releases.md +146 -0
- package/docs/examples/squads/basic-squad/README.md +46 -0
- package/docs/examples/squads/basic-squad/agents/greeter-agent.md +38 -0
- package/docs/examples/squads/basic-squad/squad.yaml +38 -0
- package/docs/examples/squads/basic-squad/tasks/greet-user.md +51 -0
- package/docs/examples/squads/multi-agent-squad/README.md +59 -0
- package/docs/examples/squads/multi-agent-squad/agents/lead-agent.md +45 -0
- package/docs/examples/squads/multi-agent-squad/agents/researcher-agent.md +41 -0
- package/docs/examples/squads/multi-agent-squad/agents/writer-agent.md +40 -0
- package/docs/examples/squads/multi-agent-squad/squad.yaml +42 -0
- package/docs/examples/squads/multi-agent-squad/tasks/research-topic.md +53 -0
- package/docs/examples/squads/multi-agent-squad/tasks/write-report.md +56 -0
- package/docs/examples/squads/squad-with-tools/README.md +51 -0
- package/docs/examples/squads/squad-with-tools/agents/analyzer-agent.md +38 -0
- package/docs/examples/squads/squad-with-tools/squad.yaml +38 -0
- package/docs/examples/squads/squad-with-tools/tools/text-analyzer.js +84 -0
- package/docs/framework/README.md +95 -0
- package/docs/framework/coding-standards.md +884 -0
- package/docs/framework/config-override-guide.md +193 -0
- package/docs/framework/entity-layer-classification.md +74 -0
- package/docs/framework/memory-lifecycle.md +99 -0
- package/docs/framework/performance-tips.md +76 -0
- package/docs/framework/source-tree.md +888 -0
- package/docs/framework/tech-stack.md +794 -0
- package/docs/getting-started.md +311 -0
- package/docs/git-workflow-guide.md +989 -0
- package/docs/glossary.md +26 -0
- package/docs/guides/IDS-CONCEITOS-EXPLICADOS.md +711 -0
- package/docs/guides/MEMORY-INTEGRATION.md +491 -0
- package/docs/guides/MEMORY-INTELLIGENCE-SYSTEM.md +1077 -0
- package/docs/guides/MEMORY-SYSTEM.md +1002 -0
- package/docs/guides/README.md +127 -0
- package/docs/guides/ade-guide.md +446 -0
- package/docs/guides/agent-selection-guide.md +289 -0
- package/docs/guides/agents/AIOX-AGENT-FLOWS.zip +0 -0
- package/docs/guides/agents/AIOX-MASTER-SYSTEM.md +575 -0
- package/docs/guides/agents/ANALYST-SYSTEM.md +673 -0
- package/docs/guides/agents/ARCHITECT-SYSTEM.md +735 -0
- package/docs/guides/agents/DATA-ENGINEER-SYSTEM.md +801 -0
- package/docs/guides/agents/DEV-SYSTEM.md +579 -0
- package/docs/guides/agents/DEVOPS-SYSTEM.md +637 -0
- package/docs/guides/agents/PM-SYSTEM.md +727 -0
- package/docs/guides/agents/QA-SYSTEM.md +654 -0
- package/docs/guides/agents/SM-SYSTEM.md +495 -0
- package/docs/guides/agents/SQUAD-CREATOR-SYSTEM.md +698 -0
- package/docs/guides/agents/UX-DESIGN-EXPERT-SYSTEM.md +834 -0
- package/docs/guides/agents/traces/00-shared-activation-pipeline.md +691 -0
- package/docs/guides/agents/traces/00-shared-activation-pipeline.v1-act8.md +691 -0
- package/docs/guides/agents/traces/README.md +256 -0
- package/docs/guides/agents/traces/aiox-master-execution-trace.md +1017 -0
- package/docs/guides/agents/traces/analyst-execution-trace.md +538 -0
- package/docs/guides/agents/traces/architect-execution-trace.md +573 -0
- package/docs/guides/agents/traces/data-engineer-execution-trace.md +1054 -0
- package/docs/guides/agents/traces/dev-execution-trace.md +711 -0
- package/docs/guides/agents/traces/devops-execution-trace.md +764 -0
- package/docs/guides/agents/traces/execution-traces.zip +0 -0
- package/docs/guides/agents/traces/pm-execution-trace.md +532 -0
- package/docs/guides/agents/traces/po-execution-trace.md +600 -0
- package/docs/guides/agents/traces/qa-execution-trace.md +847 -0
- package/docs/guides/agents/traces/sm-execution-trace.md +361 -0
- package/docs/guides/agents/traces/squad-creation-execution-trace.md +741 -0
- package/docs/guides/agents/traces/ux-design-expert-execution-trace.md +996 -0
- package/docs/guides/api-reference.md +899 -0
- package/docs/guides/build-recovery-guide.md +264 -0
- package/docs/guides/code-graph-mcp-setup.md +194 -0
- package/docs/guides/coderabbit/README.md +406 -0
- package/docs/guides/config-migration-guide.md +193 -0
- package/docs/guides/contextual-greeting-system-guide.md +381 -0
- package/docs/guides/contributing-squads.md +250 -0
- package/docs/guides/development-setup.md +1114 -0
- package/docs/guides/ide-sync-guide.md +188 -0
- package/docs/guides/installation-troubleshooting.md +321 -0
- package/docs/guides/llm-routing.md +306 -0
- package/docs/guides/mcp/desktop-commander.md +368 -0
- package/docs/guides/mcp/docker-gateway-tutorial.md +336 -0
- package/docs/guides/mcp-global-setup.md +696 -0
- package/docs/guides/permission-modes.md +307 -0
- package/docs/guides/pro/install-gate-setup.md +205 -0
- package/docs/guides/project-status-feature.md +467 -0
- package/docs/guides/quality-dashboard.md +361 -0
- package/docs/guides/quality-gates.md +608 -0
- package/docs/guides/security-hardening.md +1359 -0
- package/docs/guides/service-discovery.md +518 -0
- package/docs/guides/squad-examples/README.md +63 -0
- package/docs/guides/squad-examples/data-processor-squad.yaml +47 -0
- package/docs/guides/squad-examples/simple-agent.yaml +39 -0
- package/docs/guides/squad-migration.md +336 -0
- package/docs/guides/squads-guide.md +827 -0
- package/docs/guides/squads-overview.md +326 -0
- package/docs/guides/template-engine-v2.md +478 -0
- package/docs/guides/testing-guide.md +1215 -0
- package/docs/guides/user-guide.md +487 -0
- package/docs/guides/vertical-trails/data-engineer-trail.md +316 -0
- package/docs/guides/vertical-trails/devops-trail.md +385 -0
- package/docs/guides/vertical-trails/squad-creator-trail.md +416 -0
- package/docs/guides/workflows/AIOX-COMPLETE-CROSS-REFERENCE-ANALYSIS.md +766 -0
- package/docs/guides/workflows/AIOX-WORKFLOWS.zip +0 -0
- package/docs/guides/workflows/AUTO-WORKTREE-WORKFLOW.md +789 -0
- package/docs/guides/workflows/BROWNFIELD-DISCOVERY-WORKFLOW.md +921 -0
- package/docs/guides/workflows/BROWNFIELD-FULLSTACK-WORKFLOW.md +838 -0
- package/docs/guides/workflows/BROWNFIELD-SERVICE-WORKFLOW.md +812 -0
- package/docs/guides/workflows/BROWNFIELD-UI-WORKFLOW.md +891 -0
- package/docs/guides/workflows/DESIGN-SYSTEM-BUILD-QUALITY-WORKFLOW.md +845 -0
- package/docs/guides/workflows/GREENFIELD-FULLSTACK-WORKFLOW.md +796 -0
- package/docs/guides/workflows/GREENFIELD-SERVICE-WORKFLOW.md +784 -0
- package/docs/guides/workflows/GREENFIELD-UI-WORKFLOW.md +922 -0
- package/docs/guides/workflows/QA-LOOP-WORKFLOW.md +1111 -0
- package/docs/guides/workflows/SPEC-PIPELINE-WORKFLOW.md +1031 -0
- package/docs/guides/workflows/STORY-DEVELOPMENT-CYCLE-WORKFLOW.md +843 -0
- package/docs/guides/workflows/WORKFLOW-TASK-AGENT-ANALYSIS.md +1176 -0
- package/docs/guides/workflows/pro-developer-workflow.md +236 -0
- package/docs/guides/workflows/xref-phase2-templates.md +469 -0
- package/docs/guides/workflows/xref-phase3-scripts.md +509 -0
- package/docs/guides/workflows/xref-phase4-infra.md +431 -0
- package/docs/guides/workflows/xref-phase5-core.md +487 -0
- package/docs/guides/workflows/xref-phase6-supporting.md +702 -0
- package/docs/guides/workflows-guide.md +408 -0
- package/docs/how-to-contribute-with-pull-requests.md +158 -0
- package/docs/ide-integration.md +478 -0
- package/docs/installation/README.md +100 -0
- package/docs/installation/faq.md +608 -0
- package/docs/installation/linux.md +448 -0
- package/docs/installation/macos.md +181 -0
- package/docs/installation/troubleshooting.md +727 -0
- package/docs/installation/v4-quick-start.md +267 -0
- package/docs/installation/windows.md +477 -0
- package/docs/legal/license-clarification.md +26 -0
- package/docs/legal/privacy.md +127 -0
- package/docs/legal/terms.md +163 -0
- package/docs/meta-agent-commands.md +984 -0
- package/docs/npx-install.md +187 -0
- package/docs/prd-cli-graph-dashboard.md +274 -0
- package/docs/pt/CHANGELOG.md +117 -0
- package/docs/pt/DOCUMENTATION-ROADMAP.md +216 -0
- package/docs/pt/ENVIRONMENT.md +140 -0
- package/docs/pt/FEATURE_PROCESS.md +99 -0
- package/docs/pt/GUIDING-PRINCIPLES.md +101 -0
- package/docs/pt/README.md +134 -0
- package/docs/pt/agent-reference-guide.md +570 -0
- package/docs/pt/agents/archetype-rationale.md +566 -0
- package/docs/pt/agents/persona-definitions.md +501 -0
- package/docs/pt/aiox-nomenclature-specification.md +673 -0
- package/docs/pt/api/squads-api.md +753 -0
- package/docs/pt/architecture/ADE-ARCHITECT-HANDOFF.md +338 -0
- package/docs/pt/architecture/ADE-EPIC1-HANDOFF.md +85 -0
- package/docs/pt/architecture/ADE-EPIC2-HANDOFF.md +106 -0
- package/docs/pt/architecture/ADE-EPIC3-HANDOFF.md +327 -0
- package/docs/pt/architecture/ARCHITECTURE-INDEX.md +188 -0
- package/docs/pt/architecture/ade-architecture.md +587 -0
- package/docs/pt/architecture/adr/ADR-COLLAB-1-current-state-audit.md +259 -0
- package/docs/pt/architecture/adr/ADR-COLLAB-2-proposed-configuration.md +518 -0
- package/docs/pt/architecture/adr/adr-hcs-health-check-system.md +489 -0
- package/docs/pt/architecture/adr/adr-isolated-vm-decision.md +70 -0
- package/docs/pt/architecture/agent-config-audit.md +222 -0
- package/docs/pt/architecture/agent-responsibility-matrix.md +444 -0
- package/docs/pt/architecture/agent-tool-integration-guide.md +334 -0
- package/docs/pt/architecture/ci-cd.md +151 -0
- package/docs/pt/architecture/coding-standards.md +898 -0
- package/docs/pt/architecture/contribution-workflow-research.md +376 -0
- package/docs/pt/architecture/dashboard-architecture.md +928 -0
- package/docs/pt/architecture/dashboard-realtime.md +1253 -0
- package/docs/pt/architecture/hcs-check-specifications.md +898 -0
- package/docs/pt/architecture/hcs-execution-modes.md +519 -0
- package/docs/pt/architecture/hcs-self-healing-spec.md +695 -0
- package/docs/pt/architecture/high-level-architecture.md +357 -0
- package/docs/pt/architecture/introduction.md +21 -0
- package/docs/pt/architecture/mcp-api-keys-management.md +246 -0
- package/docs/pt/architecture/mcp-system-diagrams.md +113 -0
- package/docs/pt/architecture/module-system.md +382 -0
- package/docs/pt/architecture/multi-repo-strategy.md +386 -0
- package/docs/pt/architecture/source-tree.md +712 -0
- package/docs/pt/architecture/squad-improvement-analysis.md +204 -0
- package/docs/pt/architecture/squad-improvement-recommended-approach.md +390 -0
- package/docs/pt/architecture/tech-stack.md +808 -0
- package/docs/pt/architecture/utility-integration-guide.md +358 -0
- package/docs/pt/code-of-conduct.md +88 -0
- package/docs/pt/community/README-community-snippet-core.md +57 -0
- package/docs/pt/community/README-community-snippet-mcp.md +49 -0
- package/docs/pt/community/README-community-snippet-squads.md +40 -0
- package/docs/pt/community.md +227 -0
- package/docs/pt/contributing.md +541 -0
- package/docs/pt/core-architecture.md +229 -0
- package/docs/pt/docker-mcp-setup.md +426 -0
- package/docs/pt/framework/README.md +99 -0
- package/docs/pt/framework/coding-standards.md +892 -0
- package/docs/pt/framework/source-tree.md +727 -0
- package/docs/pt/framework/tech-stack.md +802 -0
- package/docs/pt/getting-started.md +572 -0
- package/docs/pt/git-workflow-guide.md +996 -0
- package/docs/pt/guides/README.md +133 -0
- package/docs/pt/guides/ade-guide.md +452 -0
- package/docs/pt/guides/agent-selection-guide.md +295 -0
- package/docs/pt/guides/api-reference.md +899 -0
- package/docs/pt/guides/build-recovery-guide.md +270 -0
- package/docs/pt/guides/contextual-greeting-system-guide.md +387 -0
- package/docs/pt/guides/contributing-squads.md +256 -0
- package/docs/pt/guides/development-setup.md +1114 -0
- package/docs/pt/guides/ide-sync-guide.md +194 -0
- package/docs/pt/guides/installation-troubleshooting.md +327 -0
- package/docs/pt/guides/llm-routing.md +312 -0
- package/docs/pt/guides/mcp/desktop-commander.md +368 -0
- package/docs/pt/guides/mcp/docker-gateway-tutorial.md +336 -0
- package/docs/pt/guides/mcp-global-setup.md +663 -0
- package/docs/pt/guides/permission-modes.md +313 -0
- package/docs/pt/guides/project-status-feature.md +473 -0
- package/docs/pt/guides/quality-dashboard.md +367 -0
- package/docs/pt/guides/quality-gates.md +614 -0
- package/docs/pt/guides/security-hardening.md +1359 -0
- package/docs/pt/guides/service-discovery.md +524 -0
- package/docs/pt/guides/squad-examples/README.md +64 -0
- package/docs/pt/guides/squad-migration.md +356 -0
- package/docs/pt/guides/squads-guide.md +836 -0
- package/docs/pt/guides/squads-overview.md +332 -0
- package/docs/pt/guides/template-engine-v2.md +484 -0
- package/docs/pt/guides/testing-guide.md +1215 -0
- package/docs/pt/guides/user-guide.md +452 -0
- package/docs/pt/guides/workflows-guide.md +400 -0
- package/docs/pt/how-to-contribute-with-pull-requests.md +160 -0
- package/docs/pt/ide-integration.md +425 -0
- package/docs/pt/installation/README.md +108 -0
- package/docs/pt/installation/faq.md +616 -0
- package/docs/pt/installation/linux.md +311 -0
- package/docs/pt/installation/macos.md +189 -0
- package/docs/pt/installation/troubleshooting.md +735 -0
- package/docs/pt/installation/v4-quick-start.md +269 -0
- package/docs/pt/installation/windows.md +342 -0
- package/docs/pt/meta-agent-commands.md +990 -0
- package/docs/pt/migration-guide.md +310 -0
- package/docs/pt/npx-install.md +193 -0
- package/docs/pt/performance-tuning-guide.md +707 -0
- package/docs/pt/platforms/antigravity.md +508 -0
- package/docs/pt/platforms/claude-code.md +648 -0
- package/docs/pt/platforms/cursor.md +633 -0
- package/docs/pt/platforms/gemini-cli.md +481 -0
- package/docs/pt/platforms/github-copilot.md +478 -0
- package/docs/pt/roadmap.md +119 -0
- package/docs/pt/security-best-practices.md +613 -0
- package/docs/pt/security.md +124 -0
- package/docs/pt/specifications/docs-agent-technical-specification.md +2161 -0
- package/docs/pt/troubleshooting.md +887 -0
- package/docs/pt/uninstallation.md +556 -0
- package/docs/pt/versioning-and-releases.md +146 -0
- package/docs/roadmap.md +137 -0
- package/docs/security/MANIFEST_SIGNING.md +301 -0
- package/docs/security/PR_SECURITY_CHECKLIST.md +164 -0
- package/docs/security-best-practices.md +607 -0
- package/docs/security.md +124 -0
- package/docs/troubleshooting.md +881 -0
- package/docs/uninstallation.md +550 -0
- package/docs/versioning-and-releases.md +140 -0
- package/docs/zh/CHANGELOG.md +191 -0
- package/docs/zh/ENVIRONMENT.md +136 -0
- package/docs/zh/FEATURE_PROCESS.md +92 -0
- package/docs/zh/GLOSSARY.md +179 -0
- package/docs/zh/GUIDING-PRINCIPLES.md +97 -0
- package/docs/zh/README.md +133 -0
- package/docs/zh/TRANSLATION-PLAN.md +508 -0
- package/docs/zh/agent-reference-guide.md +566 -0
- package/docs/zh/agents/archetype-rationale.md +631 -0
- package/docs/zh/agents/persona-definitions.md +560 -0
- package/docs/zh/aiox-agent-flows/README.md +196 -0
- package/docs/zh/aiox-agent-flows/aiox-master-system.md +81 -0
- package/docs/zh/aiox-agent-flows/analyst-system.md +679 -0
- package/docs/zh/aiox-agent-flows/architect-system.md +246 -0
- package/docs/zh/aiox-agent-flows/data-engineer-system.md +418 -0
- package/docs/zh/aiox-agent-flows/dev-system.md +209 -0
- package/docs/zh/aiox-agent-flows/devops-system.md +643 -0
- package/docs/zh/aiox-agent-flows/pm-system.md +733 -0
- package/docs/zh/aiox-agent-flows/qa-system.md +268 -0
- package/docs/zh/aiox-agent-flows/sm-system.md +501 -0
- package/docs/zh/aiox-agent-flows/squad-creator-system.md +704 -0
- package/docs/zh/aiox-agent-flows/ux-design-expert-system.md +160 -0
- package/docs/zh/aiox-workflows/README.md +247 -0
- package/docs/zh/aiox-workflows/auto-worktree-workflow.md +793 -0
- package/docs/zh/aiox-workflows/brownfield-discovery-workflow.md +915 -0
- package/docs/zh/aiox-workflows/brownfield-fullstack-workflow.md +764 -0
- package/docs/zh/aiox-workflows/brownfield-service-workflow.md +812 -0
- package/docs/zh/aiox-workflows/brownfield-ui-workflow.md +891 -0
- package/docs/zh/aiox-workflows/design-system-build-quality-workflow.md +845 -0
- package/docs/zh/aiox-workflows/greenfield-fullstack-workflow.md +796 -0
- package/docs/zh/aiox-workflows/greenfield-service-workflow.md +786 -0
- package/docs/zh/aiox-workflows/greenfield-ui-workflow.md +922 -0
- package/docs/zh/aiox-workflows/qa-loop-workflow.md +1111 -0
- package/docs/zh/aiox-workflows/spec-pipeline-workflow.md +1031 -0
- package/docs/zh/aiox-workflows/story-development-cycle-workflow.md +843 -0
- package/docs/zh/api/squads-api.md +753 -0
- package/docs/zh/architecture/ADE-ARCHITECT-HANDOFF.md +338 -0
- package/docs/zh/architecture/ADE-EPIC1-HANDOFF.md +85 -0
- package/docs/zh/architecture/ADE-EPIC2-HANDOFF.md +106 -0
- package/docs/zh/architecture/ADE-EPIC3-HANDOFF.md +327 -0
- package/docs/zh/architecture/AIOX-VISUAL-OVERVIEW.md +595 -0
- package/docs/zh/architecture/ARCHITECTURE-INDEX.md +190 -0
- package/docs/zh/architecture/ade-architecture.md +474 -0
- package/docs/zh/architecture/adr/ADR-COLLAB-1-current-state-audit.md +259 -0
- package/docs/zh/architecture/adr/ADR-COLLAB-2-proposed-configuration.md +518 -0
- package/docs/zh/architecture/adr/adr-hcs-health-check-system.md +489 -0
- package/docs/zh/architecture/adr/adr-isolated-vm-decision.md +70 -0
- package/docs/zh/architecture/agent-config-audit.md +220 -0
- package/docs/zh/architecture/agent-responsibility-matrix.md +444 -0
- package/docs/zh/architecture/agent-tool-integration-guide.md +336 -0
- package/docs/zh/architecture/ci-cd.md +151 -0
- package/docs/zh/architecture/coding-standards.md +898 -0
- package/docs/zh/architecture/command-authority-matrix.md +18 -0
- package/docs/zh/architecture/contribution-workflow-research.md +376 -0
- package/docs/zh/architecture/dashboard-architecture.md +569 -0
- package/docs/zh/architecture/dashboard-realtime.md +415 -0
- package/docs/zh/architecture/hcs-check-specifications.md +102 -0
- package/docs/zh/architecture/hcs-execution-modes.md +114 -0
- package/docs/zh/architecture/hcs-self-healing-spec.md +148 -0
- package/docs/zh/architecture/high-level-architecture.md +355 -0
- package/docs/zh/architecture/introduction.md +21 -0
- package/docs/zh/architecture/mcp-api-keys-management.md +248 -0
- package/docs/zh/architecture/mcp-system-diagrams.md +113 -0
- package/docs/zh/architecture/module-system.md +382 -0
- package/docs/zh/architecture/multi-repo-strategy.md +237 -0
- package/docs/zh/architecture/source-tree.md +712 -0
- package/docs/zh/architecture/squad-improvement-analysis.md +204 -0
- package/docs/zh/architecture/squad-improvement-recommended-approach.md +390 -0
- package/docs/zh/architecture/tech-stack.md +808 -0
- package/docs/zh/architecture/utility-integration-guide.md +358 -0
- package/docs/zh/code-of-conduct.md +113 -0
- package/docs/zh/community/README-community-snippet-core.md +57 -0
- package/docs/zh/community/README-community-snippet-mcp.md +49 -0
- package/docs/zh/community/README-community-snippet-squads.md +40 -0
- package/docs/zh/community.md +227 -0
- package/docs/zh/contributing.md +581 -0
- package/docs/zh/core-architecture.md +229 -0
- package/docs/zh/docker-mcp-setup.md +226 -0
- package/docs/zh/framework/README.md +97 -0
- package/docs/zh/framework/coding-standards.md +886 -0
- package/docs/zh/framework/source-tree.md +890 -0
- package/docs/zh/framework/tech-stack.md +796 -0
- package/docs/zh/getting-started.md +317 -0
- package/docs/zh/git-workflow-guide.md +988 -0
- package/docs/zh/guides/MEMORY-INTEGRATION.md +497 -0
- package/docs/zh/guides/MEMORY-INTELLIGENCE-SYSTEM.md +1083 -0
- package/docs/zh/guides/MEMORY-SYSTEM.md +1007 -0
- package/docs/zh/guides/README.md +127 -0
- package/docs/zh/guides/ade-guide.md +446 -0
- package/docs/zh/guides/agent-selection-guide.md +289 -0
- package/docs/zh/guides/api-reference.md +427 -0
- package/docs/zh/guides/build-recovery-guide.md +266 -0
- package/docs/zh/guides/contextual-greeting-system-guide.md +381 -0
- package/docs/zh/guides/contributing-squads.md +250 -0
- package/docs/zh/guides/development-setup.md +384 -0
- package/docs/zh/guides/ide-sync-guide.md +193 -0
- package/docs/zh/guides/installation-troubleshooting.md +321 -0
- package/docs/zh/guides/llm-routing.md +306 -0
- package/docs/zh/guides/mcp/desktop-commander.md +368 -0
- package/docs/zh/guides/mcp/docker-gateway-tutorial.md +336 -0
- package/docs/zh/guides/mcp-global-setup.md +696 -0
- package/docs/zh/guides/permission-modes.md +307 -0
- package/docs/zh/guides/project-status-feature.md +467 -0
- package/docs/zh/guides/quality-dashboard.md +361 -0
- package/docs/zh/guides/quality-gates.md +462 -0
- package/docs/zh/guides/security-hardening.md +1055 -0
- package/docs/zh/guides/service-discovery.md +518 -0
- package/docs/zh/guides/squad-examples/README.md +63 -0
- package/docs/zh/guides/squad-migration.md +336 -0
- package/docs/zh/guides/template-engine-v2.md +478 -0
- package/docs/zh/guides/workflows-guide.md +408 -0
- package/docs/zh/how-to-contribute-with-pull-requests.md +158 -0
- package/docs/zh/installation/README.md +106 -0
- package/docs/zh/installation/faq.md +611 -0
- package/docs/zh/installation/linux.md +447 -0
- package/docs/zh/installation/macos.md +187 -0
- package/docs/zh/installation/troubleshooting.md +729 -0
- package/docs/zh/installation/windows.md +475 -0
- package/docs/zh/meta-agent-commands.md +990 -0
- package/docs/zh/security-best-practices.md +610 -0
- package/docs/zh/security.md +124 -0
- package/docs/zh/troubleshooting.md +883 -0
- package/docs/zh/uninstallation.md +348 -0
- package/docs/zh/versioning-and-releases.md +140 -0
- package/package.json +171 -0
- package/packages/aiox-install/.releaserc.json +38 -0
- package/packages/aiox-install/CHANGELOG.md +32 -0
- package/packages/aiox-install/README.md +117 -0
- package/packages/aiox-install/bin/aiox-install.js +50 -0
- package/packages/aiox-install/bin/edmcp.js +79 -0
- package/packages/aiox-install/jest.config.js +26 -0
- package/packages/aiox-install/package.json +66 -0
- package/packages/aiox-install/src/dep-checker.js +306 -0
- package/packages/aiox-install/src/edmcp/index.js +381 -0
- package/packages/aiox-install/src/installer.js +485 -0
- package/packages/aiox-install/src/os-detector.js +280 -0
- package/packages/aiox-pro-cli/bin/aiox-pro.js +233 -0
- package/packages/aiox-pro-cli/package.json +36 -0
- package/packages/aiox-pro-cli/src/recover.js +100 -0
- package/packages/gemini-aiox-extension/README.md +53 -0
- package/packages/gemini-aiox-extension/commands/aiox-agent.js +7 -0
- package/packages/gemini-aiox-extension/commands/aiox-agents.js +49 -0
- package/packages/gemini-aiox-extension/commands/aiox-analyst.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-architect.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-data-engineer.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-dev.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-devops.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-master.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-menu.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-pm.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-po.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-qa.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-sm.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-squad-creator.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-status.js +66 -0
- package/packages/gemini-aiox-extension/commands/aiox-ux-design-expert.js +6 -0
- package/packages/gemini-aiox-extension/commands/aiox-validate.js +33 -0
- package/packages/gemini-aiox-extension/commands/lib/agent-launcher.js +138 -0
- package/packages/gemini-aiox-extension/extension.json +147 -0
- package/packages/gemini-aiox-extension/gemini-extension.json +147 -0
- package/packages/gemini-aiox-extension/hooks/hooks.json +70 -0
- package/packages/installer/package.json +39 -0
- package/packages/installer/src/__tests__/performance-benchmark.js +382 -0
- package/packages/installer/src/config/configure-environment.js +371 -0
- package/packages/installer/src/config/ide-configs.js +159 -0
- package/packages/installer/src/config/templates/core-config-template.js +222 -0
- package/packages/installer/src/config/templates/env-template.js +270 -0
- package/packages/installer/src/config/validation/config-validator.js +243 -0
- package/packages/installer/src/detection/detect-project-type.js +81 -0
- package/packages/installer/src/installer/aiox-core-installer.js +429 -0
- package/packages/installer/src/installer/brownfield-upgrader.js +501 -0
- package/packages/installer/src/installer/dependency-installer.js +335 -0
- package/packages/installer/src/installer/file-hasher.js +234 -0
- package/packages/installer/src/installer/manifest-signature.js +378 -0
- package/packages/installer/src/installer/post-install-validator.js +1522 -0
- package/packages/installer/src/merger/index.js +74 -0
- package/packages/installer/src/merger/parsers/env-parser.js +153 -0
- package/packages/installer/src/merger/parsers/markdown-section-parser.js +198 -0
- package/packages/installer/src/merger/strategies/base-merger.js +61 -0
- package/packages/installer/src/merger/strategies/env-merger.js +137 -0
- package/packages/installer/src/merger/strategies/index.js +111 -0
- package/packages/installer/src/merger/strategies/markdown-merger.js +207 -0
- package/packages/installer/src/merger/strategies/replace-merger.js +68 -0
- package/packages/installer/src/merger/strategies/yaml-merger.js +181 -0
- package/packages/installer/src/merger/types.js +71 -0
- package/packages/installer/src/pro/pro-scaffolder.js +449 -0
- package/packages/installer/src/updater/index.js +812 -0
- package/packages/installer/src/utils/aiox-colors.js +233 -0
- package/packages/installer/src/wizard/feedback.js +230 -0
- package/packages/installer/src/wizard/i18n.js +549 -0
- package/packages/installer/src/wizard/ide-config-generator.js +1185 -0
- package/packages/installer/src/wizard/ide-selector.js +85 -0
- package/packages/installer/src/wizard/index.js +994 -0
- package/packages/installer/src/wizard/pro-setup.js +1352 -0
- package/packages/installer/src/wizard/questions.js +355 -0
- package/packages/installer/src/wizard/validation/index.js +120 -0
- package/packages/installer/src/wizard/validation/report-generator.js +253 -0
- package/packages/installer/src/wizard/validation/troubleshooting-system.js +346 -0
- package/packages/installer/src/wizard/validation/validators/config-validator.js +362 -0
- package/packages/installer/src/wizard/validation/validators/dependency-validator.js +333 -0
- package/packages/installer/src/wizard/validation/validators/file-structure-validator.js +174 -0
- package/packages/installer/src/wizard/validation/validators/mcp-health-checker.js +310 -0
- package/packages/installer/src/wizard/validators.js +274 -0
- package/packages/installer/src/wizard/wizard.js +244 -0
- package/packages/installer/tests/integration/environment-configuration.test.js +329 -0
- package/packages/installer/tests/integration/wizard-detection.test.js +351 -0
- package/packages/installer/tests/unit/artifact-copy-pipeline/artifact-copy-pipeline.test.js +374 -0
- package/packages/installer/tests/unit/claude-md-template-v5/claude-md-template-v5.test.js +192 -0
- package/packages/installer/tests/unit/config-validator.test.js +315 -0
- package/packages/installer/tests/unit/detection/detect-project-type.test.js +401 -0
- package/packages/installer/tests/unit/doctor/doctor-checks.test.js +610 -0
- package/packages/installer/tests/unit/doctor/doctor-orchestrator.test.js +134 -0
- package/packages/installer/tests/unit/entity-registry-bootstrap.test.js +186 -0
- package/packages/installer/tests/unit/env-template.test.js +187 -0
- package/packages/installer/tests/unit/generate-settings-json/generate-settings-json.test.js +309 -0
- package/packages/installer/tests/unit/ide-sync-integration/ide-sync-integration.test.js +230 -0
- package/packages/installer/tests/unit/merger/env-merger.test.js +191 -0
- package/packages/installer/tests/unit/merger/markdown-merger.test.js +261 -0
- package/packages/installer/tests/unit/merger/strategies.test.js +153 -0
- package/packages/installer/tests/unit/merger/yaml-merger.test.js +327 -0
- package/scripts/check-markdown-links.py +352 -0
- package/scripts/code-intel-health-check.js +343 -0
- package/scripts/dashboard-parallel-dev.sh +183 -0
- package/scripts/dashboard-parallel-phase3.sh +129 -0
- package/scripts/dashboard-parallel-phase4.sh +130 -0
- package/scripts/ensure-manifest.js +58 -0
- package/scripts/generate-install-manifest.js +366 -0
- package/scripts/install-monitor-hooks.sh +81 -0
- package/scripts/package-synapse.js +324 -0
- package/scripts/semantic-lint.js +190 -0
- package/scripts/sign-manifest.ps1 +130 -0
- package/scripts/sign-manifest.sh +120 -0
- package/scripts/validate-aiox-core-deps.js +161 -0
- package/scripts/validate-manifest.js +265 -0
- package/scripts/validate-package-completeness.js +317 -0
|
@@ -0,0 +1,1203 @@
|
|
|
1
|
+
---
|
|
2
|
+
template_name: "Supabase RLS Policies"
|
|
3
|
+
template_version: "1.0.0"
|
|
4
|
+
output_format: "markdown"
|
|
5
|
+
destination: "rls-policies.md"
|
|
6
|
+
description: "Row Level Security policies for Supabase tables"
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
sections:
|
|
10
|
+
- id: overview
|
|
11
|
+
title: "RLS Overview"
|
|
12
|
+
instruction: |
|
|
13
|
+
Document the Row Level Security strategy:
|
|
14
|
+
|
|
15
|
+
## Purpose
|
|
16
|
+
Explain the overall security model and why RLS is being used.
|
|
17
|
+
|
|
18
|
+
## Authentication Context
|
|
19
|
+
- How users are authenticated (Supabase Auth, JWT, etc)
|
|
20
|
+
- Available auth context variables:
|
|
21
|
+
- `auth.uid()` - Current user ID
|
|
22
|
+
- `auth.jwt()` - JWT claims
|
|
23
|
+
- `auth.email()` - User email
|
|
24
|
+
- Custom claims in JWT
|
|
25
|
+
|
|
26
|
+
## Security Model
|
|
27
|
+
- Role-based access control (RBAC)
|
|
28
|
+
- Multi-tenancy approach (if applicable)
|
|
29
|
+
- Public vs authenticated vs specific role access
|
|
30
|
+
|
|
31
|
+
## Performance Considerations
|
|
32
|
+
- RLS policy performance impact
|
|
33
|
+
- Indexing strategy to support policies
|
|
34
|
+
- Caching considerations
|
|
35
|
+
|
|
36
|
+
## Testing Strategy
|
|
37
|
+
- How policies will be tested
|
|
38
|
+
- Test users and scenarios
|
|
39
|
+
elicit: true
|
|
40
|
+
|
|
41
|
+
- id: policy-patterns
|
|
42
|
+
title: "Common Policy Patterns"
|
|
43
|
+
instruction: |
|
|
44
|
+
Document reusable policy patterns used across tables:
|
|
45
|
+
|
|
46
|
+
## Pattern 1: Owner-Only Access
|
|
47
|
+
```sql
|
|
48
|
+
-- Users can only access their own records
|
|
49
|
+
(auth.uid() = user_id)
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
## Pattern 2: Tenant-Based Access
|
|
53
|
+
```sql
|
|
54
|
+
-- Users can access records in their organization
|
|
55
|
+
(auth.uid() IN (
|
|
56
|
+
SELECT user_id FROM org_members
|
|
57
|
+
WHERE org_id = table.org_id
|
|
58
|
+
))
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
## Pattern 3: Role-Based Access
|
|
62
|
+
```sql
|
|
63
|
+
-- Only admins can access
|
|
64
|
+
((auth.jwt() ->> 'role')::text = 'admin')
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
## Pattern 4: Public Read, Authenticated Write
|
|
68
|
+
```sql
|
|
69
|
+
-- SELECT: true (public read)
|
|
70
|
+
-- INSERT/UPDATE/DELETE: auth.uid() IS NOT NULL
|
|
71
|
+
```
|
|
72
|
+
|
|
73
|
+
## Pattern 5: Hierarchical Permissions
|
|
74
|
+
```sql
|
|
75
|
+
-- Access based on organizational hierarchy
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
Document any other patterns specific to your application.
|
|
79
|
+
elicit: true
|
|
80
|
+
|
|
81
|
+
- id: table-policies
|
|
82
|
+
title: "Table-by-Table Policies"
|
|
83
|
+
instruction: |
|
|
84
|
+
For each table requiring RLS, document comprehensive policies:
|
|
85
|
+
|
|
86
|
+
# Table: `table_name`
|
|
87
|
+
|
|
88
|
+
## Enable RLS
|
|
89
|
+
```sql
|
|
90
|
+
ALTER TABLE table_name ENABLE ROW LEVEL SECURITY;
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
## SELECT Policies
|
|
94
|
+
|
|
95
|
+
### Policy: `policy_name_select`
|
|
96
|
+
**Purpose**: Describe who can read what
|
|
97
|
+
|
|
98
|
+
**Policy Expression**:
|
|
99
|
+
```sql
|
|
100
|
+
CREATE POLICY "policy_name_select"
|
|
101
|
+
ON table_name
|
|
102
|
+
FOR SELECT
|
|
103
|
+
TO authenticated -- or public, anon, etc
|
|
104
|
+
USING (
|
|
105
|
+
-- Policy expression
|
|
106
|
+
auth.uid() = user_id
|
|
107
|
+
);
|
|
108
|
+
```
|
|
109
|
+
|
|
110
|
+
**Rationale**: Explain the business rule
|
|
111
|
+
|
|
112
|
+
**Performance**: Any indexes needed to support this policy
|
|
113
|
+
|
|
114
|
+
## INSERT Policies
|
|
115
|
+
|
|
116
|
+
### Policy: `policy_name_insert`
|
|
117
|
+
**Purpose**: Describe who can create records
|
|
118
|
+
|
|
119
|
+
**Policy Expression**:
|
|
120
|
+
```sql
|
|
121
|
+
CREATE POLICY "policy_name_insert"
|
|
122
|
+
ON table_name
|
|
123
|
+
FOR INSERT
|
|
124
|
+
TO authenticated
|
|
125
|
+
WITH CHECK (
|
|
126
|
+
-- Policy expression
|
|
127
|
+
auth.uid() = user_id
|
|
128
|
+
);
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
**Validation**: What validations this ensures
|
|
132
|
+
|
|
133
|
+
## UPDATE Policies
|
|
134
|
+
|
|
135
|
+
### Policy: `policy_name_update`
|
|
136
|
+
**Purpose**: Describe who can modify records
|
|
137
|
+
|
|
138
|
+
**Policy Expression**:
|
|
139
|
+
```sql
|
|
140
|
+
CREATE POLICY "policy_name_update"
|
|
141
|
+
ON table_name
|
|
142
|
+
FOR UPDATE
|
|
143
|
+
TO authenticated
|
|
144
|
+
USING (
|
|
145
|
+
-- Who can see the record to update it
|
|
146
|
+
auth.uid() = user_id
|
|
147
|
+
)
|
|
148
|
+
WITH CHECK (
|
|
149
|
+
-- What values they can set
|
|
150
|
+
auth.uid() = user_id
|
|
151
|
+
);
|
|
152
|
+
```
|
|
153
|
+
|
|
154
|
+
**Notes**: USING checks old values, WITH CHECK validates new values
|
|
155
|
+
|
|
156
|
+
## DELETE Policies
|
|
157
|
+
|
|
158
|
+
### Policy: `policy_name_delete`
|
|
159
|
+
**Purpose**: Describe who can delete records
|
|
160
|
+
|
|
161
|
+
**Policy Expression**:
|
|
162
|
+
```sql
|
|
163
|
+
CREATE POLICY "policy_name_delete"
|
|
164
|
+
ON table_name
|
|
165
|
+
FOR DELETE
|
|
166
|
+
TO authenticated
|
|
167
|
+
USING (
|
|
168
|
+
-- Who can delete
|
|
169
|
+
auth.uid() = user_id OR
|
|
170
|
+
(auth.jwt() ->> 'role')::text = 'admin'
|
|
171
|
+
);
|
|
172
|
+
```
|
|
173
|
+
|
|
174
|
+
## ALL Policies (if using combined policy)
|
|
175
|
+
|
|
176
|
+
Sometimes a single policy for all operations is clearer:
|
|
177
|
+
|
|
178
|
+
```sql
|
|
179
|
+
CREATE POLICY "policy_name_all"
|
|
180
|
+
ON table_name
|
|
181
|
+
FOR ALL
|
|
182
|
+
TO authenticated
|
|
183
|
+
USING (auth.uid() = user_id)
|
|
184
|
+
WITH CHECK (auth.uid() = user_id);
|
|
185
|
+
```
|
|
186
|
+
|
|
187
|
+
---
|
|
188
|
+
|
|
189
|
+
Repeat this section for each table.
|
|
190
|
+
elicit: true
|
|
191
|
+
|
|
192
|
+
- id: public-tables
|
|
193
|
+
title: "Public Tables"
|
|
194
|
+
instruction: |
|
|
195
|
+
Document tables with public read access:
|
|
196
|
+
|
|
197
|
+
# Table: `public_table_name`
|
|
198
|
+
|
|
199
|
+
## Public Read Policy
|
|
200
|
+
```sql
|
|
201
|
+
ALTER TABLE public_table_name ENABLE ROW LEVEL SECURITY;
|
|
202
|
+
|
|
203
|
+
CREATE POLICY "public_read_policy"
|
|
204
|
+
ON public_table_name
|
|
205
|
+
FOR SELECT
|
|
206
|
+
TO anon, authenticated
|
|
207
|
+
USING (true);
|
|
208
|
+
```
|
|
209
|
+
|
|
210
|
+
## Restricted Write Policy
|
|
211
|
+
```sql
|
|
212
|
+
CREATE POLICY "authenticated_write_policy"
|
|
213
|
+
ON public_table_name
|
|
214
|
+
FOR INSERT
|
|
215
|
+
TO authenticated
|
|
216
|
+
WITH CHECK (auth.uid() IS NOT NULL);
|
|
217
|
+
```
|
|
218
|
+
|
|
219
|
+
**Rationale**: Why this table is public
|
|
220
|
+
|
|
221
|
+
**Security Considerations**: What data is safe to expose
|
|
222
|
+
elicit: false
|
|
223
|
+
|
|
224
|
+
- id: service-role
|
|
225
|
+
title: "Service Role Bypass"
|
|
226
|
+
instruction: |
|
|
227
|
+
Document scenarios where service role (bypass RLS) is used:
|
|
228
|
+
|
|
229
|
+
## Service Role Usage
|
|
230
|
+
|
|
231
|
+
### Backend Operations
|
|
232
|
+
Operations that need to bypass RLS:
|
|
233
|
+
- Scheduled jobs (cron, edge functions with service key)
|
|
234
|
+
- Admin operations
|
|
235
|
+
- Data migration
|
|
236
|
+
- Analytics aggregation
|
|
237
|
+
|
|
238
|
+
### Safety Measures
|
|
239
|
+
- How service key is secured
|
|
240
|
+
- Where service role operations are logged
|
|
241
|
+
- Who has access to service key
|
|
242
|
+
|
|
243
|
+
### Alternatives
|
|
244
|
+
When possible, prefer:
|
|
245
|
+
- Security definer functions with RLS
|
|
246
|
+
- Elevated permission policies
|
|
247
|
+
- Temporary privilege escalation
|
|
248
|
+
elicit: false
|
|
249
|
+
|
|
250
|
+
- id: helper-functions
|
|
251
|
+
title: "Security Helper Functions"
|
|
252
|
+
instruction: |
|
|
253
|
+
Document PostgreSQL functions that support RLS:
|
|
254
|
+
|
|
255
|
+
## Function: `check_user_permission`
|
|
256
|
+
```sql
|
|
257
|
+
CREATE OR REPLACE FUNCTION check_user_permission(
|
|
258
|
+
user_id uuid,
|
|
259
|
+
resource_id uuid,
|
|
260
|
+
permission_type text
|
|
261
|
+
)
|
|
262
|
+
RETURNS boolean
|
|
263
|
+
LANGUAGE plpgsql
|
|
264
|
+
SECURITY DEFINER
|
|
265
|
+
AS $$
|
|
266
|
+
BEGIN
|
|
267
|
+
-- Permission checking logic
|
|
268
|
+
RETURN EXISTS (
|
|
269
|
+
SELECT 1 FROM permissions
|
|
270
|
+
WHERE user_id = $1
|
|
271
|
+
AND resource_id = $2
|
|
272
|
+
AND permission = $3
|
|
273
|
+
);
|
|
274
|
+
END;
|
|
275
|
+
$$;
|
|
276
|
+
```
|
|
277
|
+
|
|
278
|
+
**Usage in Policies**:
|
|
279
|
+
```sql
|
|
280
|
+
USING (check_user_permission(auth.uid(), id, 'read'))
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
## Function: `get_user_org_id`
|
|
284
|
+
```sql
|
|
285
|
+
CREATE OR REPLACE FUNCTION get_user_org_id()
|
|
286
|
+
RETURNS uuid
|
|
287
|
+
LANGUAGE sql
|
|
288
|
+
STABLE
|
|
289
|
+
AS $$
|
|
290
|
+
SELECT org_id FROM user_profiles
|
|
291
|
+
WHERE user_id = auth.uid();
|
|
292
|
+
$$;
|
|
293
|
+
```
|
|
294
|
+
|
|
295
|
+
**Usage in Policies**:
|
|
296
|
+
```sql
|
|
297
|
+
USING (org_id = get_user_org_id())
|
|
298
|
+
```
|
|
299
|
+
|
|
300
|
+
Document all helper functions used in RLS policies.
|
|
301
|
+
elicit: false
|
|
302
|
+
|
|
303
|
+
- id: multi-tenancy
|
|
304
|
+
title: "Multi-Tenancy Implementation"
|
|
305
|
+
condition: "multi_tenant"
|
|
306
|
+
instruction: |
|
|
307
|
+
If implementing multi-tenancy with RLS:
|
|
308
|
+
|
|
309
|
+
## Tenant Isolation Strategy
|
|
310
|
+
|
|
311
|
+
### Tenant Identification
|
|
312
|
+
- How tenants are identified (org_id, team_id, etc)
|
|
313
|
+
- Where tenant ID is stored (JWT claim, database lookup)
|
|
314
|
+
|
|
315
|
+
### Tenant-Scoped Tables
|
|
316
|
+
|
|
317
|
+
For each tenant-scoped table:
|
|
318
|
+
|
|
319
|
+
```sql
|
|
320
|
+
-- Example: projects table
|
|
321
|
+
CREATE POLICY "tenant_isolation_policy"
|
|
322
|
+
ON projects
|
|
323
|
+
FOR ALL
|
|
324
|
+
TO authenticated
|
|
325
|
+
USING (
|
|
326
|
+
org_id = (auth.jwt() ->> 'org_id')::uuid
|
|
327
|
+
)
|
|
328
|
+
WITH CHECK (
|
|
329
|
+
org_id = (auth.jwt() ->> 'org_id')::uuid
|
|
330
|
+
);
|
|
331
|
+
```
|
|
332
|
+
|
|
333
|
+
### Cross-Tenant Scenarios
|
|
334
|
+
- Shared resources across tenants
|
|
335
|
+
- Super admin access
|
|
336
|
+
- Tenant-to-tenant relationships
|
|
337
|
+
|
|
338
|
+
### Performance
|
|
339
|
+
- Indexes on tenant_id columns
|
|
340
|
+
- Query patterns that leverage tenant isolation
|
|
341
|
+
elicit: true
|
|
342
|
+
|
|
343
|
+
- id: storage-policies
|
|
344
|
+
title: "Supabase Storage Policies"
|
|
345
|
+
instruction: |
|
|
346
|
+
RLS policies for Supabase Storage buckets (storage.objects table).
|
|
347
|
+
|
|
348
|
+
## Overview
|
|
349
|
+
|
|
350
|
+
Supabase Storage uses RLS on the `storage.objects` system table to control file access.
|
|
351
|
+
By default, Storage requires explicit RLS policies - no uploads allowed without policies.
|
|
352
|
+
|
|
353
|
+
## Pattern 1: User-Specific Uploads
|
|
354
|
+
|
|
355
|
+
Users can only upload files to their own folder:
|
|
356
|
+
|
|
357
|
+
```sql
|
|
358
|
+
CREATE POLICY "Users upload own avatars"
|
|
359
|
+
ON storage.objects
|
|
360
|
+
FOR INSERT
|
|
361
|
+
TO authenticated
|
|
362
|
+
WITH CHECK (
|
|
363
|
+
bucket_id = 'avatars' AND
|
|
364
|
+
(select auth.uid())::text = (storage.foldername(name))[1]
|
|
365
|
+
);
|
|
366
|
+
```
|
|
367
|
+
|
|
368
|
+
**Folder Structure**: `avatars/{user_id}/filename.jpg`
|
|
369
|
+
|
|
370
|
+
**How it works**:
|
|
371
|
+
- `storage.foldername(name)` splits path by `/` returning array
|
|
372
|
+
- `[1]` gets first folder (user_id)
|
|
373
|
+
- Compares with authenticated user's ID
|
|
374
|
+
|
|
375
|
+
## Pattern 2: Public Read, Authenticated Write
|
|
376
|
+
|
|
377
|
+
Anyone can view files, only authenticated users can upload:
|
|
378
|
+
|
|
379
|
+
```sql
|
|
380
|
+
-- Public read
|
|
381
|
+
CREATE POLICY "Public avatars readable"
|
|
382
|
+
ON storage.objects
|
|
383
|
+
FOR SELECT
|
|
384
|
+
TO public
|
|
385
|
+
USING (bucket_id = 'avatars');
|
|
386
|
+
|
|
387
|
+
-- Authenticated write
|
|
388
|
+
CREATE POLICY "Authenticated upload avatars"
|
|
389
|
+
ON storage.objects
|
|
390
|
+
FOR INSERT
|
|
391
|
+
TO authenticated
|
|
392
|
+
WITH CHECK (bucket_id = 'avatars');
|
|
393
|
+
```
|
|
394
|
+
|
|
395
|
+
**Use case**: Public profile pictures, logos, marketing assets.
|
|
396
|
+
|
|
397
|
+
## Pattern 3: Tenant-Scoped Files
|
|
398
|
+
|
|
399
|
+
Users can only access files from their organization:
|
|
400
|
+
|
|
401
|
+
```sql
|
|
402
|
+
CREATE POLICY "Tenant file isolation"
|
|
403
|
+
ON storage.objects
|
|
404
|
+
FOR SELECT
|
|
405
|
+
TO authenticated
|
|
406
|
+
USING (
|
|
407
|
+
bucket_id = 'documents' AND
|
|
408
|
+
(storage.foldername(name))[1] = ((select auth.jwt()) ->> 'org_id')
|
|
409
|
+
);
|
|
410
|
+
|
|
411
|
+
CREATE POLICY "Tenant file uploads"
|
|
412
|
+
ON storage.objects
|
|
413
|
+
FOR INSERT
|
|
414
|
+
TO authenticated
|
|
415
|
+
WITH CHECK (
|
|
416
|
+
bucket_id = 'documents' AND
|
|
417
|
+
(storage.foldername(name))[1] = ((select auth.jwt()) ->> 'org_id')
|
|
418
|
+
);
|
|
419
|
+
```
|
|
420
|
+
|
|
421
|
+
**Folder Structure**: `documents/{org_id}/{file_id}.pdf`
|
|
422
|
+
|
|
423
|
+
## Pattern 4: Delete Own Files
|
|
424
|
+
|
|
425
|
+
Users can delete their own files:
|
|
426
|
+
|
|
427
|
+
```sql
|
|
428
|
+
CREATE POLICY "Users delete own files"
|
|
429
|
+
ON storage.objects
|
|
430
|
+
FOR DELETE
|
|
431
|
+
TO authenticated
|
|
432
|
+
USING (
|
|
433
|
+
bucket_id = 'avatars' AND
|
|
434
|
+
(select auth.uid())::text = (storage.foldername(name))[1]
|
|
435
|
+
);
|
|
436
|
+
```
|
|
437
|
+
|
|
438
|
+
## Pattern 5: File Overwriting (upsert)
|
|
439
|
+
|
|
440
|
+
For file overwriting via `upsert` option, grant SELECT + UPDATE:
|
|
441
|
+
|
|
442
|
+
```sql
|
|
443
|
+
-- Allow reading (required for upsert check)
|
|
444
|
+
CREATE POLICY "Users read own files"
|
|
445
|
+
ON storage.objects
|
|
446
|
+
FOR SELECT
|
|
447
|
+
TO authenticated
|
|
448
|
+
USING (
|
|
449
|
+
bucket_id = 'avatars' AND
|
|
450
|
+
(select auth.uid())::text = (storage.foldername(name))[1]
|
|
451
|
+
);
|
|
452
|
+
|
|
453
|
+
-- Allow updating (for upsert)
|
|
454
|
+
CREATE POLICY "Users update own files"
|
|
455
|
+
ON storage.objects
|
|
456
|
+
FOR UPDATE
|
|
457
|
+
TO authenticated
|
|
458
|
+
USING (
|
|
459
|
+
bucket_id = 'avatars' AND
|
|
460
|
+
(select auth.uid())::text = (storage.foldername(name))[1]
|
|
461
|
+
)
|
|
462
|
+
WITH CHECK (
|
|
463
|
+
bucket_id = 'avatars' AND
|
|
464
|
+
(select auth.uid())::text = (storage.foldername(name))[1]
|
|
465
|
+
);
|
|
466
|
+
```
|
|
467
|
+
|
|
468
|
+
## Bucket Configuration
|
|
469
|
+
|
|
470
|
+
Create buckets with appropriate public/private settings:
|
|
471
|
+
|
|
472
|
+
```sql
|
|
473
|
+
-- Create private bucket (requires policies)
|
|
474
|
+
INSERT INTO storage.buckets (id, name, public)
|
|
475
|
+
VALUES ('avatars', 'avatars', false);
|
|
476
|
+
|
|
477
|
+
-- Create public bucket (files publicly accessible by URL)
|
|
478
|
+
INSERT INTO storage.buckets (id, name, public)
|
|
479
|
+
VALUES ('public-images', 'public-images', true);
|
|
480
|
+
```
|
|
481
|
+
|
|
482
|
+
**Note**: Even public buckets respect RLS for uploads/deletes.
|
|
483
|
+
|
|
484
|
+
## Helper Functions
|
|
485
|
+
|
|
486
|
+
```sql
|
|
487
|
+
-- Extract user folder from path
|
|
488
|
+
CREATE OR REPLACE FUNCTION storage.user_owns_file(file_path text)
|
|
489
|
+
RETURNS boolean
|
|
490
|
+
LANGUAGE sql
|
|
491
|
+
STABLE
|
|
492
|
+
AS $$
|
|
493
|
+
SELECT (select auth.uid())::text = (storage.foldername(file_path))[1];
|
|
494
|
+
$$;
|
|
495
|
+
|
|
496
|
+
-- Usage in policy
|
|
497
|
+
CREATE POLICY "Users access own files"
|
|
498
|
+
ON storage.objects
|
|
499
|
+
FOR ALL
|
|
500
|
+
TO authenticated
|
|
501
|
+
USING (
|
|
502
|
+
bucket_id = 'private' AND
|
|
503
|
+
storage.user_owns_file(name)
|
|
504
|
+
);
|
|
505
|
+
```
|
|
506
|
+
|
|
507
|
+
## Security Considerations
|
|
508
|
+
|
|
509
|
+
1. **Always validate bucket_id** in policies (prevent cross-bucket access)
|
|
510
|
+
2. **Use folder structure** for user/tenant isolation
|
|
511
|
+
3. **Set appropriate bucket public/private** settings
|
|
512
|
+
4. **Monitor storage size** per user/tenant (implement quotas)
|
|
513
|
+
5. **Validate file types** server-side (policies can't check content)
|
|
514
|
+
|
|
515
|
+
## Testing
|
|
516
|
+
|
|
517
|
+
Test storage policies with Supabase client:
|
|
518
|
+
|
|
519
|
+
```typescript
|
|
520
|
+
// Test upload as user A
|
|
521
|
+
const { data, error } = await supabase.storage
|
|
522
|
+
.from('avatars')
|
|
523
|
+
.upload(`${user.id}/avatar.jpg`, file);
|
|
524
|
+
|
|
525
|
+
// Should succeed for own folder
|
|
526
|
+
expect(error).toBeNull();
|
|
527
|
+
|
|
528
|
+
// Test read as user B (should fail for user A's folder)
|
|
529
|
+
const { data: files, error: listError } = await supabase.storage
|
|
530
|
+
.from('avatars')
|
|
531
|
+
.list(`${otherUserId}/`);
|
|
532
|
+
|
|
533
|
+
// Should return empty or error
|
|
534
|
+
expect(files).toHaveLength(0);
|
|
535
|
+
```
|
|
536
|
+
|
|
537
|
+
## Performance
|
|
538
|
+
|
|
539
|
+
Storage policies are evaluated on every file operation.
|
|
540
|
+
|
|
541
|
+
**Optimize**:
|
|
542
|
+
- Use simple folder path checks (fast)
|
|
543
|
+
- Avoid complex JOINs in storage policies
|
|
544
|
+
- Cache JWT claims in helper functions
|
|
545
|
+
- Use indexes on bucket_id (already indexed by Supabase)
|
|
546
|
+
|
|
547
|
+
## Common Pitfalls
|
|
548
|
+
|
|
549
|
+
- **Forgetting SELECT policy** for upsert operations
|
|
550
|
+
- **Not validating bucket_id** (allows cross-bucket access)
|
|
551
|
+
- **Complex policies** (slow file operations)
|
|
552
|
+
- **Mixing public/private** bucket settings incorrectly
|
|
553
|
+
elicit: false
|
|
554
|
+
|
|
555
|
+
- id: performance-optimization
|
|
556
|
+
title: "RLS Performance Optimization"
|
|
557
|
+
instruction: |
|
|
558
|
+
Critical performance optimizations for RLS policies validated by Supabase documentation.
|
|
559
|
+
|
|
560
|
+
## 🚀 Optimization 1: Wrap Auth Functions with SELECT (94.97% faster)
|
|
561
|
+
|
|
562
|
+
**Critical Discovery** from Supabase docs: Wrapping auth functions enables query caching.
|
|
563
|
+
|
|
564
|
+
### ❌ SLOW (no caching):
|
|
565
|
+
```sql
|
|
566
|
+
CREATE POLICY "users_select"
|
|
567
|
+
ON users
|
|
568
|
+
FOR SELECT
|
|
569
|
+
TO authenticated
|
|
570
|
+
USING (auth.uid() = user_id);
|
|
571
|
+
```
|
|
572
|
+
|
|
573
|
+
### ✅ FAST (cached, 94.97% improvement):
|
|
574
|
+
```sql
|
|
575
|
+
CREATE POLICY "users_select"
|
|
576
|
+
ON users
|
|
577
|
+
FOR SELECT
|
|
578
|
+
TO authenticated
|
|
579
|
+
USING ((select auth.uid()) = user_id);
|
|
580
|
+
```
|
|
581
|
+
|
|
582
|
+
**Why**: PostgreSQL caches the result of `(select auth.uid())` for the duration of the transaction,
|
|
583
|
+
avoiding repeated function calls.
|
|
584
|
+
|
|
585
|
+
**Impact**: **19x faster queries** in high-traffic scenarios.
|
|
586
|
+
|
|
587
|
+
**Apply to all auth functions**:
|
|
588
|
+
- `(select auth.uid())`
|
|
589
|
+
- `(select auth.jwt())`
|
|
590
|
+
- `(select auth.email())`
|
|
591
|
+
|
|
592
|
+
## 🚀 Optimization 2: Index Policy Columns (99.94% improvement)
|
|
593
|
+
|
|
594
|
+
**Always index columns used in policy expressions.**
|
|
595
|
+
|
|
596
|
+
```sql
|
|
597
|
+
-- Policy uses user_id
|
|
598
|
+
CREATE POLICY "user_policy" ON posts
|
|
599
|
+
USING ((select auth.uid()) = user_id);
|
|
600
|
+
|
|
601
|
+
-- Index user_id (99.94% faster)
|
|
602
|
+
CREATE INDEX idx_posts_user_id ON posts(user_id);
|
|
603
|
+
```
|
|
604
|
+
|
|
605
|
+
**Critical indexes**:
|
|
606
|
+
```sql
|
|
607
|
+
-- Tenant isolation
|
|
608
|
+
CREATE INDEX idx_table_org_id ON table_name(org_id);
|
|
609
|
+
|
|
610
|
+
-- Owner-based policies
|
|
611
|
+
CREATE INDEX idx_table_user_id ON table_name(user_id);
|
|
612
|
+
|
|
613
|
+
-- Time-based policies
|
|
614
|
+
CREATE INDEX idx_table_scheduling
|
|
615
|
+
ON table_name(publish_at, expire_at)
|
|
616
|
+
WHERE publish_at IS NOT NULL OR expire_at IS NOT NULL;
|
|
617
|
+
```
|
|
618
|
+
|
|
619
|
+
## 🚀 Optimization 3: Filter Client-Side Explicitly
|
|
620
|
+
|
|
621
|
+
**Even with RLS policies, explicitly filter in client queries.**
|
|
622
|
+
|
|
623
|
+
```typescript
|
|
624
|
+
// ❌ Relies only on RLS
|
|
625
|
+
const { data } = await supabase
|
|
626
|
+
.from('users')
|
|
627
|
+
.select('*'); // Returns only own data due to RLS, but query planner doesn't know
|
|
628
|
+
|
|
629
|
+
// ✅ Explicit filter (helps query planner)
|
|
630
|
+
const { data } = await supabase
|
|
631
|
+
.from('users')
|
|
632
|
+
.select('*')
|
|
633
|
+
.eq('user_id', userId); // Query planner can use index
|
|
634
|
+
```
|
|
635
|
+
|
|
636
|
+
**Why**: Explicit filters help PostgreSQL query planner choose optimal index scan.
|
|
637
|
+
|
|
638
|
+
## 🚀 Optimization 4: Specify Roles Explicitly
|
|
639
|
+
|
|
640
|
+
```sql
|
|
641
|
+
-- ❌ Applies to all roles (unnecessary checks)
|
|
642
|
+
CREATE POLICY "policy" ON table USING (...);
|
|
643
|
+
|
|
644
|
+
-- ✅ Specific role (fewer checks)
|
|
645
|
+
CREATE POLICY "policy" ON table
|
|
646
|
+
TO authenticated -- Only authenticated users
|
|
647
|
+
USING (...);
|
|
648
|
+
```
|
|
649
|
+
|
|
650
|
+
**Common roles**:
|
|
651
|
+
- `TO authenticated` - Logged-in users
|
|
652
|
+
- `TO anon` - Anonymous users
|
|
653
|
+
- `TO public` - Both authenticated and anon
|
|
654
|
+
|
|
655
|
+
## 🚀 Optimization 5: Use Security Definer Functions
|
|
656
|
+
|
|
657
|
+
**Bypass RLS on join tables** with security definer functions.
|
|
658
|
+
|
|
659
|
+
```sql
|
|
660
|
+
-- ❌ Policy with JOIN (slow, 99.99% slower)
|
|
661
|
+
CREATE POLICY "team_access" ON documents
|
|
662
|
+
USING (
|
|
663
|
+
team_id IN (
|
|
664
|
+
SELECT team_id FROM user_teams
|
|
665
|
+
WHERE user_id = (select auth.uid())
|
|
666
|
+
)
|
|
667
|
+
);
|
|
668
|
+
|
|
669
|
+
-- ✅ Security definer function (99.99% improvement)
|
|
670
|
+
CREATE OR REPLACE FUNCTION user_team_ids()
|
|
671
|
+
RETURNS TABLE(team_id UUID)
|
|
672
|
+
LANGUAGE sql
|
|
673
|
+
STABLE
|
|
674
|
+
SECURITY DEFINER
|
|
675
|
+
AS $$
|
|
676
|
+
SELECT team_id FROM user_teams
|
|
677
|
+
WHERE user_id = auth.uid();
|
|
678
|
+
$$;
|
|
679
|
+
|
|
680
|
+
CREATE POLICY "team_access" ON documents
|
|
681
|
+
USING (team_id IN (SELECT user_team_ids()));
|
|
682
|
+
```
|
|
683
|
+
|
|
684
|
+
**Why**: Security definer functions run with elevated privileges, bypassing RLS on join tables.
|
|
685
|
+
|
|
686
|
+
## 🚀 Optimization 6: Minimize Joins
|
|
687
|
+
|
|
688
|
+
**Avoid joining source and target tables in policies.**
|
|
689
|
+
|
|
690
|
+
```sql
|
|
691
|
+
-- ❌ JOIN in policy (slow)
|
|
692
|
+
CREATE POLICY "org_access" ON documents
|
|
693
|
+
USING (
|
|
694
|
+
EXISTS (
|
|
695
|
+
SELECT 1 FROM users
|
|
696
|
+
WHERE users.id = (select auth.uid())
|
|
697
|
+
AND users.org_id = documents.org_id
|
|
698
|
+
)
|
|
699
|
+
);
|
|
700
|
+
|
|
701
|
+
-- ✅ Use JWT claims (no JOIN)
|
|
702
|
+
CREATE POLICY "org_access" ON documents
|
|
703
|
+
USING (
|
|
704
|
+
org_id = ((select auth.jwt()) ->> 'org_id')::uuid
|
|
705
|
+
);
|
|
706
|
+
```
|
|
707
|
+
|
|
708
|
+
**Strategy**: Store necessary claims in JWT (org_id, role, tenant_id).
|
|
709
|
+
|
|
710
|
+
## Performance Checklist
|
|
711
|
+
|
|
712
|
+
Apply to every RLS policy:
|
|
713
|
+
|
|
714
|
+
- [ ] Wrap `auth.uid()` with `(select auth.uid())`
|
|
715
|
+
- [ ] Index all columns used in USING/WITH CHECK
|
|
716
|
+
- [ ] Specify role explicitly (TO authenticated vs TO public)
|
|
717
|
+
- [ ] Use JWT claims instead of JOINs where possible
|
|
718
|
+
- [ ] Create security definer functions for complex permission checks
|
|
719
|
+
- [ ] Test query plans with EXPLAIN ANALYZE
|
|
720
|
+
- [ ] Filter client-side explicitly
|
|
721
|
+
|
|
722
|
+
## Measuring Performance
|
|
723
|
+
|
|
724
|
+
```sql
|
|
725
|
+
-- Check query plan (look for Sequential Scan vs Index Scan)
|
|
726
|
+
EXPLAIN ANALYZE
|
|
727
|
+
SELECT * FROM users WHERE user_id = 'xxx';
|
|
728
|
+
|
|
729
|
+
-- Monitor slow queries
|
|
730
|
+
SELECT
|
|
731
|
+
query,
|
|
732
|
+
calls,
|
|
733
|
+
mean_exec_time,
|
|
734
|
+
max_exec_time
|
|
735
|
+
FROM pg_stat_statements
|
|
736
|
+
WHERE query LIKE '%users%'
|
|
737
|
+
ORDER BY mean_exec_time DESC
|
|
738
|
+
LIMIT 10;
|
|
739
|
+
```
|
|
740
|
+
|
|
741
|
+
## Real-World Impact
|
|
742
|
+
|
|
743
|
+
**Before optimization**:
|
|
744
|
+
- Query time: 250ms
|
|
745
|
+
- Database CPU: 80%
|
|
746
|
+
- Queries/sec: 40
|
|
747
|
+
|
|
748
|
+
**After optimization** (wrapped functions + indexes):
|
|
749
|
+
- Query time: 12ms (95% improvement)
|
|
750
|
+
- Database CPU: 15%
|
|
751
|
+
- Queries/sec: 800 (20x increase)
|
|
752
|
+
elicit: false
|
|
753
|
+
|
|
754
|
+
- id: advanced-patterns
|
|
755
|
+
title: "Advanced RLS Patterns"
|
|
756
|
+
instruction: |
|
|
757
|
+
Advanced RLS patterns beyond basic owner-only and tenant isolation.
|
|
758
|
+
|
|
759
|
+
## Pattern 6: Time-Based Access (Scheduled Content)
|
|
760
|
+
|
|
761
|
+
**Use case**: Blog posts with scheduled publishing, promotions with expiration, time-limited content.
|
|
762
|
+
|
|
763
|
+
```sql
|
|
764
|
+
CREATE POLICY "scheduled_content"
|
|
765
|
+
ON posts
|
|
766
|
+
FOR SELECT
|
|
767
|
+
TO authenticated
|
|
768
|
+
USING (
|
|
769
|
+
(publish_at IS NULL OR publish_at <= NOW()) AND
|
|
770
|
+
(expire_at IS NULL OR expire_at > NOW())
|
|
771
|
+
);
|
|
772
|
+
```
|
|
773
|
+
|
|
774
|
+
**How it works**:
|
|
775
|
+
- `publish_at IS NULL` - No schedule, always visible
|
|
776
|
+
- `publish_at <= NOW()` - Past publish date, visible
|
|
777
|
+
- `expire_at IS NULL` - No expiration, always visible
|
|
778
|
+
- `expire_at > NOW()` - Not expired, visible
|
|
779
|
+
|
|
780
|
+
**Performance**:
|
|
781
|
+
```sql
|
|
782
|
+
-- Index for time-based queries
|
|
783
|
+
CREATE INDEX idx_posts_scheduling
|
|
784
|
+
ON posts(publish_at, expire_at)
|
|
785
|
+
WHERE publish_at IS NOT NULL OR expire_at IS NOT NULL;
|
|
786
|
+
```
|
|
787
|
+
|
|
788
|
+
**Client-side filtering** (helps query planner):
|
|
789
|
+
```typescript
|
|
790
|
+
const { data } = await supabase
|
|
791
|
+
.from('posts')
|
|
792
|
+
.select('*')
|
|
793
|
+
.lte('publish_at', new Date().toISOString())
|
|
794
|
+
.or('publish_at.is.null')
|
|
795
|
+
.gte('expire_at', new Date().toISOString())
|
|
796
|
+
.or('expire_at.is.null');
|
|
797
|
+
```
|
|
798
|
+
|
|
799
|
+
## Pattern 7: Hierarchical Organizations (Detailed)
|
|
800
|
+
|
|
801
|
+
**Use case**: Org > Team > User hierarchy with different access levels.
|
|
802
|
+
|
|
803
|
+
### Simple Hierarchy (Org-Level):
|
|
804
|
+
```sql
|
|
805
|
+
CREATE POLICY "org_hierarchy"
|
|
806
|
+
ON resources
|
|
807
|
+
FOR SELECT
|
|
808
|
+
TO authenticated
|
|
809
|
+
USING (
|
|
810
|
+
org_id IN (
|
|
811
|
+
SELECT org_id
|
|
812
|
+
FROM user_org_memberships
|
|
813
|
+
WHERE user_id = (select auth.uid())
|
|
814
|
+
)
|
|
815
|
+
);
|
|
816
|
+
```
|
|
817
|
+
|
|
818
|
+
**User sees resources from ALL orgs they belong to.**
|
|
819
|
+
|
|
820
|
+
### Complex Hierarchy (Org + Team):
|
|
821
|
+
```sql
|
|
822
|
+
-- Option 1: User sees resources from their teams
|
|
823
|
+
CREATE POLICY "team_hierarchy"
|
|
824
|
+
ON resources
|
|
825
|
+
FOR SELECT
|
|
826
|
+
TO authenticated
|
|
827
|
+
USING (
|
|
828
|
+
team_id IN (
|
|
829
|
+
SELECT team_id
|
|
830
|
+
FROM user_team_memberships
|
|
831
|
+
WHERE user_id = (select auth.uid())
|
|
832
|
+
)
|
|
833
|
+
);
|
|
834
|
+
|
|
835
|
+
-- Option 2: Combined (org admin sees all, team member sees team only)
|
|
836
|
+
CREATE POLICY "combined_hierarchy"
|
|
837
|
+
ON resources
|
|
838
|
+
FOR SELECT
|
|
839
|
+
TO authenticated
|
|
840
|
+
USING (
|
|
841
|
+
-- Org admin sees all resources in org
|
|
842
|
+
(
|
|
843
|
+
org_id IN (
|
|
844
|
+
SELECT org_id
|
|
845
|
+
FROM user_org_memberships
|
|
846
|
+
WHERE user_id = (select auth.uid()) AND role = 'admin'
|
|
847
|
+
)
|
|
848
|
+
)
|
|
849
|
+
OR
|
|
850
|
+
-- Team member sees only team resources
|
|
851
|
+
(
|
|
852
|
+
team_id IN (
|
|
853
|
+
SELECT team_id
|
|
854
|
+
FROM user_team_memberships
|
|
855
|
+
WHERE user_id = (select auth.uid())
|
|
856
|
+
)
|
|
857
|
+
)
|
|
858
|
+
);
|
|
859
|
+
```
|
|
860
|
+
|
|
861
|
+
**Performance**:
|
|
862
|
+
```sql
|
|
863
|
+
-- Indexes for hierarchy lookups
|
|
864
|
+
CREATE INDEX idx_user_org_memberships_user
|
|
865
|
+
ON user_org_memberships(user_id, org_id);
|
|
866
|
+
|
|
867
|
+
CREATE INDEX idx_user_team_memberships_user
|
|
868
|
+
ON user_team_memberships(user_id, team_id);
|
|
869
|
+
|
|
870
|
+
CREATE INDEX idx_resources_org_id ON resources(org_id);
|
|
871
|
+
CREATE INDEX idx_resources_team_id ON resources(team_id);
|
|
872
|
+
```
|
|
873
|
+
|
|
874
|
+
**Optimization** (security definer function):
|
|
875
|
+
```sql
|
|
876
|
+
CREATE OR REPLACE FUNCTION user_accessible_orgs()
|
|
877
|
+
RETURNS TABLE(org_id UUID)
|
|
878
|
+
LANGUAGE sql
|
|
879
|
+
STABLE
|
|
880
|
+
SECURITY DEFINER
|
|
881
|
+
AS $$
|
|
882
|
+
SELECT org_id FROM user_org_memberships
|
|
883
|
+
WHERE user_id = auth.uid();
|
|
884
|
+
$$;
|
|
885
|
+
|
|
886
|
+
CREATE POLICY "org_hierarchy_optimized"
|
|
887
|
+
ON resources
|
|
888
|
+
FOR SELECT
|
|
889
|
+
TO authenticated
|
|
890
|
+
USING (org_id IN (SELECT user_accessible_orgs()));
|
|
891
|
+
```
|
|
892
|
+
|
|
893
|
+
## Pattern 8: Role-Based with Custom Claims (Advanced)
|
|
894
|
+
|
|
895
|
+
**Use case**: Different permissions per role (admin, manager, analyst, user).
|
|
896
|
+
|
|
897
|
+
### Setup: Add role to JWT
|
|
898
|
+
```sql
|
|
899
|
+
CREATE OR REPLACE FUNCTION custom_access_token_hook(event jsonb)
|
|
900
|
+
RETURNS jsonb AS $$
|
|
901
|
+
DECLARE
|
|
902
|
+
claims jsonb;
|
|
903
|
+
user_role text;
|
|
904
|
+
user_org_id uuid;
|
|
905
|
+
BEGIN
|
|
906
|
+
-- Get user role and org from profiles table
|
|
907
|
+
SELECT role, org_id INTO user_role, user_org_id
|
|
908
|
+
FROM public.user_profiles
|
|
909
|
+
WHERE user_id = (event->>'user_id')::uuid;
|
|
910
|
+
|
|
911
|
+
-- Add to JWT claims
|
|
912
|
+
claims := event->'claims';
|
|
913
|
+
claims := jsonb_set(claims, '{role}', to_jsonb(user_role));
|
|
914
|
+
claims := jsonb_set(claims, '{org_id}', to_jsonb(user_org_id));
|
|
915
|
+
|
|
916
|
+
RETURN jsonb_set(event, '{claims}', claims);
|
|
917
|
+
END;
|
|
918
|
+
$$ LANGUAGE plpgsql SECURITY DEFINER;
|
|
919
|
+
```
|
|
920
|
+
|
|
921
|
+
**Configure in Supabase Dashboard**: Authentication > Hooks > Custom Access Token
|
|
922
|
+
|
|
923
|
+
### Policy: Role-Based Access
|
|
924
|
+
```sql
|
|
925
|
+
-- Admin sees all
|
|
926
|
+
CREATE POLICY "admin_full_access"
|
|
927
|
+
ON sensitive_data
|
|
928
|
+
FOR ALL
|
|
929
|
+
TO authenticated
|
|
930
|
+
USING (
|
|
931
|
+
((select auth.jwt()) ->> 'role') = 'admin'
|
|
932
|
+
);
|
|
933
|
+
|
|
934
|
+
-- Manager sees org data
|
|
935
|
+
CREATE POLICY "manager_org_access"
|
|
936
|
+
ON sensitive_data
|
|
937
|
+
FOR SELECT
|
|
938
|
+
TO authenticated
|
|
939
|
+
USING (
|
|
940
|
+
((select auth.jwt()) ->> 'role') = 'manager' AND
|
|
941
|
+
org_id = ((select auth.jwt()) ->> 'org_id')::uuid
|
|
942
|
+
);
|
|
943
|
+
|
|
944
|
+
-- User sees own data only
|
|
945
|
+
CREATE POLICY "user_own_access"
|
|
946
|
+
ON sensitive_data
|
|
947
|
+
FOR SELECT
|
|
948
|
+
TO authenticated
|
|
949
|
+
USING (
|
|
950
|
+
((select auth.jwt()) ->> 'role') = 'user' AND
|
|
951
|
+
user_id = (select auth.uid())
|
|
952
|
+
);
|
|
953
|
+
```
|
|
954
|
+
|
|
955
|
+
### Policy: Role Hierarchy (Admin > Manager > User)
|
|
956
|
+
```sql
|
|
957
|
+
CREATE POLICY "role_hierarchy"
|
|
958
|
+
ON resources
|
|
959
|
+
FOR ALL
|
|
960
|
+
TO authenticated
|
|
961
|
+
USING (
|
|
962
|
+
CASE ((select auth.jwt()) ->> 'role')
|
|
963
|
+
WHEN 'admin' THEN true -- Admin sees everything
|
|
964
|
+
WHEN 'manager' THEN org_id = ((select auth.jwt()) ->> 'org_id')::uuid
|
|
965
|
+
ELSE user_id = (select auth.uid()) -- User sees own only
|
|
966
|
+
END
|
|
967
|
+
);
|
|
968
|
+
```
|
|
969
|
+
|
|
970
|
+
## Pattern 9: Multi-Factor Authentication (AAL2)
|
|
971
|
+
|
|
972
|
+
**Use case**: Sensitive operations require MFA.
|
|
973
|
+
|
|
974
|
+
```sql
|
|
975
|
+
CREATE POLICY "mfa_required_for_sensitive_ops"
|
|
976
|
+
ON sensitive_operations
|
|
977
|
+
FOR INSERT
|
|
978
|
+
TO authenticated
|
|
979
|
+
USING (
|
|
980
|
+
((select auth.jwt()) ->> 'aal') = 'aal2' -- Assurance Level 2 (MFA)
|
|
981
|
+
);
|
|
982
|
+
```
|
|
983
|
+
|
|
984
|
+
**AAL levels**:
|
|
985
|
+
- `aal1` - Single factor (password only)
|
|
986
|
+
- `aal2` - Multi-factor (password + OTP/biometric)
|
|
987
|
+
|
|
988
|
+
## Pattern 10: IP-Based Restrictions
|
|
989
|
+
|
|
990
|
+
**Use case**: Restrict admin operations to office IP.
|
|
991
|
+
|
|
992
|
+
```sql
|
|
993
|
+
CREATE POLICY "admin_office_only"
|
|
994
|
+
ON admin_operations
|
|
995
|
+
FOR ALL
|
|
996
|
+
TO authenticated
|
|
997
|
+
USING (
|
|
998
|
+
((select auth.jwt()) ->> 'role') = 'admin' AND
|
|
999
|
+
inet_client_addr() << '192.168.1.0/24'::inet -- Office network
|
|
1000
|
+
);
|
|
1001
|
+
```
|
|
1002
|
+
|
|
1003
|
+
**Note**: `inet_client_addr()` returns client IP.
|
|
1004
|
+
|
|
1005
|
+
## Advanced Patterns Summary
|
|
1006
|
+
|
|
1007
|
+
| Pattern | Use Case | Complexity | Performance Impact |
|
|
1008
|
+
|---------|----------|------------|-------------------|
|
|
1009
|
+
| Time-based | Scheduled content | Low | Low (with index) |
|
|
1010
|
+
| Hierarchical | Org > Team > User | Medium | Medium (needs indexes) |
|
|
1011
|
+
| Role-based claims | RBAC | Low | Low (JWT cached) |
|
|
1012
|
+
| AAL2 MFA | Sensitive ops | Low | None |
|
|
1013
|
+
| IP restrictions | Office-only | Low | None |
|
|
1014
|
+
|
|
1015
|
+
**Best practices**:
|
|
1016
|
+
- Prefer JWT claims over database lookups (faster)
|
|
1017
|
+
- Always index columns used in policies
|
|
1018
|
+
- Use security definer functions for complex checks
|
|
1019
|
+
- Test with EXPLAIN ANALYZE
|
|
1020
|
+
- Wrap auth functions with SELECT for caching
|
|
1021
|
+
elicit: false
|
|
1022
|
+
|
|
1023
|
+
- id: testing
|
|
1024
|
+
title: "RLS Testing Strategy"
|
|
1025
|
+
instruction: |
|
|
1026
|
+
How to test and validate RLS policies:
|
|
1027
|
+
|
|
1028
|
+
## Unit Tests
|
|
1029
|
+
|
|
1030
|
+
Test individual policies with different auth contexts:
|
|
1031
|
+
|
|
1032
|
+
```sql
|
|
1033
|
+
-- Test as user A
|
|
1034
|
+
SET request.jwt.claims = '{"sub": "user-a-uuid"}';
|
|
1035
|
+
SELECT * FROM table_name; -- Should only see user A's records
|
|
1036
|
+
|
|
1037
|
+
-- Test as user B
|
|
1038
|
+
SET request.jwt.claims = '{"sub": "user-b-uuid"}';
|
|
1039
|
+
SELECT * FROM table_name; -- Should only see user B's records
|
|
1040
|
+
```
|
|
1041
|
+
|
|
1042
|
+
## Integration Tests
|
|
1043
|
+
|
|
1044
|
+
Test with actual Supabase client:
|
|
1045
|
+
|
|
1046
|
+
```typescript
|
|
1047
|
+
// Test authenticated access
|
|
1048
|
+
const { data, error } = await supabase
|
|
1049
|
+
.from('table_name')
|
|
1050
|
+
.select('*');
|
|
1051
|
+
|
|
1052
|
+
// Verify only authorized records returned
|
|
1053
|
+
```
|
|
1054
|
+
|
|
1055
|
+
## Security Audit
|
|
1056
|
+
|
|
1057
|
+
Checklist for RLS validation:
|
|
1058
|
+
- [ ] All tables with sensitive data have RLS enabled
|
|
1059
|
+
- [ ] No accidental policy holes (test with unauthorized users)
|
|
1060
|
+
- [ ] Service role usage is documented and justified
|
|
1061
|
+
- [ ] Policies perform well (no slow queries)
|
|
1062
|
+
- [ ] Cross-tenant data leakage tested
|
|
1063
|
+
- [ ] Anonymous vs authenticated access verified
|
|
1064
|
+
- [ ] Edge cases tested (null values, missing context)
|
|
1065
|
+
|
|
1066
|
+
## Automated Testing
|
|
1067
|
+
|
|
1068
|
+
Script or framework for continuous validation.
|
|
1069
|
+
elicit: false
|
|
1070
|
+
|
|
1071
|
+
- id: migration
|
|
1072
|
+
title: "RLS Migration Scripts"
|
|
1073
|
+
instruction: |
|
|
1074
|
+
Concrete SQL migration for implementing these policies:
|
|
1075
|
+
|
|
1076
|
+
## Migration: `YYYYMMDDHHMMSS_add_rls_policies.sql`
|
|
1077
|
+
|
|
1078
|
+
```sql
|
|
1079
|
+
-- Enable RLS on tables
|
|
1080
|
+
ALTER TABLE table1 ENABLE ROW LEVEL SECURITY;
|
|
1081
|
+
ALTER TABLE table2 ENABLE ROW LEVEL SECURITY;
|
|
1082
|
+
|
|
1083
|
+
-- Drop existing policies if re-running
|
|
1084
|
+
DROP POLICY IF EXISTS "policy_name" ON table_name;
|
|
1085
|
+
|
|
1086
|
+
-- Create policies
|
|
1087
|
+
CREATE POLICY "policy_name_select"
|
|
1088
|
+
ON table_name
|
|
1089
|
+
FOR SELECT
|
|
1090
|
+
TO authenticated
|
|
1091
|
+
USING (auth.uid() = user_id);
|
|
1092
|
+
|
|
1093
|
+
CREATE POLICY "policy_name_insert"
|
|
1094
|
+
ON table_name
|
|
1095
|
+
FOR INSERT
|
|
1096
|
+
TO authenticated
|
|
1097
|
+
WITH CHECK (auth.uid() = user_id);
|
|
1098
|
+
|
|
1099
|
+
-- ... additional policies ...
|
|
1100
|
+
|
|
1101
|
+
-- Create indexes to support policies
|
|
1102
|
+
CREATE INDEX IF NOT EXISTS idx_table_user_id
|
|
1103
|
+
ON table_name(user_id);
|
|
1104
|
+
|
|
1105
|
+
-- Grant permissions
|
|
1106
|
+
GRANT SELECT, INSERT, UPDATE, DELETE ON table_name TO authenticated;
|
|
1107
|
+
GRANT SELECT ON table_name TO anon;
|
|
1108
|
+
```
|
|
1109
|
+
|
|
1110
|
+
## Rollback Migration
|
|
1111
|
+
|
|
1112
|
+
```sql
|
|
1113
|
+
-- Remove policies
|
|
1114
|
+
DROP POLICY IF EXISTS "policy_name_select" ON table_name;
|
|
1115
|
+
DROP POLICY IF EXISTS "policy_name_insert" ON table_name;
|
|
1116
|
+
|
|
1117
|
+
-- Disable RLS
|
|
1118
|
+
ALTER TABLE table_name DISABLE ROW LEVEL SECURITY;
|
|
1119
|
+
```
|
|
1120
|
+
elicit: false
|
|
1121
|
+
|
|
1122
|
+
- id: monitoring
|
|
1123
|
+
title: "RLS Monitoring & Debugging"
|
|
1124
|
+
instruction: |
|
|
1125
|
+
How to monitor and debug RLS policies:
|
|
1126
|
+
|
|
1127
|
+
## Query Performance
|
|
1128
|
+
|
|
1129
|
+
Identify slow queries caused by RLS:
|
|
1130
|
+
|
|
1131
|
+
```sql
|
|
1132
|
+
-- Check query plans
|
|
1133
|
+
EXPLAIN ANALYZE
|
|
1134
|
+
SELECT * FROM table_name;
|
|
1135
|
+
```
|
|
1136
|
+
|
|
1137
|
+
## Policy Effectiveness
|
|
1138
|
+
|
|
1139
|
+
Verify policies are being applied:
|
|
1140
|
+
|
|
1141
|
+
```sql
|
|
1142
|
+
-- Check active policies
|
|
1143
|
+
SELECT schemaname, tablename, policyname, permissive, roles, cmd, qual
|
|
1144
|
+
FROM pg_policies
|
|
1145
|
+
WHERE tablename = 'your_table';
|
|
1146
|
+
```
|
|
1147
|
+
|
|
1148
|
+
## Common Issues
|
|
1149
|
+
|
|
1150
|
+
### Issue: Policy not applying
|
|
1151
|
+
- Check RLS is enabled on table
|
|
1152
|
+
- Verify user role matches policy target
|
|
1153
|
+
- Check auth context is set correctly
|
|
1154
|
+
|
|
1155
|
+
### Issue: Performance degradation
|
|
1156
|
+
- Add indexes for policy columns
|
|
1157
|
+
- Simplify policy expressions
|
|
1158
|
+
- Consider denormalization
|
|
1159
|
+
|
|
1160
|
+
### Issue: Unexpected access
|
|
1161
|
+
- Audit all policies on table
|
|
1162
|
+
- Check for permissive vs restrictive policies
|
|
1163
|
+
- Verify no service role leakage
|
|
1164
|
+
|
|
1165
|
+
## Logging
|
|
1166
|
+
|
|
1167
|
+
Log policy violations or unexpected access patterns.
|
|
1168
|
+
elicit: false
|
|
1169
|
+
|
|
1170
|
+
- id: best-practices
|
|
1171
|
+
title: "RLS Best Practices"
|
|
1172
|
+
instruction: |
|
|
1173
|
+
## Design Principles
|
|
1174
|
+
|
|
1175
|
+
1. **Start Restrictive**: Default deny, explicitly allow
|
|
1176
|
+
2. **Minimize Policy Complexity**: Simpler policies are easier to audit
|
|
1177
|
+
3. **Use Helper Functions**: Encapsulate complex logic
|
|
1178
|
+
4. **Index Policy Columns**: Performance is critical
|
|
1179
|
+
5. **Test Extensively**: Security bugs are costly
|
|
1180
|
+
6. **Document Everything**: Future you will thank you
|
|
1181
|
+
7. **Audit Regularly**: Policies drift over time
|
|
1182
|
+
8. **Avoid Service Role**: Use it only when absolutely necessary
|
|
1183
|
+
|
|
1184
|
+
## Common Pitfalls
|
|
1185
|
+
|
|
1186
|
+
- Forgetting to enable RLS on new tables
|
|
1187
|
+
- Policy expressions with poor performance
|
|
1188
|
+
- Not testing with actual user contexts
|
|
1189
|
+
- Overly permissive catch-all policies
|
|
1190
|
+
- Mixing USING and WITH CHECK incorrectly
|
|
1191
|
+
- Not considering null values in policies
|
|
1192
|
+
|
|
1193
|
+
## Security Checklist
|
|
1194
|
+
|
|
1195
|
+
- [ ] All sensitive tables have RLS enabled
|
|
1196
|
+
- [ ] Policies tested with unauthorized users
|
|
1197
|
+
- [ ] Anonymous access limited to public data only
|
|
1198
|
+
- [ ] Service role usage is minimal and documented
|
|
1199
|
+
- [ ] Policies use indexes for performance
|
|
1200
|
+
- [ ] Multi-tenant isolation is verified
|
|
1201
|
+
- [ ] Edge cases tested (nulls, empty results)
|
|
1202
|
+
- [ ] Policies are documented and reviewed
|
|
1203
|
+
elicit: false
|