@dewtech/dare-cli 2.17.0 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +98 -3
- package/dist/__tests__/confidence.test.d.ts +2 -0
- package/dist/__tests__/confidence.test.d.ts.map +1 -0
- package/dist/__tests__/confidence.test.js +73 -0
- package/dist/__tests__/confidence.test.js.map +1 -0
- package/dist/__tests__/datamodel.test.d.ts +2 -0
- package/dist/__tests__/datamodel.test.d.ts.map +1 -0
- package/dist/__tests__/datamodel.test.js +131 -0
- package/dist/__tests__/datamodel.test.js.map +1 -0
- package/dist/__tests__/dna-detector.test.d.ts +2 -0
- package/dist/__tests__/dna-detector.test.d.ts.map +1 -0
- package/dist/__tests__/dna-detector.test.js +97 -0
- package/dist/__tests__/dna-detector.test.js.map +1 -0
- package/dist/__tests__/dna-facts.test.d.ts +2 -0
- package/dist/__tests__/dna-facts.test.d.ts.map +1 -0
- package/dist/__tests__/dna-facts.test.js +44 -0
- package/dist/__tests__/dna-facts.test.js.map +1 -0
- package/dist/__tests__/graph-renderer.test.d.ts +2 -0
- package/dist/__tests__/graph-renderer.test.d.ts.map +1 -0
- package/dist/__tests__/graph-renderer.test.js +85 -0
- package/dist/__tests__/graph-renderer.test.js.map +1 -0
- package/dist/__tests__/migration.test.d.ts +2 -0
- package/dist/__tests__/migration.test.d.ts.map +1 -0
- package/dist/__tests__/migration.test.js +77 -0
- package/dist/__tests__/migration.test.js.map +1 -0
- package/dist/__tests__/module-detector.test.d.ts +2 -0
- package/dist/__tests__/module-detector.test.d.ts.map +1 -0
- package/dist/__tests__/module-detector.test.js +83 -0
- package/dist/__tests__/module-detector.test.js.map +1 -0
- package/dist/__tests__/refine.test.js +49 -49
- package/dist/__tests__/reverse-facts.test.d.ts +2 -0
- package/dist/__tests__/reverse-facts.test.d.ts.map +1 -0
- package/dist/__tests__/reverse-facts.test.js +78 -0
- package/dist/__tests__/reverse-facts.test.js.map +1 -0
- package/dist/__tests__/review.test.js +38 -38
- package/dist/__tests__/validate.test.js +65 -65
- package/dist/bin/dare.js +32 -3
- package/dist/bin/dare.js.map +1 -1
- package/dist/commands/blueprint.js +122 -122
- package/dist/commands/dag.d.ts.map +1 -1
- package/dist/commands/dag.js +43 -79
- package/dist/commands/dag.js.map +1 -1
- package/dist/commands/dna.d.ts +3 -0
- package/dist/commands/dna.d.ts.map +1 -0
- package/dist/commands/dna.js +69 -0
- package/dist/commands/dna.js.map +1 -0
- package/dist/commands/migrate.d.ts +3 -0
- package/dist/commands/migrate.d.ts.map +1 -0
- package/dist/commands/migrate.js +101 -0
- package/dist/commands/migrate.js.map +1 -0
- package/dist/commands/new.d.ts +16 -0
- package/dist/commands/new.d.ts.map +1 -0
- package/dist/commands/new.js +103 -0
- package/dist/commands/new.js.map +1 -0
- package/dist/commands/reverse.d.ts +3 -0
- package/dist/commands/reverse.d.ts.map +1 -0
- package/dist/commands/reverse.js +201 -0
- package/dist/commands/reverse.js.map +1 -0
- package/dist/commands/welcome.d.ts +14 -0
- package/dist/commands/welcome.d.ts.map +1 -0
- package/dist/commands/welcome.js +29 -0
- package/dist/commands/welcome.js.map +1 -0
- package/dist/skills/commands/add.d.ts +23 -0
- package/dist/skills/commands/add.d.ts.map +1 -0
- package/dist/skills/commands/add.js +206 -0
- package/dist/skills/commands/add.js.map +1 -0
- package/dist/skills/commands/info.d.ts +14 -0
- package/dist/skills/commands/info.d.ts.map +1 -0
- package/dist/skills/commands/info.js +99 -0
- package/dist/skills/commands/info.js.map +1 -0
- package/dist/skills/commands/list.d.ts +19 -0
- package/dist/skills/commands/list.d.ts.map +1 -0
- package/dist/skills/commands/list.js +163 -0
- package/dist/skills/commands/list.js.map +1 -0
- package/dist/skills/commands/publish.d.ts +56 -0
- package/dist/skills/commands/publish.d.ts.map +1 -0
- package/dist/skills/commands/publish.js +272 -0
- package/dist/skills/commands/publish.js.map +1 -0
- package/dist/skills/commands/remove.d.ts +19 -0
- package/dist/skills/commands/remove.d.ts.map +1 -0
- package/dist/skills/commands/remove.js +96 -0
- package/dist/skills/commands/remove.js.map +1 -0
- package/dist/skills/commands/update.d.ts +31 -0
- package/dist/skills/commands/update.d.ts.map +1 -0
- package/dist/skills/commands/update.js +132 -0
- package/dist/skills/commands/update.js.map +1 -0
- package/dist/skills/index.d.ts +22 -0
- package/dist/skills/index.d.ts.map +1 -0
- package/dist/skills/index.js +33 -0
- package/dist/skills/index.js.map +1 -0
- package/dist/skills/manifest.d.ts +54 -0
- package/dist/skills/manifest.d.ts.map +1 -0
- package/dist/skills/manifest.js +162 -0
- package/dist/skills/manifest.js.map +1 -0
- package/dist/skills/registry-local.d.ts +67 -0
- package/dist/skills/registry-local.d.ts.map +1 -0
- package/dist/skills/registry-local.js +130 -0
- package/dist/skills/registry-local.js.map +1 -0
- package/dist/skills/registry-mock.json +109 -0
- package/dist/skills/registry-remote.d.ts +110 -0
- package/dist/skills/registry-remote.d.ts.map +1 -0
- package/dist/skills/registry-remote.js +246 -0
- package/dist/skills/registry-remote.js.map +1 -0
- package/dist/skills/registry.d.ts +49 -0
- package/dist/skills/registry.d.ts.map +1 -0
- package/dist/skills/registry.js +94 -0
- package/dist/skills/registry.js.map +1 -0
- package/dist/skills/tests/manifest.spec.d.ts +8 -0
- package/dist/skills/tests/manifest.spec.d.ts.map +1 -0
- package/dist/skills/tests/manifest.spec.js +176 -0
- package/dist/skills/tests/manifest.spec.js.map +1 -0
- package/dist/skills/tests/publish.spec.d.ts +12 -0
- package/dist/skills/tests/publish.spec.d.ts.map +1 -0
- package/dist/skills/tests/publish.spec.js +276 -0
- package/dist/skills/tests/publish.spec.js.map +1 -0
- package/dist/skills/tests/registry-local.spec.d.ts +8 -0
- package/dist/skills/tests/registry-local.spec.d.ts.map +1 -0
- package/dist/skills/tests/registry-local.spec.js +231 -0
- package/dist/skills/tests/registry-local.spec.js.map +1 -0
- package/dist/skills/tests/registry.spec.d.ts +7 -0
- package/dist/skills/tests/registry.spec.d.ts.map +1 -0
- package/dist/skills/tests/registry.spec.js +58 -0
- package/dist/skills/tests/registry.spec.js.map +1 -0
- package/dist/skills/tests/remote-registry.spec.d.ts +9 -0
- package/dist/skills/tests/remote-registry.spec.d.ts.map +1 -0
- package/dist/skills/tests/remote-registry.spec.js +357 -0
- package/dist/skills/tests/remote-registry.spec.js.map +1 -0
- package/dist/skills/tests/update.spec.d.ts +9 -0
- package/dist/skills/tests/update.spec.d.ts.map +1 -0
- package/dist/skills/tests/update.spec.js +166 -0
- package/dist/skills/tests/update.spec.js.map +1 -0
- package/dist/utils/banner.d.ts +28 -0
- package/dist/utils/banner.d.ts.map +1 -0
- package/dist/utils/banner.js +77 -0
- package/dist/utils/banner.js.map +1 -0
- package/dist/utils/banner.spec.d.ts +5 -0
- package/dist/utils/banner.spec.d.ts.map +1 -0
- package/dist/utils/banner.spec.js +253 -0
- package/dist/utils/banner.spec.js.map +1 -0
- package/dist/utils/confidence.d.ts +41 -0
- package/dist/utils/confidence.d.ts.map +1 -0
- package/dist/utils/confidence.js +101 -0
- package/dist/utils/confidence.js.map +1 -0
- package/dist/utils/datamodel.d.ts +41 -0
- package/dist/utils/datamodel.d.ts.map +1 -0
- package/dist/utils/datamodel.js +535 -0
- package/dist/utils/datamodel.js.map +1 -0
- package/dist/utils/dna-detector.d.ts +61 -0
- package/dist/utils/dna-detector.d.ts.map +1 -0
- package/dist/utils/dna-detector.js +354 -0
- package/dist/utils/dna-detector.js.map +1 -0
- package/dist/utils/dna-facts.d.ts +13 -0
- package/dist/utils/dna-facts.d.ts.map +1 -0
- package/dist/utils/dna-facts.js +109 -0
- package/dist/utils/dna-facts.js.map +1 -0
- package/dist/utils/excalidraw-renderer.d.ts +11 -71
- package/dist/utils/excalidraw-renderer.d.ts.map +1 -1
- package/dist/utils/excalidraw-renderer.js +29 -162
- package/dist/utils/excalidraw-renderer.js.map +1 -1
- package/dist/utils/graph-renderer.d.ts +115 -0
- package/dist/utils/graph-renderer.d.ts.map +1 -0
- package/dist/utils/graph-renderer.js +216 -0
- package/dist/utils/graph-renderer.js.map +1 -0
- package/dist/utils/migration.d.ts +64 -0
- package/dist/utils/migration.d.ts.map +1 -0
- package/dist/utils/migration.js +183 -0
- package/dist/utils/migration.js.map +1 -0
- package/dist/utils/module-detector.d.ts +46 -0
- package/dist/utils/module-detector.d.ts.map +1 -0
- package/dist/utils/module-detector.js +348 -0
- package/dist/utils/module-detector.js.map +1 -0
- package/dist/utils/project-generator.js +252 -252
- package/dist/utils/reverse-facts.d.ts +50 -0
- package/dist/utils/reverse-facts.d.ts.map +1 -0
- package/dist/utils/reverse-facts.js +291 -0
- package/dist/utils/reverse-facts.js.map +1 -0
- package/dist/utils/stack-bootstrap.js +371 -371
- package/package.json +8 -3
- package/templates/DARE-dag-example.yaml +280 -280
- package/templates/UPDATE-MANIFEST.json +48 -48
- package/templates/backend/node-nestjs/.env.example +9 -9
- package/templates/backend/node-nestjs/nest-cli.json +8 -8
- package/templates/backend/node-nestjs/package.json +50 -50
- package/templates/backend/node-nestjs/src/app.controller.ts +12 -12
- package/templates/backend/node-nestjs/src/app.module.ts +15 -15
- package/templates/backend/node-nestjs/src/app.service.ts +8 -8
- package/templates/backend/node-nestjs/src/main.ts +24 -24
- package/templates/backend/node-nestjs/tsconfig.json +21 -21
- package/templates/backend/php-laravel/.env.example +22 -22
- package/templates/backend/php-laravel/app/Http/Controllers/HealthController.php +15 -15
- package/templates/backend/php-laravel/composer.json +40 -40
- package/templates/backend/python-fastapi/.env.example +4 -4
- package/templates/backend/python-fastapi/app/api/router.py +8 -8
- package/templates/backend/python-fastapi/app/core/config.py +20 -20
- package/templates/backend/python-fastapi/main.py +35 -35
- package/templates/backend/python-fastapi/requirements.txt +13 -13
- package/templates/backend/rust-axum/.env.example +3 -3
- package/templates/backend/rust-axum/Cargo.toml +23 -23
- package/templates/backend/rust-axum/src/errors.rs +30 -30
- package/templates/backend/rust-axum/src/main.rs +32 -32
- package/templates/backend/rust-axum/src/routes.rs +6 -6
- package/templates/frontend/leptos-csr/.cargo/config.toml +2 -2
- package/templates/frontend/leptos-csr/Cargo.toml +16 -16
- package/templates/frontend/leptos-csr/Trunk.toml +10 -10
- package/templates/frontend/leptos-csr/index.html +11 -11
- package/templates/frontend/leptos-csr/src/lib.rs +20 -20
- package/templates/frontend/leptos-csr/style/main.scss +19 -19
- package/templates/frontend/leptos-fullstack/.cargo/config.toml +4 -4
- package/templates/frontend/leptos-fullstack/Cargo.toml +56 -56
- package/templates/frontend/leptos-fullstack/src/app.rs +49 -49
- package/templates/frontend/leptos-fullstack/src/lib.rs +9 -9
- package/templates/frontend/leptos-fullstack/src/main.rs +29 -29
- package/templates/frontend/leptos-fullstack/style/main.scss +19 -19
- package/templates/frontend/react/index.html +12 -12
- package/templates/frontend/react/package.json +35 -35
- package/templates/frontend/react/src/App.tsx +25 -25
- package/templates/frontend/react/src/main.tsx +9 -9
- package/templates/frontend/vue/package.json +32 -32
- package/templates/frontend/vue/src/App.vue +7 -7
- package/templates/frontend/vue/src/main.ts +10 -10
- package/templates/frontend/vue/src/router/index.ts +14 -14
- package/templates/frontend/vue/src/views/HomeView.vue +6 -6
- package/templates/hooks/pre-commit-dare-validate +24 -24
- package/templates/ide/antigravity/.agents/skills/dare-ax/SKILL.md +152 -0
- package/templates/ide/antigravity/.agents/skills/dare-dag-build/SKILL.md +154 -0
- package/templates/ide/antigravity/.agents/skills/dare-dag-run/SKILL.md +130 -0
- package/templates/ide/antigravity/.agents/skills/dare-dag-runner/SKILL.md +203 -203
- package/templates/ide/antigravity/.agents/skills/dare-dna/SKILL.md +63 -0
- package/templates/ide/antigravity/.agents/skills/dare-docker/SKILL.md +315 -0
- package/templates/ide/antigravity/.agents/skills/dare-frontend-design/SKILL.md +192 -0
- package/templates/ide/antigravity/.agents/skills/dare-laravel-api/SKILL.md +337 -0
- package/templates/ide/antigravity/.agents/skills/dare-layered-design/SKILL.md +166 -0
- package/templates/ide/antigravity/.agents/skills/dare-llm-integration/SKILL.md +217 -0
- package/templates/ide/antigravity/.agents/skills/dare-migrate/SKILL.md +61 -0
- package/templates/ide/antigravity/.agents/skills/dare-quality-telemetry/SKILL.md +187 -0
- package/templates/ide/antigravity/.agents/skills/dare-realtime/SKILL.md +217 -0
- package/templates/ide/antigravity/.agents/skills/dare-refine/SKILL.md +114 -114
- package/templates/ide/antigravity/.agents/skills/dare-reverse/SKILL.md +108 -0
- package/templates/ide/antigravity/.agents/skills/dare-review/SKILL.md +111 -111
- package/templates/ide/antigravity/.agents/skills/dare-rust-leptos/SKILL.md +263 -0
- package/templates/ide/antigravity/.agents/skills/dare-rust-workspace/SKILL.md +275 -275
- package/templates/ide/antigravity/.agents/skills/dare-security/SKILL.md +274 -0
- package/templates/ide/antigravity/.agents/skills/dare-tasks/SKILL.md +265 -265
- package/templates/ide/antigravity/.agents/skills/dare-telemetry/SKILL.md +188 -0
- package/templates/ide/antigravity/.agents/skills/skill-fastapi-api/SKILL.md +343 -0
- package/templates/ide/antigravity/.agents/skills/skill-go-gin-api/SKILL.md +377 -0
- package/templates/ide/antigravity/.agents/skills/skill-mcp-server/SKILL.md +382 -0
- package/templates/ide/antigravity/.agents/skills/skill-nestjs-api/SKILL.md +326 -0
- package/templates/ide/antigravity/.agents/skills/skill-rails-api/SKILL.md +393 -0
- package/templates/ide/antigravity/templates/BLUEPRINT-template.md +193 -193
- package/templates/ide/antigravity/templates/DESIGN-template.md +129 -129
- package/templates/ide/antigravity/templates/TASK-SPEC-template.md +141 -141
- package/templates/ide/claude/.claude/commands/dare-ax.md +131 -0
- package/templates/ide/claude/.claude/commands/dare-blueprint.md +134 -134
- package/templates/ide/claude/.claude/commands/dare-bugfix-design.md +119 -0
- package/templates/ide/claude/.claude/commands/dare-dag-build.md +151 -151
- package/templates/ide/claude/.claude/commands/dare-dag-run.md +109 -109
- package/templates/ide/claude/.claude/commands/dare-dag-runner.md +117 -0
- package/templates/ide/claude/.claude/commands/dare-dag-viz.md +197 -197
- package/templates/ide/claude/.claude/commands/dare-design.md +69 -69
- package/templates/ide/claude/.claude/commands/dare-dna.md +75 -0
- package/templates/ide/claude/.claude/commands/dare-docker.md +207 -0
- package/templates/ide/claude/.claude/commands/dare-execute.md +152 -152
- package/templates/ide/claude/.claude/commands/dare-feature-design.md +147 -0
- package/templates/ide/claude/.claude/commands/dare-frontend-design.md +149 -0
- package/templates/ide/claude/.claude/commands/dare-laravel-api.md +211 -0
- package/templates/ide/claude/.claude/commands/dare-layered-design.md +124 -0
- package/templates/ide/claude/.claude/commands/dare-llm-integration.md +148 -0
- package/templates/ide/claude/.claude/commands/dare-migrate.md +72 -0
- package/templates/ide/claude/.claude/commands/dare-quality-telemetry.md +166 -0
- package/templates/ide/claude/.claude/commands/dare-realtime.md +159 -0
- package/templates/ide/claude/.claude/commands/dare-refine.md +145 -145
- package/templates/ide/claude/.claude/commands/dare-reverse.md +139 -0
- package/templates/ide/claude/.claude/commands/dare-review.md +113 -113
- package/templates/ide/claude/.claude/commands/dare-rust-leptos.md +269 -269
- package/templates/ide/claude/.claude/commands/dare-rust-workspace.md +209 -209
- package/templates/ide/claude/.claude/commands/dare-security.md +232 -232
- package/templates/ide/claude/.claude/commands/dare-tasks.md +70 -70
- package/templates/ide/claude/.claude/commands/dare-telemetry.md +132 -0
- package/templates/ide/claude/.claude/commands/skill-fastapi-api.md +205 -0
- package/templates/ide/claude/.claude/commands/skill-go-gin-api.md +232 -0
- package/templates/ide/claude/.claude/commands/skill-mcp-server.md +228 -0
- package/templates/ide/claude/.claude/commands/skill-nestjs-api.md +210 -0
- package/templates/ide/claude/.claude/commands/skill-rails-api.md +236 -0
- package/templates/ide/claude/.claude/settings.example.json +35 -35
- package/templates/ide/claude/CLAUDE.md +146 -146
- package/templates/ide/claude/templates/BLUEPRINT-template.md +193 -193
- package/templates/ide/claude/templates/DESIGN-template.md +129 -129
- package/templates/ide/claude/templates/TASK-SPEC-template.md +141 -141
- package/templates/ide/cursor/.cursor/commands/dag-viz.md +139 -0
- package/templates/ide/cursor/.cursor/commands/generate-blueprint.md +86 -86
- package/templates/ide/cursor/.cursor/commands/generate-design.md +35 -35
- package/templates/ide/cursor/.cursor/commands/generate-tasks.md +184 -184
- package/templates/ide/cursor/.cursor/commands/refine-task.md +107 -107
- package/templates/ide/cursor/.cursor/commands/review-task.md +91 -91
- package/templates/ide/cursor/.cursor/commands/run-dag.md +110 -110
- package/templates/ide/cursor/.cursor/rules/skill-ax.mdc +263 -0
- package/templates/ide/cursor/.cursor/rules/skill-dag-build.mdc +173 -0
- package/templates/ide/cursor/.cursor/rules/skill-dag-run.mdc +134 -0
- package/templates/ide/cursor/.cursor/rules/skill-dag-runner.mdc +221 -221
- package/templates/ide/cursor/.cursor/rules/skill-dna.mdc +63 -0
- package/templates/ide/cursor/.cursor/rules/skill-fastapi-api.mdc +352 -0
- package/templates/ide/cursor/.cursor/rules/skill-frontend-design.mdc +244 -0
- package/templates/ide/cursor/.cursor/rules/skill-go-gin-api.mdc +371 -0
- package/templates/ide/cursor/.cursor/rules/skill-layered-design.mdc +266 -0
- package/templates/ide/cursor/.cursor/rules/skill-llm-integration.mdc +295 -0
- package/templates/ide/cursor/.cursor/rules/skill-mcp-server.mdc +367 -0
- package/templates/ide/cursor/.cursor/rules/skill-migrate.mdc +58 -0
- package/templates/ide/cursor/.cursor/rules/skill-nestjs-api.mdc +346 -0
- package/templates/ide/cursor/.cursor/rules/skill-quality-telemetry.mdc +248 -0
- package/templates/ide/cursor/.cursor/rules/skill-rails-api.mdc +400 -0
- package/templates/ide/cursor/.cursor/rules/skill-realtime.mdc +262 -0
- package/templates/ide/cursor/.cursor/rules/skill-reverse.mdc +107 -0
- package/templates/ide/cursor/.cursor/rules/skill-rust-leptos.mdc +281 -0
- package/templates/ide/cursor/.cursor/rules/skill-rust-workspace.mdc +312 -312
- package/templates/ide/cursor/.cursor/rules/skill-security.mdc +245 -245
- package/templates/ide/cursor/templates/BLUEPRINT-template.md +193 -193
- package/templates/ide/cursor/templates/DESIGN-template.md +129 -129
- package/templates/ide/cursor/templates/TASK-SPEC-template.md +141 -141
- package/templates/shared/docker-compose.yml +41 -41
- package/dist/__tests__/dag-runner/adapters.test.d.ts +0 -2
- package/dist/__tests__/dag-runner/adapters.test.d.ts.map +0 -1
- package/dist/__tests__/dag-runner/adapters.test.js +0 -134
- package/dist/__tests__/dag-runner/adapters.test.js.map +0 -1
- package/dist/dag-runner/adapters/antigravity.d.ts +0 -6
- package/dist/dag-runner/adapters/antigravity.d.ts.map +0 -1
- package/dist/dag-runner/adapters/antigravity.js +0 -54
- package/dist/dag-runner/adapters/antigravity.js.map +0 -1
- package/dist/dag-runner/adapters/claude.d.ts +0 -6
- package/dist/dag-runner/adapters/claude.d.ts.map +0 -1
- package/dist/dag-runner/adapters/claude.js +0 -48
- package/dist/dag-runner/adapters/claude.js.map +0 -1
- package/dist/dag-runner/adapters/cursor.d.ts +0 -6
- package/dist/dag-runner/adapters/cursor.d.ts.map +0 -1
- package/dist/dag-runner/adapters/cursor.js +0 -58
- package/dist/dag-runner/adapters/cursor.js.map +0 -1
- package/dist/dag-runner/adapters/index.d.ts +0 -46
- package/dist/dag-runner/adapters/index.d.ts.map +0 -1
- package/dist/dag-runner/adapters/index.js +0 -55
- package/dist/dag-runner/adapters/index.js.map +0 -1
- package/dist/dag-runner/utils/timeout.d.ts +0 -27
- package/dist/dag-runner/utils/timeout.d.ts.map +0 -1
- package/dist/dag-runner/utils/timeout.js +0 -55
- package/dist/dag-runner/utils/timeout.js.map +0 -1
|
@@ -1,197 +1,197 @@
|
|
|
1
|
-
# /dare-dag-viz — Visualizar DAG com Excalidraw
|
|
2
|
-
|
|
3
|
-
Gera diagrama interativo `.excalidraw` a partir do `dare-dag.yaml` atual, com cores semânticas por complexidade e status visual das tasks.
|
|
4
|
-
|
|
5
|
-
## O que faz
|
|
6
|
-
|
|
7
|
-
1. **Lê** `DARE/dare-dag.yaml` (grafo de tasks + dependências)
|
|
8
|
-
2. **Mapeia** cada task para um retângulo Excalidraw com:
|
|
9
|
-
- Cor baseada em `complexity` (LOW=azul, MED=laranja, HIGH=rosa)
|
|
10
|
-
- Status visual (PENDING/RUNNING/DONE/FAILED)
|
|
11
|
-
- ID + nome da task
|
|
12
|
-
3. **Agrupa** tasks por `rank` em colunas verticais (swim lanes)
|
|
13
|
-
4. **Cria** setas para cada dependência (`depends_on`)
|
|
14
|
-
5. **Salva** em `DARE/dag-graph.excalidraw`
|
|
15
|
-
|
|
16
|
-
Output é um arquivo **editável e interativo** — abre direto em https://excalidraw.com.
|
|
17
|
-
|
|
18
|
-
## Convenções visuais
|
|
19
|
-
|
|
20
|
-
Referência: `/docs/DESIGN-TOKENS-EXCALIDRAW.md`
|
|
21
|
-
|
|
22
|
-
**Cores por complexidade:**
|
|
23
|
-
- 🔵 **Azul** (#e3f2fd) = LOW
|
|
24
|
-
- 🟠 **Laranja** (#fff3e0) = MEDIUM
|
|
25
|
-
- 🔴 **Rosa** (#fce4ec) = HIGH
|
|
26
|
-
|
|
27
|
-
**Status:**
|
|
28
|
-
- ⏳ PENDING = cinza, stroke normal
|
|
29
|
-
- ⚙️ RUNNING = azul, stroke pontilhado
|
|
30
|
-
- ✅ DONE = verde
|
|
31
|
-
- ❌ FAILED = vermelho
|
|
32
|
-
|
|
33
|
-
**Posicionamento:**
|
|
34
|
-
- Cada task ocupa 120×60px
|
|
35
|
-
- Tasks no mesmo rank ficam lado a lado (swim lane)
|
|
36
|
-
- Setas conectam dependências
|
|
37
|
-
|
|
38
|
-
## Exemplo de output
|
|
39
|
-
|
|
40
|
-
Arquivo `DARE/dag-graph.excalidraw` com estrutura:
|
|
41
|
-
|
|
42
|
-
```
|
|
43
|
-
Rank 1
|
|
44
|
-
├── task-001 (LOW, DONE)
|
|
45
|
-
├── task-002 (HIGH, PENDING)
|
|
46
|
-
|
|
47
|
-
Rank 2
|
|
48
|
-
├── task-003 (MEDIUM, RUNNING) ← depende de task-001
|
|
49
|
-
├── task-004 (LOW, PENDING) ← depende de task-001
|
|
50
|
-
|
|
51
|
-
Rank 3
|
|
52
|
-
└── task-005 (HIGH, PENDING) ← depende de task-003 e task-004
|
|
53
|
-
```
|
|
54
|
-
|
|
55
|
-
## Como usar
|
|
56
|
-
|
|
57
|
-
### Primeira vez
|
|
58
|
-
|
|
59
|
-
```bash
|
|
60
|
-
/dare-dag-viz
|
|
61
|
-
```
|
|
62
|
-
|
|
63
|
-
Claude Code vai:
|
|
64
|
-
1. Ler `DARE/dare-dag.yaml`
|
|
65
|
-
2. Gerar JSON `.excalidraw`
|
|
66
|
-
3. Salvar em `DARE/dag-graph.excalidraw`
|
|
67
|
-
4. Output: "✅ DAG gerado — abra em https://excalidraw.com"
|
|
68
|
-
|
|
69
|
-
### Atualizar após mudanças
|
|
70
|
-
|
|
71
|
-
Sempre que você atualiza `dare-dag.yaml`:
|
|
72
|
-
|
|
73
|
-
```bash
|
|
74
|
-
/dare-dag-viz
|
|
75
|
-
```
|
|
76
|
-
|
|
77
|
-
Isso regenera o diagrama com as novas tasks/dependências.
|
|
78
|
-
|
|
79
|
-
### Abrir e editar
|
|
80
|
-
|
|
81
|
-
1. Acesse https://excalidraw.com
|
|
82
|
-
2. File → Open → selecione `DARE/dag-graph.excalidraw`
|
|
83
|
-
3. Edite livremente:
|
|
84
|
-
- Mova elementos
|
|
85
|
-
- Customize cores/textos
|
|
86
|
-
- Adicione anotações
|
|
87
|
-
4. Salve no mesmo arquivo
|
|
88
|
-
|
|
89
|
-
Dica: Se editou manualmente e quer regenerar com `dare-dag-viz` de novo, faça backup antes.
|
|
90
|
-
|
|
91
|
-
## Detalhes técnicos
|
|
92
|
-
|
|
93
|
-
### Estrutura do JSON gerado
|
|
94
|
-
|
|
95
|
-
```json
|
|
96
|
-
{
|
|
97
|
-
"elements": [
|
|
98
|
-
{
|
|
99
|
-
"id": "task-001",
|
|
100
|
-
"type": "rectangle",
|
|
101
|
-
"x": 20, "y": 20,
|
|
102
|
-
"width": 120, "height": 60,
|
|
103
|
-
"backgroundColor": "#e3f2fd",
|
|
104
|
-
"stroke": "#1976d2",
|
|
105
|
-
"text": "task-001\nSetup Auth\n[LOW]",
|
|
106
|
-
"fontSize": 12,
|
|
107
|
-
"roundness": { "type": 2, "value": 6 }
|
|
108
|
-
},
|
|
109
|
-
{
|
|
110
|
-
"type": "arrow",
|
|
111
|
-
"startBinding": { "elementId": "task-001" },
|
|
112
|
-
"endBinding": { "elementId": "task-003" },
|
|
113
|
-
"stroke": "#999"
|
|
114
|
-
}
|
|
115
|
-
],
|
|
116
|
-
"appState": {
|
|
117
|
-
"gridMode": "grid",
|
|
118
|
-
"gridSize": 20
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
```
|
|
122
|
-
|
|
123
|
-
### Algoritmo de posicionamento
|
|
124
|
-
|
|
125
|
-
1. **Calcular ranks** — depth-first do DAG
|
|
126
|
-
```
|
|
127
|
-
rank = 1 + max(rank of dependencies)
|
|
128
|
-
```
|
|
129
|
-
|
|
130
|
-
2. **Agrupar por rank**
|
|
131
|
-
```
|
|
132
|
-
Rank 1: [task-001, task-002]
|
|
133
|
-
Rank 2: [task-003, task-004]
|
|
134
|
-
```
|
|
135
|
-
|
|
136
|
-
3. **Posicionar**
|
|
137
|
-
```
|
|
138
|
-
x = 20 + (taskIndex * 140)
|
|
139
|
-
y = 20 + (rank - 1) * 160
|
|
140
|
-
```
|
|
141
|
-
|
|
142
|
-
4. **Desenhar setas**
|
|
143
|
-
```
|
|
144
|
-
Para cada depends_on: arrow(source → target)
|
|
145
|
-
```
|
|
146
|
-
|
|
147
|
-
## Campos esperados em dare-dag.yaml
|
|
148
|
-
|
|
149
|
-
```yaml
|
|
150
|
-
tasks:
|
|
151
|
-
task-001:
|
|
152
|
-
name: "Setup Auth"
|
|
153
|
-
complexity: "LOW" # ← determina cor
|
|
154
|
-
rank: 1 # ← se não existir, é calculado
|
|
155
|
-
depends_on: [] # ← usada para setas
|
|
156
|
-
status: "DONE" # ← determina stroke/fill
|
|
157
|
-
subtask_prompt: "..." # ← (opcional)
|
|
158
|
-
```
|
|
159
|
-
|
|
160
|
-
**Campos obrigatórios:** `name`, `complexity`
|
|
161
|
-
**Campos opcionais:** `rank` (calculado), `status` (default PENDING), `depends_on` (default [])
|
|
162
|
-
|
|
163
|
-
## Troubleshooting
|
|
164
|
-
|
|
165
|
-
### "File not found: DARE/dare-dag.yaml"
|
|
166
|
-
Certifique-se de que está em um projeto DARE. Se não, rode:
|
|
167
|
-
```bash
|
|
168
|
-
dare discover
|
|
169
|
-
```
|
|
170
|
-
|
|
171
|
-
### "JSON inválido"
|
|
172
|
-
Valide seu `dare-dag.yaml`:
|
|
173
|
-
```bash
|
|
174
|
-
dare dag validate
|
|
175
|
-
```
|
|
176
|
-
|
|
177
|
-
### Diagrama muito grande/pequeno
|
|
178
|
-
Abra em Excalidraw e ajuste com Ctrl+Mouse ou pinch zoom.
|
|
179
|
-
|
|
180
|
-
## Próximos passos
|
|
181
|
-
|
|
182
|
-
- 🎨 Customize as cores em `docs/DESIGN-TOKENS-EXCALIDRAW.md`
|
|
183
|
-
- 📤 Exporte para PNG com botão "Export to Image" no Excalidraw
|
|
184
|
-
- 🔄 Atualize após cada `dare design` ou `dare execute`
|
|
185
|
-
- 📊 Compartilhe com stakeholders (Excalidraw é colaborativo)
|
|
186
|
-
|
|
187
|
-
## Referência de design
|
|
188
|
-
|
|
189
|
-
Ver `/docs/DESIGN-TOKENS-EXCALIDRAW.md` para detalhes de cores, fonts, tamanhos, e créditos.
|
|
190
|
-
|
|
191
|
-
## Licença
|
|
192
|
-
|
|
193
|
-
Esta skill é parte do DARE CLI e está sob
|
|
194
|
-
|
|
195
|
-
Você pode usar, modificar
|
|
196
|
-
|
|
197
|
-
Créditos: Inspiração na [Excalidraw Diagram Skill](https://github.com/coleam00/excalidraw-diagram-skill) por Cole Medin.
|
|
1
|
+
# /dare-dag-viz — Visualizar DAG com Excalidraw
|
|
2
|
+
|
|
3
|
+
Gera diagrama interativo `.excalidraw` a partir do `dare-dag.yaml` atual, com cores semânticas por complexidade e status visual das tasks.
|
|
4
|
+
|
|
5
|
+
## O que faz
|
|
6
|
+
|
|
7
|
+
1. **Lê** `DARE/dare-dag.yaml` (grafo de tasks + dependências)
|
|
8
|
+
2. **Mapeia** cada task para um retângulo Excalidraw com:
|
|
9
|
+
- Cor baseada em `complexity` (LOW=azul, MED=laranja, HIGH=rosa)
|
|
10
|
+
- Status visual (PENDING/RUNNING/DONE/FAILED)
|
|
11
|
+
- ID + nome da task
|
|
12
|
+
3. **Agrupa** tasks por `rank` em colunas verticais (swim lanes)
|
|
13
|
+
4. **Cria** setas para cada dependência (`depends_on`)
|
|
14
|
+
5. **Salva** em `DARE/dag-graph.excalidraw`
|
|
15
|
+
|
|
16
|
+
Output é um arquivo **editável e interativo** — abre direto em https://excalidraw.com.
|
|
17
|
+
|
|
18
|
+
## Convenções visuais
|
|
19
|
+
|
|
20
|
+
Referência: `/docs/DESIGN-TOKENS-EXCALIDRAW.md`
|
|
21
|
+
|
|
22
|
+
**Cores por complexidade:**
|
|
23
|
+
- 🔵 **Azul** (#e3f2fd) = LOW
|
|
24
|
+
- 🟠 **Laranja** (#fff3e0) = MEDIUM
|
|
25
|
+
- 🔴 **Rosa** (#fce4ec) = HIGH
|
|
26
|
+
|
|
27
|
+
**Status:**
|
|
28
|
+
- ⏳ PENDING = cinza, stroke normal
|
|
29
|
+
- ⚙️ RUNNING = azul, stroke pontilhado
|
|
30
|
+
- ✅ DONE = verde
|
|
31
|
+
- ❌ FAILED = vermelho
|
|
32
|
+
|
|
33
|
+
**Posicionamento:**
|
|
34
|
+
- Cada task ocupa 120×60px
|
|
35
|
+
- Tasks no mesmo rank ficam lado a lado (swim lane)
|
|
36
|
+
- Setas conectam dependências
|
|
37
|
+
|
|
38
|
+
## Exemplo de output
|
|
39
|
+
|
|
40
|
+
Arquivo `DARE/dag-graph.excalidraw` com estrutura:
|
|
41
|
+
|
|
42
|
+
```
|
|
43
|
+
Rank 1
|
|
44
|
+
├── task-001 (LOW, DONE)
|
|
45
|
+
├── task-002 (HIGH, PENDING)
|
|
46
|
+
|
|
47
|
+
Rank 2
|
|
48
|
+
├── task-003 (MEDIUM, RUNNING) ← depende de task-001
|
|
49
|
+
├── task-004 (LOW, PENDING) ← depende de task-001
|
|
50
|
+
|
|
51
|
+
Rank 3
|
|
52
|
+
└── task-005 (HIGH, PENDING) ← depende de task-003 e task-004
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
## Como usar
|
|
56
|
+
|
|
57
|
+
### Primeira vez
|
|
58
|
+
|
|
59
|
+
```bash
|
|
60
|
+
/dare-dag-viz
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
Claude Code vai:
|
|
64
|
+
1. Ler `DARE/dare-dag.yaml`
|
|
65
|
+
2. Gerar JSON `.excalidraw`
|
|
66
|
+
3. Salvar em `DARE/dag-graph.excalidraw`
|
|
67
|
+
4. Output: "✅ DAG gerado — abra em https://excalidraw.com"
|
|
68
|
+
|
|
69
|
+
### Atualizar após mudanças
|
|
70
|
+
|
|
71
|
+
Sempre que você atualiza `dare-dag.yaml`:
|
|
72
|
+
|
|
73
|
+
```bash
|
|
74
|
+
/dare-dag-viz
|
|
75
|
+
```
|
|
76
|
+
|
|
77
|
+
Isso regenera o diagrama com as novas tasks/dependências.
|
|
78
|
+
|
|
79
|
+
### Abrir e editar
|
|
80
|
+
|
|
81
|
+
1. Acesse https://excalidraw.com
|
|
82
|
+
2. File → Open → selecione `DARE/dag-graph.excalidraw`
|
|
83
|
+
3. Edite livremente:
|
|
84
|
+
- Mova elementos
|
|
85
|
+
- Customize cores/textos
|
|
86
|
+
- Adicione anotações
|
|
87
|
+
4. Salve no mesmo arquivo
|
|
88
|
+
|
|
89
|
+
Dica: Se editou manualmente e quer regenerar com `dare-dag-viz` de novo, faça backup antes.
|
|
90
|
+
|
|
91
|
+
## Detalhes técnicos
|
|
92
|
+
|
|
93
|
+
### Estrutura do JSON gerado
|
|
94
|
+
|
|
95
|
+
```json
|
|
96
|
+
{
|
|
97
|
+
"elements": [
|
|
98
|
+
{
|
|
99
|
+
"id": "task-001",
|
|
100
|
+
"type": "rectangle",
|
|
101
|
+
"x": 20, "y": 20,
|
|
102
|
+
"width": 120, "height": 60,
|
|
103
|
+
"backgroundColor": "#e3f2fd",
|
|
104
|
+
"stroke": "#1976d2",
|
|
105
|
+
"text": "task-001\nSetup Auth\n[LOW]",
|
|
106
|
+
"fontSize": 12,
|
|
107
|
+
"roundness": { "type": 2, "value": 6 }
|
|
108
|
+
},
|
|
109
|
+
{
|
|
110
|
+
"type": "arrow",
|
|
111
|
+
"startBinding": { "elementId": "task-001" },
|
|
112
|
+
"endBinding": { "elementId": "task-003" },
|
|
113
|
+
"stroke": "#999"
|
|
114
|
+
}
|
|
115
|
+
],
|
|
116
|
+
"appState": {
|
|
117
|
+
"gridMode": "grid",
|
|
118
|
+
"gridSize": 20
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
### Algoritmo de posicionamento
|
|
124
|
+
|
|
125
|
+
1. **Calcular ranks** — depth-first do DAG
|
|
126
|
+
```
|
|
127
|
+
rank = 1 + max(rank of dependencies)
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
2. **Agrupar por rank**
|
|
131
|
+
```
|
|
132
|
+
Rank 1: [task-001, task-002]
|
|
133
|
+
Rank 2: [task-003, task-004]
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
3. **Posicionar**
|
|
137
|
+
```
|
|
138
|
+
x = 20 + (taskIndex * 140)
|
|
139
|
+
y = 20 + (rank - 1) * 160
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
4. **Desenhar setas**
|
|
143
|
+
```
|
|
144
|
+
Para cada depends_on: arrow(source → target)
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
## Campos esperados em dare-dag.yaml
|
|
148
|
+
|
|
149
|
+
```yaml
|
|
150
|
+
tasks:
|
|
151
|
+
task-001:
|
|
152
|
+
name: "Setup Auth"
|
|
153
|
+
complexity: "LOW" # ← determina cor
|
|
154
|
+
rank: 1 # ← se não existir, é calculado
|
|
155
|
+
depends_on: [] # ← usada para setas
|
|
156
|
+
status: "DONE" # ← determina stroke/fill
|
|
157
|
+
subtask_prompt: "..." # ← (opcional)
|
|
158
|
+
```
|
|
159
|
+
|
|
160
|
+
**Campos obrigatórios:** `name`, `complexity`
|
|
161
|
+
**Campos opcionais:** `rank` (calculado), `status` (default PENDING), `depends_on` (default [])
|
|
162
|
+
|
|
163
|
+
## Troubleshooting
|
|
164
|
+
|
|
165
|
+
### "File not found: DARE/dare-dag.yaml"
|
|
166
|
+
Certifique-se de que está em um projeto DARE. Se não, rode:
|
|
167
|
+
```bash
|
|
168
|
+
dare discover
|
|
169
|
+
```
|
|
170
|
+
|
|
171
|
+
### "JSON inválido"
|
|
172
|
+
Valide seu `dare-dag.yaml`:
|
|
173
|
+
```bash
|
|
174
|
+
dare dag validate
|
|
175
|
+
```
|
|
176
|
+
|
|
177
|
+
### Diagrama muito grande/pequeno
|
|
178
|
+
Abra em Excalidraw e ajuste com Ctrl+Mouse ou pinch zoom.
|
|
179
|
+
|
|
180
|
+
## Próximos passos
|
|
181
|
+
|
|
182
|
+
- 🎨 Customize as cores em `docs/DESIGN-TOKENS-EXCALIDRAW.md`
|
|
183
|
+
- 📤 Exporte para PNG com botão "Export to Image" no Excalidraw
|
|
184
|
+
- 🔄 Atualize após cada `dare design` ou `dare execute`
|
|
185
|
+
- 📊 Compartilhe com stakeholders (Excalidraw é colaborativo)
|
|
186
|
+
|
|
187
|
+
## Referência de design
|
|
188
|
+
|
|
189
|
+
Ver `/docs/DESIGN-TOKENS-EXCALIDRAW.md` para detalhes de cores, fonts, tamanhos, e créditos.
|
|
190
|
+
|
|
191
|
+
## Licença
|
|
192
|
+
|
|
193
|
+
Esta skill é parte do DARE CLI e está sob licença MIT (D-001).
|
|
194
|
+
|
|
195
|
+
Você pode usar, modificar, compartilhar e distribuir livremente.
|
|
196
|
+
|
|
197
|
+
Créditos: Inspiração na [Excalidraw Diagram Skill](https://github.com/coleam00/excalidraw-diagram-skill) por Cole Medin.
|
|
@@ -1,69 +1,69 @@
|
|
|
1
|
-
# /dare-design
|
|
2
|
-
|
|
3
|
-
Gera ou atualiza o `DARE/DESIGN.md` a partir de uma descrição do projeto ou feature.
|
|
4
|
-
|
|
5
|
-
## Como usar
|
|
6
|
-
|
|
7
|
-
```
|
|
8
|
-
/dare-design Quero uma API REST de autenticação com JWT e refresh token
|
|
9
|
-
/dare-design Adicionar módulo de pagamentos com Stripe e webhook
|
|
10
|
-
```
|
|
11
|
-
|
|
12
|
-
## O que fazer
|
|
13
|
-
|
|
14
|
-
### 1. Leia o contexto atual do projeto
|
|
15
|
-
|
|
16
|
-
- `package.json` / `composer.json` / `Cargo.toml` / `go.mod` / `requirements.txt` — stack atual
|
|
17
|
-
- Estrutura de pastas existente
|
|
18
|
-
- `DARE/DESIGN.md` se já existir — não sobrescreva sem aprovação explícita do usuário
|
|
19
|
-
|
|
20
|
-
### 2. Gere `DARE/DESIGN.md` com as seguintes seções obrigatórias
|
|
21
|
-
|
|
22
|
-
**2.1 Descrição** — 3 a 5 frases claras: o que é, qual problema resolve, quem usa.
|
|
23
|
-
|
|
24
|
-
**2.2 Objetivos e Métricas de Sucesso** — tabela numerada (O-01, O-02…) com métrica verificável e meta numérica para cada objetivo. Evite objetivos vagos como "melhorar performance" — use "p99 < 200 ms".
|
|
25
|
-
|
|
26
|
-
**2.3 Stakeholders** — tabela: papel, nome/time, interesse principal.
|
|
27
|
-
|
|
28
|
-
**2.4 Requisitos Funcionais** — tabela numerada (RF-01, RF-02…) com prioridade MUST/SHOULD/COULD e critério de aceite verificável para cada um.
|
|
29
|
-
|
|
30
|
-
**2.5 Requisitos Não-Funcionais** — tabela numerada (RNF-01…) cobrindo: performance, disponibilidade, segurança (autenticação, rate limiting, segredos), observabilidade, manutenibilidade.
|
|
31
|
-
|
|
32
|
-
**2.6 Requisitos de Segurança** — tabela numerada (RS-01…). Inclua **sempre**:
|
|
33
|
-
- RS-01: validação de entrada (OWASP A03)
|
|
34
|
-
- RS-02: proteção de dados sensíveis / hash de senhas (OWASP A02)
|
|
35
|
-
- RS-03: controle de acesso por recurso (OWASP A01)
|
|
36
|
-
- RS-04: auditoria de dependências sem CVE HIGH/CRITICAL (OWASP A06)
|
|
37
|
-
- RS-05: secrets via variáveis de ambiente — nunca em código
|
|
38
|
-
- Adicione requisitos específicos do domínio do projeto
|
|
39
|
-
|
|
40
|
-
**2.7 Stack Técnica** — tabela por camada com tecnologia e versão.
|
|
41
|
-
|
|
42
|
-
**2.8 Integrações Externas** — tabela: sistema, tipo, protocolo, direção, dados trocados, responsável. Inclua apenas integrações confirmadas; marque incertas como "A confirmar".
|
|
43
|
-
|
|
44
|
-
**2.9 Restrições** — prazo, orçamento de infra, limitações técnicas, compliance regulatório.
|
|
45
|
-
|
|
46
|
-
**2.10 Fora do Escopo (v1)** — lista explícita do que NÃO será feito e o motivo.
|
|
47
|
-
|
|
48
|
-
**2.11 Riscos e Mitigações** — tabela: risco, probabilidade (Alta/Média/Baixa), impacto (Alto/Médio/Baixo), mitigação concreta.
|
|
49
|
-
|
|
50
|
-
**2.12 Checklist de Aprovação** — checkboxes para o usuário revisar antes de avançar ao `/dare-blueprint`.
|
|
51
|
-
|
|
52
|
-
### 3. Use o template em `templates/DESIGN-template.md`
|
|
53
|
-
|
|
54
|
-
Siga o template fielmente. Não omita seções — use "[A definir]" se a informação não estiver disponível ainda, mas deixe a seção explícita para o usuário preencher.
|
|
55
|
-
|
|
56
|
-
### 4. Qualidade esperada
|
|
57
|
-
|
|
58
|
-
O DESIGN.md gerado deve permitir que qualquer engenheiro novo no projeto entenda:
|
|
59
|
-
- **O QUÊ** vai ser construído (requisitos funcionais)
|
|
60
|
-
- **POR QUÊ** (objetivos e métricas)
|
|
61
|
-
- **PARA QUEM** (stakeholders e personas)
|
|
62
|
-
- **O QUE NÃO** vai ser feito (escopo)
|
|
63
|
-
- **QUAIS RISCOS** existem (com mitigação)
|
|
64
|
-
|
|
65
|
-
### 5. Confirme com o usuário antes de prosseguir
|
|
66
|
-
|
|
67
|
-
Após gerar o DESIGN.md, apresente um resumo das seções geradas e pergunte se o usuário quer ajustar algo antes de rodar `/dare-blueprint`.
|
|
68
|
-
|
|
69
|
-
$ARGUMENTS
|
|
1
|
+
# /dare-design
|
|
2
|
+
|
|
3
|
+
Gera ou atualiza o `DARE/DESIGN.md` a partir de uma descrição do projeto ou feature.
|
|
4
|
+
|
|
5
|
+
## Como usar
|
|
6
|
+
|
|
7
|
+
```
|
|
8
|
+
/dare-design Quero uma API REST de autenticação com JWT e refresh token
|
|
9
|
+
/dare-design Adicionar módulo de pagamentos com Stripe e webhook
|
|
10
|
+
```
|
|
11
|
+
|
|
12
|
+
## O que fazer
|
|
13
|
+
|
|
14
|
+
### 1. Leia o contexto atual do projeto
|
|
15
|
+
|
|
16
|
+
- `package.json` / `composer.json` / `Cargo.toml` / `go.mod` / `requirements.txt` — stack atual
|
|
17
|
+
- Estrutura de pastas existente
|
|
18
|
+
- `DARE/DESIGN.md` se já existir — não sobrescreva sem aprovação explícita do usuário
|
|
19
|
+
|
|
20
|
+
### 2. Gere `DARE/DESIGN.md` com as seguintes seções obrigatórias
|
|
21
|
+
|
|
22
|
+
**2.1 Descrição** — 3 a 5 frases claras: o que é, qual problema resolve, quem usa.
|
|
23
|
+
|
|
24
|
+
**2.2 Objetivos e Métricas de Sucesso** — tabela numerada (O-01, O-02…) com métrica verificável e meta numérica para cada objetivo. Evite objetivos vagos como "melhorar performance" — use "p99 < 200 ms".
|
|
25
|
+
|
|
26
|
+
**2.3 Stakeholders** — tabela: papel, nome/time, interesse principal.
|
|
27
|
+
|
|
28
|
+
**2.4 Requisitos Funcionais** — tabela numerada (RF-01, RF-02…) com prioridade MUST/SHOULD/COULD e critério de aceite verificável para cada um.
|
|
29
|
+
|
|
30
|
+
**2.5 Requisitos Não-Funcionais** — tabela numerada (RNF-01…) cobrindo: performance, disponibilidade, segurança (autenticação, rate limiting, segredos), observabilidade, manutenibilidade.
|
|
31
|
+
|
|
32
|
+
**2.6 Requisitos de Segurança** — tabela numerada (RS-01…). Inclua **sempre**:
|
|
33
|
+
- RS-01: validação de entrada (OWASP A03)
|
|
34
|
+
- RS-02: proteção de dados sensíveis / hash de senhas (OWASP A02)
|
|
35
|
+
- RS-03: controle de acesso por recurso (OWASP A01)
|
|
36
|
+
- RS-04: auditoria de dependências sem CVE HIGH/CRITICAL (OWASP A06)
|
|
37
|
+
- RS-05: secrets via variáveis de ambiente — nunca em código
|
|
38
|
+
- Adicione requisitos específicos do domínio do projeto
|
|
39
|
+
|
|
40
|
+
**2.7 Stack Técnica** — tabela por camada com tecnologia e versão.
|
|
41
|
+
|
|
42
|
+
**2.8 Integrações Externas** — tabela: sistema, tipo, protocolo, direção, dados trocados, responsável. Inclua apenas integrações confirmadas; marque incertas como "A confirmar".
|
|
43
|
+
|
|
44
|
+
**2.9 Restrições** — prazo, orçamento de infra, limitações técnicas, compliance regulatório.
|
|
45
|
+
|
|
46
|
+
**2.10 Fora do Escopo (v1)** — lista explícita do que NÃO será feito e o motivo.
|
|
47
|
+
|
|
48
|
+
**2.11 Riscos e Mitigações** — tabela: risco, probabilidade (Alta/Média/Baixa), impacto (Alto/Médio/Baixo), mitigação concreta.
|
|
49
|
+
|
|
50
|
+
**2.12 Checklist de Aprovação** — checkboxes para o usuário revisar antes de avançar ao `/dare-blueprint`.
|
|
51
|
+
|
|
52
|
+
### 3. Use o template em `templates/DESIGN-template.md`
|
|
53
|
+
|
|
54
|
+
Siga o template fielmente. Não omita seções — use "[A definir]" se a informação não estiver disponível ainda, mas deixe a seção explícita para o usuário preencher.
|
|
55
|
+
|
|
56
|
+
### 4. Qualidade esperada
|
|
57
|
+
|
|
58
|
+
O DESIGN.md gerado deve permitir que qualquer engenheiro novo no projeto entenda:
|
|
59
|
+
- **O QUÊ** vai ser construído (requisitos funcionais)
|
|
60
|
+
- **POR QUÊ** (objetivos e métricas)
|
|
61
|
+
- **PARA QUEM** (stakeholders e personas)
|
|
62
|
+
- **O QUE NÃO** vai ser feito (escopo)
|
|
63
|
+
- **QUAIS RISCOS** existem (com mitigação)
|
|
64
|
+
|
|
65
|
+
### 5. Confirme com o usuário antes de prosseguir
|
|
66
|
+
|
|
67
|
+
Após gerar o DESIGN.md, apresente um resumo das seções geradas e pergunte se o usuário quer ajustar algo antes de rodar `/dare-blueprint`.
|
|
68
|
+
|
|
69
|
+
$ARGUMENTS
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
# /dare-dna
|
|
2
|
+
|
|
3
|
+
Camada semântica da extração de DNA do projeto. Roda **depois** do comando `dare dna`, que já varreu
|
|
4
|
+
o código e extraiu os fatos de convenção. Sua função é **transformar fatos em regras acionáveis** —
|
|
5
|
+
o "como esse codebase faz as coisas" que uma nova feature deve respeitar.
|
|
6
|
+
|
|
7
|
+
## Como usar
|
|
8
|
+
|
|
9
|
+
```
|
|
10
|
+
/dare-dna # preenche o PROJECT-DNA.md gerado por `dare dna`
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
> Pré-requisito: rodar `dare dna` antes (gera `DARE/PROJECT-DNA.md` e `DARE/dna-facts.json`).
|
|
14
|
+
> Se não existirem, instrua o usuário a rodar `dare dna` primeiro.
|
|
15
|
+
|
|
16
|
+
## Quando usar
|
|
17
|
+
|
|
18
|
+
- Projeto **legado** que vai adotar o DARE para novas features, sem reescrever o existente.
|
|
19
|
+
- Acabou de rodar `dare dna` e o `PROJECT-DNA.md` tem seções `<!-- AGENT -->` em aberto.
|
|
20
|
+
- O objetivo é um **ruleset** que faça o agente seguir o padrão da casa, não o default genérico.
|
|
21
|
+
|
|
22
|
+
## O que fazer
|
|
23
|
+
|
|
24
|
+
### 1. Carregar os fatos (não re-varrer tudo)
|
|
25
|
+
|
|
26
|
+
- Leia `DARE/dna-facts.json` — fonte determinística (tooling, naming, camadas, testes, libs, commits).
|
|
27
|
+
- Abra **2-5 arquivos representativos por camada** (um controller, um service, um model, um teste) para
|
|
28
|
+
inferir os padrões que o CLI não detecta (tratamento de erro, validação, estilo de teste).
|
|
29
|
+
|
|
30
|
+
### 2. Preencher `DARE/PROJECT-DNA.md`
|
|
31
|
+
|
|
32
|
+
Substitua cada bloco `<!-- AGENT: ... -->`:
|
|
33
|
+
|
|
34
|
+
- **Convenções de Nomenclatura** — confirme o estilo detectado e documente exceções (ex.: componentes
|
|
35
|
+
em PascalCase, utilitários em kebab).
|
|
36
|
+
- **Arquitetura & Camadas** — nomeie o padrão com confiança (MVC / Layered / Hexagonal) e escreva as
|
|
37
|
+
**regras de onde cada coisa mora** (ex.: "controllers só orquestram; regra de negócio vai em services;
|
|
38
|
+
acesso a dados só em repositories").
|
|
39
|
+
- **Padrões de Teste** — onde os testes ficam, naming, assertions reais (não `expect(true)`), uso de
|
|
40
|
+
mocks/fixtures.
|
|
41
|
+
- **Tratamento de Erros & Validação** — como o projeto trata erros (exceptions, Result/Either, try/catch)
|
|
42
|
+
e valida inputs. Dê **exemplos concretos** do código real.
|
|
43
|
+
- **Regras de Ouro do Projeto** — liste o que **SEMPRE** e o que **NUNCA** fazer neste codebase.
|
|
44
|
+
- **⚠️ Incertezas / Inconsistências** — convenções ambíguas/misturadas que o humano precisa decidir.
|
|
45
|
+
|
|
46
|
+
**Não toque** nos fatos determinísticos já preenchidos pelo CLI (tooling, tabela de naming, libs).
|
|
47
|
+
|
|
48
|
+
### 3. Apresentar ao usuário
|
|
49
|
+
|
|
50
|
+
Resumo: arquitetura nomeada, principais regras de ouro, inconsistências encontradas. Reforce que o
|
|
51
|
+
`PROJECT-DNA.md` vira referência para `/dare-feature-design` e `/dare-execute` respeitarem o legado.
|
|
52
|
+
|
|
53
|
+
## Regras de ouro
|
|
54
|
+
|
|
55
|
+
1. **Descritivo, não aspiracional** — documente como o código É, não como deveria ser.
|
|
56
|
+
2. **Exemplos reais** — cite arquivos/trechos do próprio projeto nas regras.
|
|
57
|
+
3. **Sinalize inconsistência** — se o legado mistura padrões, diga isso em "⚠️ Incertezas", não invente um padrão único.
|
|
58
|
+
4. **Não re-varra** — os fatos já estão em `dna-facts.json`.
|
|
59
|
+
5. **Preserve o determinístico** — não reescreva tooling/naming/libs gerados pelo CLI.
|
|
60
|
+
|
|
61
|
+
## Antipatterns
|
|
62
|
+
|
|
63
|
+
| AP | Antipattern | Por quê |
|
|
64
|
+
|---|---|---|
|
|
65
|
+
| AP-01 | Documentar o padrão "ideal" em vez do real | O agente vai gerar código fora do estilo do legado |
|
|
66
|
+
| AP-02 | Forçar um padrão único onde o legado é inconsistente | Esconde a realidade; melhor sinalizar a incerteza |
|
|
67
|
+
| AP-03 | Reescrever os fatos determinísticos do CLI | Quebra a fonte de verdade |
|
|
68
|
+
| AP-04 | Regras vagas ("siga boas práticas") | Inúteis — o valor está na regra específica do projeto |
|
|
69
|
+
| AP-05 | Ignorar os testes existentes ao descrever o estilo de teste | Nova feature nasce inconsistente |
|
|
70
|
+
|
|
71
|
+
$ARGUMENTS
|
|
72
|
+
|
|
73
|
+
---
|
|
74
|
+
|
|
75
|
+
Skill MIT — parte do DARE Method. DNA do projeto (brownfield). Pareia com o comando `dare dna`.
|