@reqord/cli 0.1.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/LICENSE +661 -0
- package/README.md +73 -0
- package/dist/commands/context/init.d.ts +3 -0
- package/dist/commands/context/init.d.ts.map +1 -0
- package/dist/commands/context/init.js +38 -0
- package/dist/commands/context/init.js.map +1 -0
- package/dist/commands/context/show.d.ts +3 -0
- package/dist/commands/context/show.d.ts.map +1 -0
- package/dist/commands/context/show.js +69 -0
- package/dist/commands/context/show.js.map +1 -0
- package/dist/commands/context/update.d.ts +3 -0
- package/dist/commands/context/update.d.ts.map +1 -0
- package/dist/commands/context/update.js +58 -0
- package/dist/commands/context/update.js.map +1 -0
- package/dist/commands/feedback/close.d.ts +3 -0
- package/dist/commands/feedback/close.d.ts.map +1 -0
- package/dist/commands/feedback/close.js +32 -0
- package/dist/commands/feedback/close.js.map +1 -0
- package/dist/commands/feedback/create.d.ts +3 -0
- package/dist/commands/feedback/create.d.ts.map +1 -0
- package/dist/commands/feedback/create.js +32 -0
- package/dist/commands/feedback/create.js.map +1 -0
- package/dist/commands/feedback/index.d.ts +3 -0
- package/dist/commands/feedback/index.d.ts.map +1 -0
- package/dist/commands/feedback/index.js +20 -0
- package/dist/commands/feedback/index.js.map +1 -0
- package/dist/commands/feedback/link.d.ts +3 -0
- package/dist/commands/feedback/link.d.ts.map +1 -0
- package/dist/commands/feedback/link.js +54 -0
- package/dist/commands/feedback/link.js.map +1 -0
- package/dist/commands/feedback/list.d.ts +3 -0
- package/dist/commands/feedback/list.d.ts.map +1 -0
- package/dist/commands/feedback/list.js +50 -0
- package/dist/commands/feedback/list.js.map +1 -0
- package/dist/commands/feedback/resolve.d.ts +3 -0
- package/dist/commands/feedback/resolve.d.ts.map +1 -0
- package/dist/commands/feedback/resolve.js +24 -0
- package/dist/commands/feedback/resolve.js.map +1 -0
- package/dist/commands/feedback/show.d.ts +3 -0
- package/dist/commands/feedback/show.d.ts.map +1 -0
- package/dist/commands/feedback/show.js +35 -0
- package/dist/commands/feedback/show.js.map +1 -0
- package/dist/commands/feedback/sync.d.ts +3 -0
- package/dist/commands/feedback/sync.d.ts.map +1 -0
- package/dist/commands/feedback/sync.js +29 -0
- package/dist/commands/feedback/sync.js.map +1 -0
- package/dist/commands/feedback/unlink.d.ts +3 -0
- package/dist/commands/feedback/unlink.d.ts.map +1 -0
- package/dist/commands/feedback/unlink.js +39 -0
- package/dist/commands/feedback/unlink.js.map +1 -0
- package/dist/commands/impact/analyze.d.ts +3 -0
- package/dist/commands/impact/analyze.d.ts.map +1 -0
- package/dist/commands/impact/analyze.js +131 -0
- package/dist/commands/impact/analyze.js.map +1 -0
- package/dist/commands/impact/analyze.test.d.ts +2 -0
- package/dist/commands/impact/analyze.test.d.ts.map +1 -0
- package/dist/commands/impact/analyze.test.js +203 -0
- package/dist/commands/impact/analyze.test.js.map +1 -0
- package/dist/commands/impact/index.d.ts +3 -0
- package/dist/commands/impact/index.d.ts.map +1 -0
- package/dist/commands/impact/index.js +8 -0
- package/dist/commands/impact/index.js.map +1 -0
- package/dist/commands/impact/integration.test.d.ts +2 -0
- package/dist/commands/impact/integration.test.d.ts.map +1 -0
- package/dist/commands/impact/integration.test.js +183 -0
- package/dist/commands/impact/integration.test.js.map +1 -0
- package/dist/commands/impact/notify.d.ts +3 -0
- package/dist/commands/impact/notify.d.ts.map +1 -0
- package/dist/commands/impact/notify.js +78 -0
- package/dist/commands/impact/notify.js.map +1 -0
- package/dist/commands/impact/notify.test.d.ts +2 -0
- package/dist/commands/impact/notify.test.d.ts.map +1 -0
- package/dist/commands/impact/notify.test.js +136 -0
- package/dist/commands/impact/notify.test.js.map +1 -0
- package/dist/commands/init.d.ts +3 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +31 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/issue/create.d.ts +3 -0
- package/dist/commands/issue/create.d.ts.map +1 -0
- package/dist/commands/issue/create.js +62 -0
- package/dist/commands/issue/create.js.map +1 -0
- package/dist/commands/issue/create.test.d.ts +2 -0
- package/dist/commands/issue/create.test.d.ts.map +1 -0
- package/dist/commands/issue/create.test.js +204 -0
- package/dist/commands/issue/create.test.js.map +1 -0
- package/dist/commands/issue/fetch.d.ts +3 -0
- package/dist/commands/issue/fetch.d.ts.map +1 -0
- package/dist/commands/issue/fetch.js +66 -0
- package/dist/commands/issue/fetch.js.map +1 -0
- package/dist/commands/issue/fetch.test.d.ts +2 -0
- package/dist/commands/issue/fetch.test.d.ts.map +1 -0
- package/dist/commands/issue/fetch.test.js +135 -0
- package/dist/commands/issue/fetch.test.js.map +1 -0
- package/dist/commands/issue/index.d.ts +3 -0
- package/dist/commands/issue/index.d.ts.map +1 -0
- package/dist/commands/issue/index.js +13 -0
- package/dist/commands/issue/index.js.map +1 -0
- package/dist/commands/issue/sync.d.ts +4 -0
- package/dist/commands/issue/sync.d.ts.map +1 -0
- package/dist/commands/issue/sync.js +65 -0
- package/dist/commands/issue/sync.js.map +1 -0
- package/dist/commands/issue/sync.test.d.ts +2 -0
- package/dist/commands/issue/sync.test.d.ts.map +1 -0
- package/dist/commands/issue/sync.test.js +275 -0
- package/dist/commands/issue/sync.test.js.map +1 -0
- package/dist/commands/issue/validate.d.ts +14 -0
- package/dist/commands/issue/validate.d.ts.map +1 -0
- package/dist/commands/issue/validate.js +88 -0
- package/dist/commands/issue/validate.js.map +1 -0
- package/dist/commands/issue/validate.test.d.ts +2 -0
- package/dist/commands/issue/validate.test.d.ts.map +1 -0
- package/dist/commands/issue/validate.test.js +83 -0
- package/dist/commands/issue/validate.test.js.map +1 -0
- package/dist/commands/migrate-to-yaml.d.ts +3 -0
- package/dist/commands/migrate-to-yaml.d.ts.map +1 -0
- package/dist/commands/migrate-to-yaml.js +53 -0
- package/dist/commands/migrate-to-yaml.js.map +1 -0
- package/dist/commands/req/approve.d.ts +3 -0
- package/dist/commands/req/approve.d.ts.map +1 -0
- package/dist/commands/req/approve.js +61 -0
- package/dist/commands/req/approve.js.map +1 -0
- package/dist/commands/req/approve.test.d.ts +2 -0
- package/dist/commands/req/approve.test.d.ts.map +1 -0
- package/dist/commands/req/approve.test.js +207 -0
- package/dist/commands/req/approve.test.js.map +1 -0
- package/dist/commands/req/create.d.ts +3 -0
- package/dist/commands/req/create.d.ts.map +1 -0
- package/dist/commands/req/create.js +33 -0
- package/dist/commands/req/create.js.map +1 -0
- package/dist/commands/req/delete.d.ts +3 -0
- package/dist/commands/req/delete.d.ts.map +1 -0
- package/dist/commands/req/delete.js +37 -0
- package/dist/commands/req/delete.js.map +1 -0
- package/dist/commands/req/draft.d.ts +3 -0
- package/dist/commands/req/draft.d.ts.map +1 -0
- package/dist/commands/req/draft.js +93 -0
- package/dist/commands/req/draft.js.map +1 -0
- package/dist/commands/req/draft.test.d.ts +2 -0
- package/dist/commands/req/draft.test.d.ts.map +1 -0
- package/dist/commands/req/draft.test.js +235 -0
- package/dist/commands/req/draft.test.js.map +1 -0
- package/dist/commands/req/history.d.ts +3 -0
- package/dist/commands/req/history.d.ts.map +1 -0
- package/dist/commands/req/history.js +48 -0
- package/dist/commands/req/history.js.map +1 -0
- package/dist/commands/req/implement.d.ts +3 -0
- package/dist/commands/req/implement.d.ts.map +1 -0
- package/dist/commands/req/implement.js +61 -0
- package/dist/commands/req/implement.js.map +1 -0
- package/dist/commands/req/implement.test.d.ts +2 -0
- package/dist/commands/req/implement.test.d.ts.map +1 -0
- package/dist/commands/req/implement.test.js +235 -0
- package/dist/commands/req/implement.test.js.map +1 -0
- package/dist/commands/req/implemented.d.ts +3 -0
- package/dist/commands/req/implemented.d.ts.map +1 -0
- package/dist/commands/req/implemented.js +46 -0
- package/dist/commands/req/implemented.js.map +1 -0
- package/dist/commands/req/implemented.test.d.ts +2 -0
- package/dist/commands/req/implemented.test.d.ts.map +1 -0
- package/dist/commands/req/implemented.test.js +157 -0
- package/dist/commands/req/implemented.test.js.map +1 -0
- package/dist/commands/req/list.d.ts +3 -0
- package/dist/commands/req/list.d.ts.map +1 -0
- package/dist/commands/req/list.js +50 -0
- package/dist/commands/req/list.js.map +1 -0
- package/dist/commands/req/show.d.ts +3 -0
- package/dist/commands/req/show.d.ts.map +1 -0
- package/dist/commands/req/show.js +40 -0
- package/dist/commands/req/show.js.map +1 -0
- package/dist/commands/req/update.d.ts +3 -0
- package/dist/commands/req/update.d.ts.map +1 -0
- package/dist/commands/req/update.js +112 -0
- package/dist/commands/req/update.js.map +1 -0
- package/dist/commands/req/validate.d.ts +3 -0
- package/dist/commands/req/validate.d.ts.map +1 -0
- package/dist/commands/req/validate.js +71 -0
- package/dist/commands/req/validate.js.map +1 -0
- package/dist/commands/spec/approve.d.ts +3 -0
- package/dist/commands/spec/approve.d.ts.map +1 -0
- package/dist/commands/spec/approve.js +88 -0
- package/dist/commands/spec/approve.js.map +1 -0
- package/dist/commands/spec/approve.test.d.ts +2 -0
- package/dist/commands/spec/approve.test.d.ts.map +1 -0
- package/dist/commands/spec/approve.test.js +304 -0
- package/dist/commands/spec/approve.test.js.map +1 -0
- package/dist/commands/spec/coverage.d.ts +3 -0
- package/dist/commands/spec/coverage.d.ts.map +1 -0
- package/dist/commands/spec/coverage.js +57 -0
- package/dist/commands/spec/coverage.js.map +1 -0
- package/dist/commands/spec/create.d.ts +3 -0
- package/dist/commands/spec/create.d.ts.map +1 -0
- package/dist/commands/spec/create.js +30 -0
- package/dist/commands/spec/create.js.map +1 -0
- package/dist/commands/spec/design.d.ts +3 -0
- package/dist/commands/spec/design.d.ts.map +1 -0
- package/dist/commands/spec/design.js +30 -0
- package/dist/commands/spec/design.js.map +1 -0
- package/dist/commands/spec/draft.d.ts +3 -0
- package/dist/commands/spec/draft.d.ts.map +1 -0
- package/dist/commands/spec/draft.js +93 -0
- package/dist/commands/spec/draft.js.map +1 -0
- package/dist/commands/spec/draft.test.d.ts +2 -0
- package/dist/commands/spec/draft.test.d.ts.map +1 -0
- package/dist/commands/spec/draft.test.js +213 -0
- package/dist/commands/spec/draft.test.js.map +1 -0
- package/dist/commands/spec/history.d.ts +3 -0
- package/dist/commands/spec/history.d.ts.map +1 -0
- package/dist/commands/spec/history.js +48 -0
- package/dist/commands/spec/history.js.map +1 -0
- package/dist/commands/spec/history.test.d.ts +2 -0
- package/dist/commands/spec/history.test.d.ts.map +1 -0
- package/dist/commands/spec/history.test.js +137 -0
- package/dist/commands/spec/history.test.js.map +1 -0
- package/dist/commands/spec/implement.d.ts +3 -0
- package/dist/commands/spec/implement.d.ts.map +1 -0
- package/dist/commands/spec/implement.js +41 -0
- package/dist/commands/spec/implement.js.map +1 -0
- package/dist/commands/spec/implement.test.d.ts +2 -0
- package/dist/commands/spec/implement.test.d.ts.map +1 -0
- package/dist/commands/spec/implement.test.js +118 -0
- package/dist/commands/spec/implement.test.js.map +1 -0
- package/dist/commands/spec/implemented.d.ts +3 -0
- package/dist/commands/spec/implemented.d.ts.map +1 -0
- package/dist/commands/spec/implemented.js +56 -0
- package/dist/commands/spec/implemented.js.map +1 -0
- package/dist/commands/spec/implemented.test.d.ts +2 -0
- package/dist/commands/spec/implemented.test.d.ts.map +1 -0
- package/dist/commands/spec/implemented.test.js +175 -0
- package/dist/commands/spec/implemented.test.js.map +1 -0
- package/dist/commands/spec/list.d.ts +3 -0
- package/dist/commands/spec/list.d.ts.map +1 -0
- package/dist/commands/spec/list.js +53 -0
- package/dist/commands/spec/list.js.map +1 -0
- package/dist/commands/spec/research.d.ts +3 -0
- package/dist/commands/spec/research.d.ts.map +1 -0
- package/dist/commands/spec/research.js +30 -0
- package/dist/commands/spec/research.js.map +1 -0
- package/dist/commands/spec/show.d.ts +3 -0
- package/dist/commands/spec/show.d.ts.map +1 -0
- package/dist/commands/spec/show.js +51 -0
- package/dist/commands/spec/show.js.map +1 -0
- package/dist/commands/spec/spec-approval-flow.integration.test.d.ts +2 -0
- package/dist/commands/spec/spec-approval-flow.integration.test.d.ts.map +1 -0
- package/dist/commands/spec/spec-approval-flow.integration.test.js +249 -0
- package/dist/commands/spec/spec-approval-flow.integration.test.js.map +1 -0
- package/dist/commands/spec/update.d.ts +3 -0
- package/dist/commands/spec/update.d.ts.map +1 -0
- package/dist/commands/spec/update.js +81 -0
- package/dist/commands/spec/update.js.map +1 -0
- package/dist/commands/spec/update.test.d.ts +2 -0
- package/dist/commands/spec/update.test.d.ts.map +1 -0
- package/dist/commands/spec/update.test.js +172 -0
- package/dist/commands/spec/update.test.js.map +1 -0
- package/dist/commands/spec/validate.d.ts +3 -0
- package/dist/commands/spec/validate.d.ts.map +1 -0
- package/dist/commands/spec/validate.js +62 -0
- package/dist/commands/spec/validate.js.map +1 -0
- package/dist/commands/spec/validate.test.d.ts +2 -0
- package/dist/commands/spec/validate.test.d.ts.map +1 -0
- package/dist/commands/spec/validate.test.js +135 -0
- package/dist/commands/spec/validate.test.js.map +1 -0
- package/dist/commands/status.d.ts +3 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +190 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/status.test.d.ts +2 -0
- package/dist/commands/status.test.d.ts.map +1 -0
- package/dist/commands/status.test.js +175 -0
- package/dist/commands/status.test.js.map +1 -0
- package/dist/commands/task/create.d.ts +3 -0
- package/dist/commands/task/create.d.ts.map +1 -0
- package/dist/commands/task/create.js +62 -0
- package/dist/commands/task/create.js.map +1 -0
- package/dist/commands/task/create.test.d.ts +2 -0
- package/dist/commands/task/create.test.d.ts.map +1 -0
- package/dist/commands/task/create.test.js +204 -0
- package/dist/commands/task/create.test.js.map +1 -0
- package/dist/commands/task/fetch.d.ts +3 -0
- package/dist/commands/task/fetch.d.ts.map +1 -0
- package/dist/commands/task/fetch.js +66 -0
- package/dist/commands/task/fetch.js.map +1 -0
- package/dist/commands/task/fetch.test.d.ts +2 -0
- package/dist/commands/task/fetch.test.d.ts.map +1 -0
- package/dist/commands/task/fetch.test.js +135 -0
- package/dist/commands/task/fetch.test.js.map +1 -0
- package/dist/commands/task/index.d.ts +3 -0
- package/dist/commands/task/index.d.ts.map +1 -0
- package/dist/commands/task/index.js +13 -0
- package/dist/commands/task/index.js.map +1 -0
- package/dist/commands/task/sync.d.ts +4 -0
- package/dist/commands/task/sync.d.ts.map +1 -0
- package/dist/commands/task/sync.js +65 -0
- package/dist/commands/task/sync.js.map +1 -0
- package/dist/commands/task/sync.test.d.ts +2 -0
- package/dist/commands/task/sync.test.d.ts.map +1 -0
- package/dist/commands/task/sync.test.js +275 -0
- package/dist/commands/task/sync.test.js.map +1 -0
- package/dist/commands/task/validate.d.ts +14 -0
- package/dist/commands/task/validate.d.ts.map +1 -0
- package/dist/commands/task/validate.js +88 -0
- package/dist/commands/task/validate.js.map +1 -0
- package/dist/commands/task/validate.test.d.ts +2 -0
- package/dist/commands/task/validate.test.d.ts.map +1 -0
- package/dist/commands/task/validate.test.js +83 -0
- package/dist/commands/task/validate.test.js.map +1 -0
- package/dist/commands/ui.d.ts +3 -0
- package/dist/commands/ui.d.ts.map +1 -0
- package/dist/commands/ui.js +107 -0
- package/dist/commands/ui.js.map +1 -0
- package/dist/commands/validate/impl.d.ts +3 -0
- package/dist/commands/validate/impl.d.ts.map +1 -0
- package/dist/commands/validate/impl.js +71 -0
- package/dist/commands/validate/impl.js.map +1 -0
- package/dist/commands/validate/impl.test.d.ts +2 -0
- package/dist/commands/validate/impl.test.d.ts.map +1 -0
- package/dist/commands/validate/impl.test.js +83 -0
- package/dist/commands/validate/impl.test.js.map +1 -0
- package/dist/commands/version/version.d.ts +3 -0
- package/dist/commands/version/version.d.ts.map +1 -0
- package/dist/commands/version/version.js +61 -0
- package/dist/commands/version/version.js.map +1 -0
- package/dist/commands/version/version.test.d.ts +2 -0
- package/dist/commands/version/version.test.d.ts.map +1 -0
- package/dist/commands/version/version.test.js +262 -0
- package/dist/commands/version/version.test.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +114 -0
- package/dist/index.js.map +1 -0
- package/dist/middleware/reqord-check.d.ts +2 -0
- package/dist/middleware/reqord-check.d.ts.map +1 -0
- package/dist/middleware/reqord-check.js +9 -0
- package/dist/middleware/reqord-check.js.map +1 -0
- package/dist/middleware/reqord-check.test.d.ts +2 -0
- package/dist/middleware/reqord-check.test.d.ts.map +1 -0
- package/dist/middleware/reqord-check.test.js +44 -0
- package/dist/middleware/reqord-check.test.js.map +1 -0
- package/dist/repositories/__tests__/file-system-yaml.test.d.ts +2 -0
- package/dist/repositories/__tests__/file-system-yaml.test.d.ts.map +1 -0
- package/dist/repositories/__tests__/file-system-yaml.test.js +132 -0
- package/dist/repositories/__tests__/file-system-yaml.test.js.map +1 -0
- package/dist/repositories/feedback.d.ts +7 -0
- package/dist/repositories/feedback.d.ts.map +1 -0
- package/dist/repositories/feedback.js +62 -0
- package/dist/repositories/feedback.js.map +1 -0
- package/dist/repositories/feedback.test.d.ts +2 -0
- package/dist/repositories/feedback.test.d.ts.map +1 -0
- package/dist/repositories/feedback.test.js +108 -0
- package/dist/repositories/feedback.test.js.map +1 -0
- package/dist/repositories/file-system-yaml.test.d.ts +2 -0
- package/dist/repositories/file-system-yaml.test.d.ts.map +1 -0
- package/dist/repositories/file-system-yaml.test.js +246 -0
- package/dist/repositories/file-system-yaml.test.js.map +1 -0
- package/dist/repositories/file-system.d.ts +15 -0
- package/dist/repositories/file-system.d.ts.map +1 -0
- package/dist/repositories/file-system.js +156 -0
- package/dist/repositories/file-system.js.map +1 -0
- package/dist/repositories/git.d.ts +8 -0
- package/dist/repositories/git.d.ts.map +1 -0
- package/dist/repositories/git.js +29 -0
- package/dist/repositories/git.js.map +1 -0
- package/dist/repositories/git.test.d.ts +2 -0
- package/dist/repositories/git.test.d.ts.map +1 -0
- package/dist/repositories/git.test.js +112 -0
- package/dist/repositories/git.test.js.map +1 -0
- package/dist/repositories/github.d.ts +18 -0
- package/dist/repositories/github.d.ts.map +1 -0
- package/dist/repositories/github.js +59 -0
- package/dist/repositories/github.js.map +1 -0
- package/dist/repositories/github.test.d.ts +2 -0
- package/dist/repositories/github.test.d.ts.map +1 -0
- package/dist/repositories/github.test.js +180 -0
- package/dist/repositories/github.test.js.map +1 -0
- package/dist/repositories/project-context.d.ts +8 -0
- package/dist/repositories/project-context.d.ts.map +1 -0
- package/dist/repositories/project-context.js +43 -0
- package/dist/repositories/project-context.js.map +1 -0
- package/dist/repositories/requirement.d.ts +9 -0
- package/dist/repositories/requirement.d.ts.map +1 -0
- package/dist/repositories/requirement.js +65 -0
- package/dist/repositories/requirement.js.map +1 -0
- package/dist/repositories/specification.d.ts +10 -0
- package/dist/repositories/specification.d.ts.map +1 -0
- package/dist/repositories/specification.js +67 -0
- package/dist/repositories/specification.js.map +1 -0
- package/dist/services/approval-service.d.ts +28 -0
- package/dist/services/approval-service.d.ts.map +1 -0
- package/dist/services/approval-service.js +59 -0
- package/dist/services/approval-service.js.map +1 -0
- package/dist/services/approval-service.test.d.ts +2 -0
- package/dist/services/approval-service.test.d.ts.map +1 -0
- package/dist/services/approval-service.test.js +187 -0
- package/dist/services/approval-service.test.js.map +1 -0
- package/dist/services/context-service.d.ts +33 -0
- package/dist/services/context-service.d.ts.map +1 -0
- package/dist/services/context-service.js +118 -0
- package/dist/services/context-service.js.map +1 -0
- package/dist/services/context-service.test.d.ts +2 -0
- package/dist/services/context-service.test.d.ts.map +1 -0
- package/dist/services/context-service.test.js +182 -0
- package/dist/services/context-service.test.js.map +1 -0
- package/dist/services/coverage-service.d.ts +27 -0
- package/dist/services/coverage-service.d.ts.map +1 -0
- package/dist/services/coverage-service.js +48 -0
- package/dist/services/coverage-service.js.map +1 -0
- package/dist/services/coverage-service.test.d.ts +2 -0
- package/dist/services/coverage-service.test.d.ts.map +1 -0
- package/dist/services/coverage-service.test.js +100 -0
- package/dist/services/coverage-service.test.js.map +1 -0
- package/dist/services/draft-reversion-service.d.ts +11 -0
- package/dist/services/draft-reversion-service.d.ts.map +1 -0
- package/dist/services/draft-reversion-service.js +132 -0
- package/dist/services/draft-reversion-service.js.map +1 -0
- package/dist/services/draft-reversion-service.test.d.ts +2 -0
- package/dist/services/draft-reversion-service.test.d.ts.map +1 -0
- package/dist/services/draft-reversion-service.test.js +349 -0
- package/dist/services/draft-reversion-service.test.js.map +1 -0
- package/dist/services/feedback-service.d.ts +64 -0
- package/dist/services/feedback-service.d.ts.map +1 -0
- package/dist/services/feedback-service.js +329 -0
- package/dist/services/feedback-service.js.map +1 -0
- package/dist/services/feedback-service.test.d.ts +2 -0
- package/dist/services/feedback-service.test.d.ts.map +1 -0
- package/dist/services/feedback-service.test.js +977 -0
- package/dist/services/feedback-service.test.js.map +1 -0
- package/dist/services/feedback-sync-service.d.ts +7 -0
- package/dist/services/feedback-sync-service.d.ts.map +1 -0
- package/dist/services/feedback-sync-service.js +70 -0
- package/dist/services/feedback-sync-service.js.map +1 -0
- package/dist/services/feedback-sync-service.test.d.ts +2 -0
- package/dist/services/feedback-sync-service.test.d.ts.map +1 -0
- package/dist/services/feedback-sync-service.test.js +328 -0
- package/dist/services/feedback-sync-service.test.js.map +1 -0
- package/dist/services/github-client.d.ts +42 -0
- package/dist/services/github-client.d.ts.map +1 -0
- package/dist/services/github-client.js +120 -0
- package/dist/services/github-client.js.map +1 -0
- package/dist/services/github-client.test.d.ts +2 -0
- package/dist/services/github-client.test.d.ts.map +1 -0
- package/dist/services/github-client.test.js +393 -0
- package/dist/services/github-client.test.js.map +1 -0
- package/dist/services/impact-service.d.ts +57 -0
- package/dist/services/impact-service.d.ts.map +1 -0
- package/dist/services/impact-service.js +302 -0
- package/dist/services/impact-service.js.map +1 -0
- package/dist/services/impact-service.test.d.ts +2 -0
- package/dist/services/impact-service.test.d.ts.map +1 -0
- package/dist/services/impact-service.test.js +566 -0
- package/dist/services/impact-service.test.js.map +1 -0
- package/dist/services/impl-validation-service.d.ts +63 -0
- package/dist/services/impl-validation-service.d.ts.map +1 -0
- package/dist/services/impl-validation-service.js +189 -0
- package/dist/services/impl-validation-service.js.map +1 -0
- package/dist/services/impl-validation-service.test.d.ts +2 -0
- package/dist/services/impl-validation-service.test.d.ts.map +1 -0
- package/dist/services/impl-validation-service.test.js +407 -0
- package/dist/services/impl-validation-service.test.js.map +1 -0
- package/dist/services/init-service.d.ts +6 -0
- package/dist/services/init-service.d.ts.map +1 -0
- package/dist/services/init-service.js +57 -0
- package/dist/services/init-service.js.map +1 -0
- package/dist/services/init-service.test.d.ts +2 -0
- package/dist/services/init-service.test.d.ts.map +1 -0
- package/dist/services/init-service.test.js +103 -0
- package/dist/services/init-service.test.js.map +1 -0
- package/dist/services/issue-fetch-service.d.ts +24 -0
- package/dist/services/issue-fetch-service.d.ts.map +1 -0
- package/dist/services/issue-fetch-service.js +109 -0
- package/dist/services/issue-fetch-service.js.map +1 -0
- package/dist/services/issue-fetch-service.test.d.ts +2 -0
- package/dist/services/issue-fetch-service.test.d.ts.map +1 -0
- package/dist/services/issue-fetch-service.test.js +243 -0
- package/dist/services/issue-fetch-service.test.js.map +1 -0
- package/dist/services/issue-service.d.ts +25 -0
- package/dist/services/issue-service.d.ts.map +1 -0
- package/dist/services/issue-service.js +114 -0
- package/dist/services/issue-service.js.map +1 -0
- package/dist/services/issue-service.test.d.ts +2 -0
- package/dist/services/issue-service.test.d.ts.map +1 -0
- package/dist/services/issue-service.test.js +235 -0
- package/dist/services/issue-service.test.js.map +1 -0
- package/dist/services/issue-sync-service.d.ts +25 -0
- package/dist/services/issue-sync-service.d.ts.map +1 -0
- package/dist/services/issue-sync-service.js +84 -0
- package/dist/services/issue-sync-service.js.map +1 -0
- package/dist/services/issue-sync-service.test.d.ts +2 -0
- package/dist/services/issue-sync-service.test.d.ts.map +1 -0
- package/dist/services/issue-sync-service.test.js +187 -0
- package/dist/services/issue-sync-service.test.js.map +1 -0
- package/dist/services/migration-service.d.ts +19 -0
- package/dist/services/migration-service.d.ts.map +1 -0
- package/dist/services/migration-service.js +114 -0
- package/dist/services/migration-service.js.map +1 -0
- package/dist/services/migration-service.test.d.ts +2 -0
- package/dist/services/migration-service.test.d.ts.map +1 -0
- package/dist/services/migration-service.test.js +269 -0
- package/dist/services/migration-service.test.js.map +1 -0
- package/dist/services/reqord-comment.d.ts +15 -0
- package/dist/services/reqord-comment.d.ts.map +1 -0
- package/dist/services/reqord-comment.js +46 -0
- package/dist/services/reqord-comment.js.map +1 -0
- package/dist/services/reqord-comment.test.d.ts +2 -0
- package/dist/services/reqord-comment.test.d.ts.map +1 -0
- package/dist/services/reqord-comment.test.js +304 -0
- package/dist/services/reqord-comment.test.js.map +1 -0
- package/dist/services/requirement-approval-handler.d.ts +15 -0
- package/dist/services/requirement-approval-handler.d.ts.map +1 -0
- package/dist/services/requirement-approval-handler.js +68 -0
- package/dist/services/requirement-approval-handler.js.map +1 -0
- package/dist/services/requirement-approval-handler.test.d.ts +2 -0
- package/dist/services/requirement-approval-handler.test.d.ts.map +1 -0
- package/dist/services/requirement-approval-handler.test.js +41 -0
- package/dist/services/requirement-approval-handler.test.js.map +1 -0
- package/dist/services/requirement-service.d.ts +38 -0
- package/dist/services/requirement-service.d.ts.map +1 -0
- package/dist/services/requirement-service.js +167 -0
- package/dist/services/requirement-service.js.map +1 -0
- package/dist/services/requirement-service.test.d.ts +2 -0
- package/dist/services/requirement-service.test.d.ts.map +1 -0
- package/dist/services/requirement-service.test.js +356 -0
- package/dist/services/requirement-service.test.js.map +1 -0
- package/dist/services/spec-approval-helpers.d.ts +15 -0
- package/dist/services/spec-approval-helpers.d.ts.map +1 -0
- package/dist/services/spec-approval-helpers.js +84 -0
- package/dist/services/spec-approval-helpers.js.map +1 -0
- package/dist/services/spec-approval-helpers.test.d.ts +2 -0
- package/dist/services/spec-approval-helpers.test.d.ts.map +1 -0
- package/dist/services/spec-approval-helpers.test.js +132 -0
- package/dist/services/spec-approval-helpers.test.js.map +1 -0
- package/dist/services/spec-validation-service.d.ts +26 -0
- package/dist/services/spec-validation-service.d.ts.map +1 -0
- package/dist/services/spec-validation-service.js +235 -0
- package/dist/services/spec-validation-service.js.map +1 -0
- package/dist/services/spec-validation-service.test.d.ts +2 -0
- package/dist/services/spec-validation-service.test.d.ts.map +1 -0
- package/dist/services/spec-validation-service.test.js +149 -0
- package/dist/services/spec-validation-service.test.js.map +1 -0
- package/dist/services/specification-approval-handler.d.ts +3 -0
- package/dist/services/specification-approval-handler.d.ts.map +1 -0
- package/dist/services/specification-approval-handler.js +32 -0
- package/dist/services/specification-approval-handler.js.map +1 -0
- package/dist/services/specification-service.d.ts +63 -0
- package/dist/services/specification-service.d.ts.map +1 -0
- package/dist/services/specification-service.js +194 -0
- package/dist/services/specification-service.js.map +1 -0
- package/dist/services/specification-service.test.d.ts +2 -0
- package/dist/services/specification-service.test.d.ts.map +1 -0
- package/dist/services/specification-service.test.js +549 -0
- package/dist/services/specification-service.test.js.map +1 -0
- package/dist/services/status-service.d.ts +72 -0
- package/dist/services/status-service.d.ts.map +1 -0
- package/dist/services/status-service.js +253 -0
- package/dist/services/status-service.js.map +1 -0
- package/dist/services/status-service.test.d.ts +2 -0
- package/dist/services/status-service.test.d.ts.map +1 -0
- package/dist/services/status-service.test.js +447 -0
- package/dist/services/status-service.test.js.map +1 -0
- package/dist/services/task-fetch-service.d.ts +24 -0
- package/dist/services/task-fetch-service.d.ts.map +1 -0
- package/dist/services/task-fetch-service.js +109 -0
- package/dist/services/task-fetch-service.js.map +1 -0
- package/dist/services/task-fetch-service.test.d.ts +2 -0
- package/dist/services/task-fetch-service.test.d.ts.map +1 -0
- package/dist/services/task-fetch-service.test.js +243 -0
- package/dist/services/task-fetch-service.test.js.map +1 -0
- package/dist/services/task-service.d.ts +25 -0
- package/dist/services/task-service.d.ts.map +1 -0
- package/dist/services/task-service.js +114 -0
- package/dist/services/task-service.js.map +1 -0
- package/dist/services/task-service.test.d.ts +2 -0
- package/dist/services/task-service.test.d.ts.map +1 -0
- package/dist/services/task-service.test.js +235 -0
- package/dist/services/task-service.test.js.map +1 -0
- package/dist/services/task-sync-service.d.ts +25 -0
- package/dist/services/task-sync-service.d.ts.map +1 -0
- package/dist/services/task-sync-service.js +84 -0
- package/dist/services/task-sync-service.js.map +1 -0
- package/dist/services/task-sync-service.test.d.ts +2 -0
- package/dist/services/task-sync-service.test.d.ts.map +1 -0
- package/dist/services/task-sync-service.test.js +187 -0
- package/dist/services/task-sync-service.test.js.map +1 -0
- package/dist/services/validation-service.d.ts +6 -0
- package/dist/services/validation-service.d.ts.map +1 -0
- package/dist/services/validation-service.js +167 -0
- package/dist/services/validation-service.js.map +1 -0
- package/dist/services/validation-service.test.d.ts +2 -0
- package/dist/services/validation-service.test.d.ts.map +1 -0
- package/dist/services/validation-service.test.js +136 -0
- package/dist/services/validation-service.test.js.map +1 -0
- package/dist/services/version-service.d.ts +85 -0
- package/dist/services/version-service.d.ts.map +1 -0
- package/dist/services/version-service.js +184 -0
- package/dist/services/version-service.js.map +1 -0
- package/dist/services/version-service.test.d.ts +2 -0
- package/dist/services/version-service.test.d.ts.map +1 -0
- package/dist/services/version-service.test.js +332 -0
- package/dist/services/version-service.test.js.map +1 -0
- package/dist/templates/finalize-approval.yml +135 -0
- package/dist/templates/templates/finalize-approval.yml +144 -0
- package/dist/utils/display.d.ts +6 -0
- package/dist/utils/display.d.ts.map +1 -0
- package/dist/utils/display.js +27 -0
- package/dist/utils/display.js.map +1 -0
- package/dist/utils/error-handler.d.ts +4 -0
- package/dist/utils/error-handler.d.ts.map +1 -0
- package/dist/utils/error-handler.js +17 -0
- package/dist/utils/error-handler.js.map +1 -0
- package/dist/utils/error-handler.test.d.ts +2 -0
- package/dist/utils/error-handler.test.d.ts.map +1 -0
- package/dist/utils/error-handler.test.js +65 -0
- package/dist/utils/error-handler.test.js.map +1 -0
- package/dist/utils/errors.d.ts +17 -0
- package/dist/utils/errors.d.ts.map +1 -0
- package/dist/utils/errors.js +23 -0
- package/dist/utils/errors.js.map +1 -0
- package/dist/utils/errors.test.d.ts +2 -0
- package/dist/utils/errors.test.d.ts.map +1 -0
- package/dist/utils/errors.test.js +39 -0
- package/dist/utils/errors.test.js.map +1 -0
- package/dist/utils/id-generator.d.ts +3 -0
- package/dist/utils/id-generator.d.ts.map +1 -0
- package/dist/utils/id-generator.js +24 -0
- package/dist/utils/id-generator.js.map +1 -0
- package/dist/utils/progress-calculator.d.ts +11 -0
- package/dist/utils/progress-calculator.d.ts.map +1 -0
- package/dist/utils/progress-calculator.js +11 -0
- package/dist/utils/progress-calculator.js.map +1 -0
- package/dist/utils/progress-calculator.test.d.ts +2 -0
- package/dist/utils/progress-calculator.test.d.ts.map +1 -0
- package/dist/utils/progress-calculator.test.js +186 -0
- package/dist/utils/progress-calculator.test.js.map +1 -0
- package/dist/utils/spec-id-generator.d.ts +2 -0
- package/dist/utils/spec-id-generator.d.ts.map +1 -0
- package/dist/utils/spec-id-generator.js +3 -0
- package/dist/utils/spec-id-generator.js.map +1 -0
- package/dist/utils/spec-tag-parser.d.ts +7 -0
- package/dist/utils/spec-tag-parser.d.ts.map +1 -0
- package/dist/utils/spec-tag-parser.js +27 -0
- package/dist/utils/spec-tag-parser.js.map +1 -0
- package/dist/utils/spec-tag-parser.test.d.ts +2 -0
- package/dist/utils/spec-tag-parser.test.d.ts.map +1 -0
- package/dist/utils/spec-tag-parser.test.js +73 -0
- package/dist/utils/spec-tag-parser.test.js.map +1 -0
- package/dist/utils/templates.d.ts +5 -0
- package/dist/utils/templates.d.ts.map +1 -0
- package/dist/utils/templates.js +116 -0
- package/dist/utils/templates.js.map +1 -0
- package/package.json +56 -0
package/README.md
ADDED
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
# @reqord/cli
|
|
2
|
+
|
|
3
|
+
**Git-native requirements management CLI -- traceable, AI-ready, local-first.**
|
|
4
|
+
|
|
5
|
+
[](https://www.npmjs.com/package/@reqord/cli)
|
|
6
|
+
[](../../LICENSE)
|
|
7
|
+
|
|
8
|
+
## Install
|
|
9
|
+
|
|
10
|
+
```bash
|
|
11
|
+
npm install -g @reqord/cli
|
|
12
|
+
```
|
|
13
|
+
|
|
14
|
+
## Quick Start
|
|
15
|
+
|
|
16
|
+
```bash
|
|
17
|
+
# 1. Initialize .reqord/ directory in your project
|
|
18
|
+
reqord init
|
|
19
|
+
|
|
20
|
+
# 2. Create your first requirement
|
|
21
|
+
reqord req create
|
|
22
|
+
|
|
23
|
+
# 3. List requirements
|
|
24
|
+
reqord req list
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
## Commands
|
|
28
|
+
|
|
29
|
+
| Command | Description |
|
|
30
|
+
|---------|-------------|
|
|
31
|
+
| `reqord init` | Initialize `.reqord/` directory structure |
|
|
32
|
+
| `reqord context init` | Set up project context |
|
|
33
|
+
| `reqord context show` | Display project context summary |
|
|
34
|
+
| `reqord context update` | Update context metadata |
|
|
35
|
+
| `reqord req create` | Create a new requirement |
|
|
36
|
+
| `reqord req list` | List requirements (with filters) |
|
|
37
|
+
| `reqord req show <id>` | Show requirement details |
|
|
38
|
+
| `reqord req update <id>` | Update requirement metadata |
|
|
39
|
+
| `reqord req delete <id>` | Delete a requirement |
|
|
40
|
+
| `reqord req validate <id>` | SMART validation scoring |
|
|
41
|
+
| `reqord req history <id>` | View version history |
|
|
42
|
+
| `reqord req approve <id>` | Create approval PR |
|
|
43
|
+
| `reqord spec create <req-id>` | Create specification for a requirement |
|
|
44
|
+
| `reqord spec list` | List specifications |
|
|
45
|
+
| `reqord spec show <id>` | Show specification details |
|
|
46
|
+
| `reqord spec design <id>` | View/update design document |
|
|
47
|
+
| `reqord spec approve <id>` | Create approval PR for specification |
|
|
48
|
+
| `reqord feedback sync` | Sync with GitHub Issues |
|
|
49
|
+
| `reqord feedback list` | List feedback items |
|
|
50
|
+
| `reqord feedback show <id>` | Show feedback details |
|
|
51
|
+
| `reqord feedback close <id>` | Close a feedback item |
|
|
52
|
+
| `reqord feedback link <id>` | Link feedback to requirement/spec |
|
|
53
|
+
| `reqord task create <spec-id>` | Generate GitHub Issues from tasks |
|
|
54
|
+
| `reqord task sync <spec-id>` | Sync issue status to specification |
|
|
55
|
+
| `reqord ui` | Launch web dashboard |
|
|
56
|
+
|
|
57
|
+
For the full command reference including planned features, see the [CLI Reference](../../docs/cli-reference.md).
|
|
58
|
+
|
|
59
|
+
## Prerequisites
|
|
60
|
+
|
|
61
|
+
- Node.js 20+
|
|
62
|
+
- Git
|
|
63
|
+
- GitHub CLI (`gh`) -- required for feedback sync, approval, and issue commands
|
|
64
|
+
|
|
65
|
+
## Documentation
|
|
66
|
+
|
|
67
|
+
- [Getting Started](../../docs/getting-started.md)
|
|
68
|
+
- [Requirements Guide](../../docs/guide-requirements.md)
|
|
69
|
+
- [Full Documentation](../../docs/README.md)
|
|
70
|
+
|
|
71
|
+
## License
|
|
72
|
+
|
|
73
|
+
[AGPL-3.0](../../LICENSE)
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../../../src/commands/context/init.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAKpC,eAAO,MAAM,kBAAkB,SAmC3B,CAAC"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import chalk from "chalk";
|
|
3
|
+
import { initContext } from "../../services/context-service.js";
|
|
4
|
+
import { handleError } from "../../utils/error-handler.js";
|
|
5
|
+
export const contextInitCommand = new Command("init")
|
|
6
|
+
.description("Initialize project context")
|
|
7
|
+
.argument("<name>", "Project name")
|
|
8
|
+
.option("-l, --language <lang>", "Language (default: ja)", "ja")
|
|
9
|
+
.action(async (name, options) => {
|
|
10
|
+
const cwd = process.cwd();
|
|
11
|
+
try {
|
|
12
|
+
const id = name.toLowerCase().replace(/\s+/g, "-");
|
|
13
|
+
const context = await initContext(cwd, {
|
|
14
|
+
id,
|
|
15
|
+
name,
|
|
16
|
+
language: options.language,
|
|
17
|
+
});
|
|
18
|
+
console.log(chalk.green(`Initialized project context: ${context.name}`));
|
|
19
|
+
console.log("");
|
|
20
|
+
console.log(` ID: ${context.id}`);
|
|
21
|
+
console.log(` Name: ${context.name}`);
|
|
22
|
+
console.log(` Version: ${context.version}`);
|
|
23
|
+
console.log(` Language: ${context.language}`);
|
|
24
|
+
console.log("");
|
|
25
|
+
console.log(chalk.gray("Generated files:"));
|
|
26
|
+
console.log(chalk.gray(" context/context.yaml"));
|
|
27
|
+
console.log(chalk.gray(" context/product.yaml"));
|
|
28
|
+
console.log(chalk.gray(" context/technical.yaml"));
|
|
29
|
+
console.log(chalk.gray(" context/structure.yaml"));
|
|
30
|
+
console.log(chalk.gray(" context/domain/"));
|
|
31
|
+
console.log("");
|
|
32
|
+
console.log(chalk.gray("Next: Edit context files to describe your project."));
|
|
33
|
+
}
|
|
34
|
+
catch (error) {
|
|
35
|
+
handleError(error);
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
//# sourceMappingURL=init.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../../src/commands/context/init.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,MAAM,mCAAmC,CAAC;AAChE,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAE3D,MAAM,CAAC,MAAM,kBAAkB,GAAG,IAAI,OAAO,CAAC,MAAM,CAAC;KAClD,WAAW,CAAC,4BAA4B,CAAC;KACzC,QAAQ,CAAC,QAAQ,EAAE,cAAc,CAAC;KAClC,MAAM,CAAC,uBAAuB,EAAE,wBAAwB,EAAE,IAAI,CAAC;KAC/D,MAAM,CAAC,KAAK,EAAE,IAAY,EAAE,OAA6B,EAAE,EAAE;IAC5D,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;IAE1B,IAAI,CAAC;QACH,MAAM,EAAE,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QACnD,MAAM,OAAO,GAAG,MAAM,WAAW,CAAC,GAAG,EAAE;YACrC,EAAE;YACF,IAAI;YACJ,QAAQ,EAAE,OAAO,CAAC,QAAQ;SAC3B,CAAC,CAAC;QAEH,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,gCAAgC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QACzE,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAChB,OAAO,CAAC,GAAG,CAAC,eAAe,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;QACzC,OAAO,CAAC,GAAG,CAAC,eAAe,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;QAC3C,OAAO,CAAC,GAAG,CAAC,eAAe,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;QAC9C,OAAO,CAAC,GAAG,CAAC,eAAe,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC/C,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAChB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC;QAC5C,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC,CAAC;QAClD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC,CAAC;QAClD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC,CAAC;QACpD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC,CAAC;QACpD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC;QAC7C,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAChB,OAAO,CAAC,GAAG,CACT,KAAK,CAAC,IAAI,CAAC,oDAAoD,CAAC,CACjE,CAAC;IACJ,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,WAAW,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"show.d.ts","sourceRoot":"","sources":["../../../src/commands/context/show.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,eAAO,MAAM,kBAAkB,SA0D3B,CAAC"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import chalk from "chalk";
|
|
3
|
+
import { showContext, resolveFilePath } from "../../services/context-service.js";
|
|
4
|
+
import * as fs from "../../repositories/file-system.js";
|
|
5
|
+
import { handleError } from "../../utils/error-handler.js";
|
|
6
|
+
export const contextShowCommand = new Command("show")
|
|
7
|
+
.description("Show project context summary")
|
|
8
|
+
.option("--json", "Output as JSON")
|
|
9
|
+
.option("--detail", "Show file contents")
|
|
10
|
+
.action(async (options) => {
|
|
11
|
+
const cwd = process.cwd();
|
|
12
|
+
try {
|
|
13
|
+
const result = await showContext(cwd);
|
|
14
|
+
const ctx = result.context;
|
|
15
|
+
if (options.json) {
|
|
16
|
+
const jsonOutput = {
|
|
17
|
+
context: result.context,
|
|
18
|
+
product: result.product ?? null,
|
|
19
|
+
technical: result.technical ?? null,
|
|
20
|
+
structure: result.structure ?? null,
|
|
21
|
+
domainFiles: result.domainFiles,
|
|
22
|
+
};
|
|
23
|
+
console.log(JSON.stringify(jsonOutput, null, 2));
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
console.log(chalk.cyan(`Project: ${ctx.name}`));
|
|
27
|
+
console.log("");
|
|
28
|
+
console.log(` ID: ${ctx.id}`);
|
|
29
|
+
console.log(` Version: ${ctx.version}`);
|
|
30
|
+
console.log(` Language: ${ctx.language}`);
|
|
31
|
+
console.log("");
|
|
32
|
+
console.log(chalk.cyan("Files:"));
|
|
33
|
+
console.log(` product: ${result.productExists ? chalk.green("exists") : chalk.red("missing")}`);
|
|
34
|
+
console.log(` technical: ${result.technicalExists ? chalk.green("exists") : chalk.red("missing")}`);
|
|
35
|
+
console.log(` structure: ${result.structureExists ? chalk.green("exists") : chalk.red("missing")}`);
|
|
36
|
+
console.log(` domain: ${result.domainFiles.length} file(s)`);
|
|
37
|
+
if (result.domainFiles.length > 0) {
|
|
38
|
+
for (const file of result.domainFiles) {
|
|
39
|
+
console.log(chalk.gray(` - ${file}`));
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
if (options.detail) {
|
|
43
|
+
console.log("");
|
|
44
|
+
await showFileDetail(cwd, "product", result.productExists, ctx);
|
|
45
|
+
await showFileDetail(cwd, "technical", result.technicalExists, ctx);
|
|
46
|
+
await showFileDetail(cwd, "structure", result.structureExists, ctx);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
catch (error) {
|
|
50
|
+
handleError(error, { json: options.json });
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
async function showFileDetail(cwd, name, exists, ctx) {
|
|
54
|
+
if (!exists)
|
|
55
|
+
return;
|
|
56
|
+
const filePath = resolveFilePath(ctx.files[name]);
|
|
57
|
+
if (!filePath)
|
|
58
|
+
return;
|
|
59
|
+
const fullPath = fs.getReqordDir(cwd, filePath);
|
|
60
|
+
try {
|
|
61
|
+
const content = await fs.readText(fullPath);
|
|
62
|
+
console.log(chalk.cyan(`--- ${name} (${filePath}) ---`));
|
|
63
|
+
console.log(content);
|
|
64
|
+
}
|
|
65
|
+
catch {
|
|
66
|
+
// skip unreadable files
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
//# sourceMappingURL=show.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"show.js","sourceRoot":"","sources":["../../../src/commands/context/show.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update.d.ts","sourceRoot":"","sources":["../../../src/commands/context/update.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAUpC,eAAO,MAAM,oBAAoB,SA4D9B,CAAC"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import chalk from "chalk";
|
|
3
|
+
import { updateContext, } from "../../services/context-service.js";
|
|
4
|
+
import * as fs from "../../repositories/file-system.js";
|
|
5
|
+
import { handleError } from "../../utils/error-handler.js";
|
|
6
|
+
import { AppError, ErrorCode } from "../../utils/errors.js";
|
|
7
|
+
export const contextUpdateCommand = new Command("update")
|
|
8
|
+
.description("Update project context")
|
|
9
|
+
.option("-n, --name <name>", "New project name")
|
|
10
|
+
.option("-v, --version <version>", "New project version")
|
|
11
|
+
.option("--product <path>", "JSON file to patch product.yaml")
|
|
12
|
+
.option("--technical <path>", "JSON file to patch technical.yaml")
|
|
13
|
+
.option("--structure <path>", "JSON file to patch structure.yaml")
|
|
14
|
+
.option("--json", "Output as JSON")
|
|
15
|
+
.action(async (options) => {
|
|
16
|
+
const { name, version, product, technical, structure } = options;
|
|
17
|
+
const cwd = process.cwd();
|
|
18
|
+
try {
|
|
19
|
+
if (!name && !version && !product && !technical && !structure) {
|
|
20
|
+
throw new AppError("At least one option (--name, --version, --product, --technical, --structure) is required.", ErrorCode.INVALID_ARGUMENT);
|
|
21
|
+
}
|
|
22
|
+
const updateOpts = {
|
|
23
|
+
name,
|
|
24
|
+
version,
|
|
25
|
+
productPatch: product ? await loadPatchFile(product) : undefined,
|
|
26
|
+
technicalPatch: technical ? await loadPatchFile(technical) : undefined,
|
|
27
|
+
structurePatch: structure ? await loadPatchFile(structure) : undefined,
|
|
28
|
+
};
|
|
29
|
+
const result = await updateContext(cwd, updateOpts);
|
|
30
|
+
if (options.json) {
|
|
31
|
+
console.log(JSON.stringify(result, null, 2));
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
console.log(chalk.green("Updated project context."));
|
|
35
|
+
if (result.before.name !== result.after.name) {
|
|
36
|
+
console.log(` name: ${result.before.name} → ${result.after.name}`);
|
|
37
|
+
}
|
|
38
|
+
if (result.before.version !== result.after.version) {
|
|
39
|
+
console.log(` version: ${result.before.version} → ${result.after.version}`);
|
|
40
|
+
}
|
|
41
|
+
if (result.updatedFiles.length > 0) {
|
|
42
|
+
console.log(` files: ${result.updatedFiles.map((f) => `${f}.yaml`).join(", ")} updated`);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
catch (error) {
|
|
46
|
+
handleError(error, { json: options.json });
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
async function loadPatchFile(path) {
|
|
50
|
+
const content = await fs.readText(path);
|
|
51
|
+
try {
|
|
52
|
+
return JSON.parse(content);
|
|
53
|
+
}
|
|
54
|
+
catch {
|
|
55
|
+
throw new Error(`Invalid JSON in patch file: ${path}`);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=update.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update.js","sourceRoot":"","sources":["../../../src/commands/context/update.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"close.d.ts","sourceRoot":"","sources":["../../../src/commands/feedback/close.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,eAAO,MAAM,oBAAoB,SAmC7B,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import chalk from "chalk";
|
|
3
|
+
import { closeFeedback, checkRemainingFlags, showFeedback } from "../../services/feedback-service.js";
|
|
4
|
+
import { handleError } from "../../utils/error-handler.js";
|
|
5
|
+
import { parseIssueNumber } from "../../utils/display.js";
|
|
6
|
+
export const feedbackCloseCommand = new Command("close")
|
|
7
|
+
.description("Close feedback (updates index.yaml and closes GitHub Issue)")
|
|
8
|
+
.argument("<issue-number>", "GitHub issue number")
|
|
9
|
+
.action(async (issueNumberStr) => {
|
|
10
|
+
try {
|
|
11
|
+
const cwd = process.cwd();
|
|
12
|
+
const issueNumber = parseIssueNumber(issueNumberStr);
|
|
13
|
+
// v3.0.0: Remaining flag warning
|
|
14
|
+
const { feedback } = await showFeedback(cwd, issueNumber);
|
|
15
|
+
const remainingFlags = checkRemainingFlags(feedback);
|
|
16
|
+
if (remainingFlags.length > 0) {
|
|
17
|
+
console.log(chalk.yellow(`⚠ Warning: Linked artifacts have unresolved feedback:`));
|
|
18
|
+
for (const flag of remainingFlags) {
|
|
19
|
+
console.log(chalk.yellow(` - ${flag.artifactId}: unresolved (issue #${flag.issueNumber}, ${flag.severity})`));
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
await closeFeedback(cwd, issueNumber);
|
|
23
|
+
console.log(chalk.green(`✓ Closed Feedback #${issueNumber}`));
|
|
24
|
+
if (remainingFlags.length > 0) {
|
|
25
|
+
console.log(chalk.gray(" Unresolved feedback remains. Use 'reqord feedback resolve' to mark as resolved."));
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
catch (error) {
|
|
29
|
+
handleError(error);
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
//# sourceMappingURL=close.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"close.js","sourceRoot":"","sources":["../../../src/commands/feedback/close.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,YAAY,EAAE,MAAM,oCAAoC,CAAC;AACtG,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAE1D,MAAM,CAAC,MAAM,oBAAoB,GAAG,IAAI,OAAO,CAAC,OAAO,CAAC;KACrD,WAAW,CAAC,6DAA6D,CAAC;KAC1E,QAAQ,CAAC,gBAAgB,EAAE,qBAAqB,CAAC;KACjD,MAAM,CAAC,KAAK,EAAE,cAAsB,EAAE,EAAE;IACvC,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QAC1B,MAAM,WAAW,GAAG,gBAAgB,CAAC,cAAc,CAAC,CAAC;QAErD,iCAAiC;QACjC,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,YAAY,CAAC,GAAG,EAAE,WAAW,CAAC,CAAC;QAC1D,MAAM,cAAc,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAC;QACrD,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,OAAO,CAAC,GAAG,CACT,KAAK,CAAC,MAAM,CACV,uDAAuD,CACxD,CACF,CAAC;YACF,KAAK,MAAM,IAAI,IAAI,cAAc,EAAE,CAAC;gBAClC,OAAO,CAAC,GAAG,CACT,KAAK,CAAC,MAAM,CACV,OAAO,IAAI,CAAC,UAAU,wBAAwB,IAAI,CAAC,WAAW,KAAK,IAAI,CAAC,QAAQ,GAAG,CACpF,CACF,CAAC;YACJ,CAAC;QACH,CAAC;QAED,MAAM,aAAa,CAAC,GAAG,EAAE,WAAW,CAAC,CAAC;QAEtC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,sBAAsB,WAAW,EAAE,CAAC,CAAC,CAAC;QAC9D,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,mFAAmF,CAAC,CAAC,CAAC;QAC/G,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,WAAW,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create.d.ts","sourceRoot":"","sources":["../../../src/commands/feedback/create.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,eAAO,MAAM,qBAAqB,SAkC9B,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import chalk from "chalk";
|
|
3
|
+
import { createFeedbackIssue } from "../../services/feedback-service.js";
|
|
4
|
+
import { handleError } from "../../utils/error-handler.js";
|
|
5
|
+
export const feedbackCreateCommand = new Command("create")
|
|
6
|
+
.description("Create a new feedback GitHub Issue (follows ISSUE_TEMPLATE/05-feedback.yml)")
|
|
7
|
+
.requiredOption("--title <title>", "Issue title (auto-prefixed with [Feedback])")
|
|
8
|
+
.requiredOption("--description <text>", "What happened / what did you notice?")
|
|
9
|
+
.option("--type <type>", "Feedback type (bug|improvement|requirement-gap|spec-mismatch|security)")
|
|
10
|
+
.option("--severity <level>", "Severity (critical|high|medium|low)")
|
|
11
|
+
.option("--related-req <id>", "Related requirement ID")
|
|
12
|
+
.option("--related-spec <id>", "Related specification ID")
|
|
13
|
+
.action(async (options) => {
|
|
14
|
+
try {
|
|
15
|
+
const cwd = process.cwd();
|
|
16
|
+
const issueNumber = await createFeedbackIssue(cwd, {
|
|
17
|
+
title: options.title,
|
|
18
|
+
description: options.description,
|
|
19
|
+
type: options.type,
|
|
20
|
+
severity: options.severity,
|
|
21
|
+
relatedReq: options.relatedReq,
|
|
22
|
+
relatedSpec: options.relatedSpec,
|
|
23
|
+
});
|
|
24
|
+
console.log(chalk.green(`✓ Created Feedback Issue #${issueNumber}`));
|
|
25
|
+
console.log(chalk.gray(` Label: feedback, reqord-generated`));
|
|
26
|
+
console.log(chalk.gray(` Updated .reqord/issues/feedbacks.yaml`));
|
|
27
|
+
}
|
|
28
|
+
catch (error) {
|
|
29
|
+
handleError(error);
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
//# sourceMappingURL=create.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/commands/feedback/create.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AAEzE,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAE3D,MAAM,CAAC,MAAM,qBAAqB,GAAG,IAAI,OAAO,CAAC,QAAQ,CAAC;KACvD,WAAW,CAAC,6EAA6E,CAAC;KAC1F,cAAc,CAAC,iBAAiB,EAAE,6CAA6C,CAAC;KAChF,cAAc,CAAC,sBAAsB,EAAE,sCAAsC,CAAC;KAC9E,MAAM,CAAC,eAAe,EAAE,wEAAwE,CAAC;KACjG,MAAM,CAAC,oBAAoB,EAAE,qCAAqC,CAAC;KACnE,MAAM,CAAC,oBAAoB,EAAE,wBAAwB,CAAC;KACtD,MAAM,CAAC,qBAAqB,EAAE,0BAA0B,CAAC;KACzD,MAAM,CAAC,KAAK,EAAE,OAOd,EAAE,EAAE;IACH,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QAE1B,MAAM,WAAW,GAAG,MAAM,mBAAmB,CAAC,GAAG,EAAE;YACjD,KAAK,EAAE,OAAO,CAAC,KAAK;YACpB,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,IAAI,EAAE,OAAO,CAAC,IAAgC;YAC9C,QAAQ,EAAE,OAAO,CAAC,QAAwC;YAC1D,UAAU,EAAE,OAAO,CAAC,UAAU;YAC9B,WAAW,EAAE,OAAO,CAAC,WAAW;SACjC,CAAC,CAAC;QAEH,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,6BAA6B,WAAW,EAAE,CAAC,CAAC,CAAC;QACrE,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,qCAAqC,CAAC,CAAC,CAAC;QAC/D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,yCAAyC,CAAC,CAAC,CAAC;IACrE,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,WAAW,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/commands/feedback/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAUpC,eAAO,MAAM,eAAe,SACwB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import { syncCommand } from "./sync.js";
|
|
3
|
+
import { feedbackListCommand } from "./list.js";
|
|
4
|
+
import { feedbackShowCommand } from "./show.js";
|
|
5
|
+
import { feedbackLinkCommand } from "./link.js";
|
|
6
|
+
import { feedbackUnlinkCommand } from "./unlink.js";
|
|
7
|
+
import { feedbackCloseCommand } from "./close.js";
|
|
8
|
+
import { resolveCommand } from "./resolve.js";
|
|
9
|
+
import { feedbackCreateCommand } from "./create.js";
|
|
10
|
+
export const feedbackCommand = new Command("feedback")
|
|
11
|
+
.description("Manage feedback from GitHub issues");
|
|
12
|
+
feedbackCommand.addCommand(syncCommand);
|
|
13
|
+
feedbackCommand.addCommand(feedbackListCommand);
|
|
14
|
+
feedbackCommand.addCommand(feedbackShowCommand);
|
|
15
|
+
feedbackCommand.addCommand(feedbackLinkCommand);
|
|
16
|
+
feedbackCommand.addCommand(feedbackUnlinkCommand);
|
|
17
|
+
feedbackCommand.addCommand(feedbackCloseCommand);
|
|
18
|
+
feedbackCommand.addCommand(resolveCommand);
|
|
19
|
+
feedbackCommand.addCommand(feedbackCreateCommand);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/feedback/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxC,OAAO,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAChD,OAAO,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAChD,OAAO,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AACpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAEpD,MAAM,CAAC,MAAM,eAAe,GAAG,IAAI,OAAO,CAAC,UAAU,CAAC;KACnD,WAAW,CAAC,oCAAoC,CAAC,CAAC;AAErD,eAAe,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;AACxC,eAAe,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;AAChD,eAAe,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;AAChD,eAAe,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;AAChD,eAAe,CAAC,UAAU,CAAC,qBAAqB,CAAC,CAAC;AAClD,eAAe,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC;AACjD,eAAe,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;AAC3C,eAAe,CAAC,UAAU,CAAC,qBAAqB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"link.d.ts","sourceRoot":"","sources":["../../../src/commands/feedback/link.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAWpC,eAAO,MAAM,mBAAmB,SAoD5B,CAAC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import chalk from "chalk";
|
|
3
|
+
import { linkToRequirement, linkWithNewRequirement, linkToSpecification, } from "../../services/feedback-service.js";
|
|
4
|
+
import { handleError } from "../../utils/error-handler.js";
|
|
5
|
+
import { parseIssueNumber } from "../../utils/display.js";
|
|
6
|
+
export const feedbackLinkCommand = new Command("link")
|
|
7
|
+
.description("Link feedback to requirement or specification")
|
|
8
|
+
.argument("<issue-number>", "GitHub issue number")
|
|
9
|
+
.option("--req <id>", "Link to existing requirement")
|
|
10
|
+
.option("--created-req", "Create new requirement from feedback")
|
|
11
|
+
.option("--spec <id>", "Link to specification")
|
|
12
|
+
.option("--type <type>", "Feedback type (bug|improvement|requirement-gap|spec-mismatch|security)")
|
|
13
|
+
.option("--severity <level>", "Severity (critical|high|medium|low)")
|
|
14
|
+
.action(async (issueNumberStr, options) => {
|
|
15
|
+
try {
|
|
16
|
+
const cwd = process.cwd();
|
|
17
|
+
const issueNumber = parseIssueNumber(issueNumberStr);
|
|
18
|
+
// Mutual exclusion check
|
|
19
|
+
const modes = [options.req, options.createdReq, options.spec].filter(Boolean);
|
|
20
|
+
if (modes.length !== 1) {
|
|
21
|
+
throw new Error("Specify exactly one of --req, --created-req, or --spec");
|
|
22
|
+
}
|
|
23
|
+
if (options.req) {
|
|
24
|
+
await linkToRequirement(cwd, {
|
|
25
|
+
issueNumber,
|
|
26
|
+
requirementId: options.req,
|
|
27
|
+
type: options.type,
|
|
28
|
+
severity: options.severity,
|
|
29
|
+
});
|
|
30
|
+
console.log(chalk.green(`✓ Linked Feedback #${issueNumber} to ${options.req}`));
|
|
31
|
+
}
|
|
32
|
+
else if (options.createdReq) {
|
|
33
|
+
const newId = await linkWithNewRequirement(cwd, {
|
|
34
|
+
issueNumber,
|
|
35
|
+
type: options.type,
|
|
36
|
+
severity: options.severity,
|
|
37
|
+
});
|
|
38
|
+
console.log(chalk.green(`✓ Created ${newId} from Feedback #${issueNumber}`));
|
|
39
|
+
}
|
|
40
|
+
else if (options.spec) {
|
|
41
|
+
await linkToSpecification(cwd, {
|
|
42
|
+
issueNumber,
|
|
43
|
+
specificationId: options.spec,
|
|
44
|
+
type: options.type,
|
|
45
|
+
severity: options.severity,
|
|
46
|
+
});
|
|
47
|
+
console.log(chalk.green(`✓ Linked Feedback #${issueNumber} to ${options.spec}`));
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
catch (error) {
|
|
51
|
+
handleError(error);
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
//# sourceMappingURL=link.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"link.js","sourceRoot":"","sources":["../../../src/commands/feedback/link.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EACL,iBAAiB,EACjB,sBAAsB,EACtB,mBAAmB,GACpB,MAAM,oCAAoC,CAAC;AAE5C,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAE1D,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,OAAO,CAAC,MAAM,CAAC;KACnD,WAAW,CAAC,+CAA+C,CAAC;KAC5D,QAAQ,CAAC,gBAAgB,EAAE,qBAAqB,CAAC;KACjD,MAAM,CAAC,YAAY,EAAE,8BAA8B,CAAC;KACpD,MAAM,CAAC,eAAe,EAAE,sCAAsC,CAAC;KAC/D,MAAM,CAAC,aAAa,EAAE,uBAAuB,CAAC;KAC9C,MAAM,CAAC,eAAe,EAAE,wEAAwE,CAAC;KACjG,MAAM,CAAC,oBAAoB,EAAE,qCAAqC,CAAC;KACnE,MAAM,CAAC,KAAK,EAAE,cAAsB,EAAE,OAMtC,EAAE,EAAE;IACH,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QAC1B,MAAM,WAAW,GAAG,gBAAgB,CAAC,cAAc,CAAC,CAAC;QAErD,yBAAyB;QACzB,MAAM,KAAK,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,UAAU,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC9E,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACvB,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAC;QAC5E,CAAC;QAED,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;YAChB,MAAM,iBAAiB,CAAC,GAAG,EAAE;gBAC3B,WAAW;gBACX,aAAa,EAAE,OAAO,CAAC,GAAG;gBAC1B,IAAI,EAAE,OAAO,CAAC,IAAgC;gBAC9C,QAAQ,EAAE,OAAO,CAAC,QAAwC;aAC3D,CAAC,CAAC;YACH,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,sBAAsB,WAAW,OAAO,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QAClF,CAAC;aAAM,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;YAC9B,MAAM,KAAK,GAAG,MAAM,sBAAsB,CAAC,GAAG,EAAE;gBAC9C,WAAW;gBACX,IAAI,EAAE,OAAO,CAAC,IAAgC;gBAC9C,QAAQ,EAAE,OAAO,CAAC,QAAwC;aAC3D,CAAC,CAAC;YACH,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,aAAa,KAAK,mBAAmB,WAAW,EAAE,CAAC,CAAC,CAAC;QAC/E,CAAC;aAAM,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACxB,MAAM,mBAAmB,CAAC,GAAG,EAAE;gBAC7B,WAAW;gBACX,eAAe,EAAE,OAAO,CAAC,IAAI;gBAC7B,IAAI,EAAE,OAAO,CAAC,IAAgC;gBAC9C,QAAQ,EAAE,OAAO,CAAC,QAAwC;aAC3D,CAAC,CAAC;YACH,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,sBAAsB,WAAW,OAAO,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QACnF,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,WAAW,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list.d.ts","sourceRoot":"","sources":["../../../src/commands/feedback/list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAQpC,eAAO,MAAM,mBAAmB,SA8C5B,CAAC"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import chalk from "chalk";
|
|
3
|
+
import Table from "cli-table3";
|
|
4
|
+
import { listFeedbacks } from "../../services/feedback-service.js";
|
|
5
|
+
import { handleError } from "../../utils/error-handler.js";
|
|
6
|
+
import { FEEDBACK_STATUS_COLORS, identityColor } from "../../utils/display.js";
|
|
7
|
+
export const feedbackListCommand = new Command("list")
|
|
8
|
+
.description("List feedback issues from index.yaml")
|
|
9
|
+
.option("--state <state>", "Filter by state (open|closed|all)", "all")
|
|
10
|
+
.option("--type <type>", "Filter by type")
|
|
11
|
+
.option("--json", "Output as JSON")
|
|
12
|
+
.action(async (options) => {
|
|
13
|
+
try {
|
|
14
|
+
const cwd = process.cwd();
|
|
15
|
+
const feedbacks = await listFeedbacks(cwd, {
|
|
16
|
+
state: options.state,
|
|
17
|
+
type: options.type,
|
|
18
|
+
});
|
|
19
|
+
if (options.json) {
|
|
20
|
+
console.log(JSON.stringify(feedbacks, null, 2));
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
if (feedbacks.length === 0) {
|
|
24
|
+
console.log(chalk.gray("No feedbacks found. Run 'reqord feedback sync' first."));
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
const table = new Table({
|
|
28
|
+
head: ["Issue", "Title", "Status", "Type", "Severity", "Requirements", "Specs"],
|
|
29
|
+
style: { head: ["cyan"] },
|
|
30
|
+
});
|
|
31
|
+
for (const f of feedbacks) {
|
|
32
|
+
const statusColor = FEEDBACK_STATUS_COLORS[f.status] ?? identityColor;
|
|
33
|
+
table.push([
|
|
34
|
+
`#${f.githubIssue}`,
|
|
35
|
+
f.title ?? "-",
|
|
36
|
+
statusColor(f.status),
|
|
37
|
+
f.type ?? "-",
|
|
38
|
+
f.severity ?? "-",
|
|
39
|
+
f.linkedTo.requirements.join(", ") || "-",
|
|
40
|
+
f.linkedTo.specifications.join(", ") || "-",
|
|
41
|
+
]);
|
|
42
|
+
}
|
|
43
|
+
console.log(table.toString());
|
|
44
|
+
console.log(chalk.gray(`\n${feedbacks.length} feedback(s) found.`));
|
|
45
|
+
}
|
|
46
|
+
catch (error) {
|
|
47
|
+
handleError(error, { json: options.json });
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
//# sourceMappingURL=list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/commands/feedback/list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,KAAK,MAAM,YAAY,CAAC;AAC/B,OAAO,EAAE,aAAa,EAAE,MAAM,oCAAoC,CAAC;AAEnE,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,sBAAsB,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAE/E,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,OAAO,CAAC,MAAM,CAAC;KACnD,WAAW,CAAC,sCAAsC,CAAC;KACnD,MAAM,CAAC,iBAAiB,EAAE,mCAAmC,EAAE,KAAK,CAAC;KACrE,MAAM,CAAC,eAAe,EAAE,gBAAgB,CAAC;KACzC,MAAM,CAAC,QAAQ,EAAE,gBAAgB,CAAC;KAClC,MAAM,CAAC,KAAK,EAAE,OAA0D,EAAE,EAAE;IAC3E,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QAC1B,MAAM,SAAS,GAAG,MAAM,aAAa,CAAC,GAAG,EAAE;YACzC,KAAK,EAAE,OAAO,CAAC,KAA8C;YAC7D,IAAI,EAAE,OAAO,CAAC,IAAgC;SAC/C,CAAC,CAAC;QAEH,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YAChD,OAAO;QACT,CAAC;QAED,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC3B,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,uDAAuD,CAAC,CAAC,CAAC;YACjF,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC;YACtB,IAAI,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,cAAc,EAAE,OAAO,CAAC;YAC/E,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,MAAM,CAAC,EAAE;SAC1B,CAAC,CAAC;QAEH,KAAK,MAAM,CAAC,IAAI,SAAS,EAAE,CAAC;YAC1B,MAAM,WAAW,GAAG,sBAAsB,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,aAAa,CAAC;YACtE,KAAK,CAAC,IAAI,CAAC;gBACT,IAAI,CAAC,CAAC,WAAW,EAAE;gBACnB,CAAC,CAAC,KAAK,IAAI,GAAG;gBACd,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC;gBACrB,CAAC,CAAC,IAAI,IAAI,GAAG;gBACb,CAAC,CAAC,QAAQ,IAAI,GAAG;gBACjB,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG;gBACzC,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG;aAC5C,CAAC,CAAC;QACL,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC9B,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,SAAS,CAAC,MAAM,qBAAqB,CAAC,CAAC,CAAC;IACtE,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,WAAW,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;IAC7C,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve.d.ts","sourceRoot":"","sources":["../../../src/commands/feedback/resolve.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAKpC,eAAO,MAAM,cAAc,SA0BvB,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import chalk from "chalk";
|
|
3
|
+
import { resolveFeedback } from "../../services/feedback-service.js";
|
|
4
|
+
import { handleError } from "../../utils/error-handler.js";
|
|
5
|
+
export const resolveCommand = new Command("resolve")
|
|
6
|
+
.description("Resolve feedback flag on a requirement/specification")
|
|
7
|
+
.argument("<artifact-id>", "Requirement or Specification ID (e.g., req-000006)")
|
|
8
|
+
.requiredOption("--issue <number>", "GitHub issue number")
|
|
9
|
+
.action(async (artifactId, options) => {
|
|
10
|
+
try {
|
|
11
|
+
const cwd = process.cwd();
|
|
12
|
+
const issueNumber = parseInt(options.issue, 10);
|
|
13
|
+
if (isNaN(issueNumber) || issueNumber <= 0) {
|
|
14
|
+
throw new Error(`Invalid GitHub issue number (must be a positive integer): ${options.issue}`);
|
|
15
|
+
}
|
|
16
|
+
await resolveFeedback(cwd, { issueNumber, artifactId });
|
|
17
|
+
console.log(chalk.green(`✓ Resolved feedback #${issueNumber} flag on ${artifactId}`));
|
|
18
|
+
console.log(chalk.gray(` Added ${artifactId} to linkedTo.resolved`));
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
handleError(error);
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
//# sourceMappingURL=resolve.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve.js","sourceRoot":"","sources":["../../../src/commands/feedback/resolve.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAE3D,MAAM,CAAC,MAAM,cAAc,GAAG,IAAI,OAAO,CAAC,SAAS,CAAC;KACjD,WAAW,CAAC,sDAAsD,CAAC;KACnE,QAAQ,CAAC,eAAe,EAAE,oDAAoD,CAAC;KAC/E,cAAc,CAAC,kBAAkB,EAAE,qBAAqB,CAAC;KACzD,MAAM,CAAC,KAAK,EAAE,UAAkB,EAAE,OAA0B,EAAE,EAAE;IAC/D,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QAC1B,MAAM,WAAW,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEhD,IAAI,KAAK,CAAC,WAAW,CAAC,IAAI,WAAW,IAAI,CAAC,EAAE,CAAC;YAC3C,MAAM,IAAI,KAAK,CACb,6DAA6D,OAAO,CAAC,KAAK,EAAE,CAC7E,CAAC;QACJ,CAAC;QAED,MAAM,eAAe,CAAC,GAAG,EAAE,EAAE,WAAW,EAAE,UAAU,EAAE,CAAC,CAAC;QAExD,OAAO,CAAC,GAAG,CACT,KAAK,CAAC,KAAK,CACT,wBAAwB,WAAW,YAAY,UAAU,EAAE,CAC5D,CACF,CAAC;QACF,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,UAAU,uBAAuB,CAAC,CAAC,CAAC;IACxE,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,WAAW,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"show.d.ts","sourceRoot":"","sources":["../../../src/commands/feedback/show.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,eAAO,MAAM,mBAAmB,SA8B5B,CAAC"}
|