agentrix 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +235 -0
- package/bin/agentrix.js +5 -0
- package/dist/api/auth.d.ts +10 -0
- package/dist/api/auth.d.ts.map +1 -0
- package/dist/api/auth.js +30 -0
- package/dist/api/auth.js.map +1 -0
- package/dist/api/automation.d.ts +52 -0
- package/dist/api/automation.d.ts.map +1 -0
- package/dist/api/automation.js +181 -0
- package/dist/api/automation.js.map +1 -0
- package/dist/api/base-handler.d.ts +62 -0
- package/dist/api/base-handler.d.ts.map +1 -0
- package/dist/api/base-handler.js +55 -0
- package/dist/api/base-handler.js.map +1 -0
- package/dist/api/config.d.ts +5 -0
- package/dist/api/config.d.ts.map +1 -0
- package/dist/api/config.js +14 -0
- package/dist/api/config.js.map +1 -0
- package/dist/api/create-plan.d.ts +8 -0
- package/dist/api/create-plan.d.ts.map +1 -0
- package/dist/api/create-plan.js +77 -0
- package/dist/api/create-plan.js.map +1 -0
- package/dist/api/git-status.d.ts +6 -0
- package/dist/api/git-status.d.ts.map +1 -0
- package/dist/api/git-status.js +57 -0
- package/dist/api/git-status.js.map +1 -0
- package/dist/api/plans.d.ts +6 -0
- package/dist/api/plans.d.ts.map +1 -0
- package/dist/api/plans.js +75 -0
- package/dist/api/plans.js.map +1 -0
- package/dist/api/repo-dashboard.d.ts +13 -0
- package/dist/api/repo-dashboard.d.ts.map +1 -0
- package/dist/api/repo-dashboard.js +47 -0
- package/dist/api/repo-dashboard.js.map +1 -0
- package/dist/api/repo-issue.d.ts +12 -0
- package/dist/api/repo-issue.d.ts.map +1 -0
- package/dist/api/repo-issue.js +47 -0
- package/dist/api/repo-issue.js.map +1 -0
- package/dist/api/repos.d.ts +9 -0
- package/dist/api/repos.d.ts.map +1 -0
- package/dist/api/repos.js +46 -0
- package/dist/api/repos.js.map +1 -0
- package/dist/api/sessions.d.ts +5 -0
- package/dist/api/sessions.d.ts.map +1 -0
- package/dist/api/sessions.js +19 -0
- package/dist/api/sessions.js.map +1 -0
- package/dist/api/tasks.d.ts +6 -0
- package/dist/api/tasks.d.ts.map +1 -0
- package/dist/api/tasks.js +22 -0
- package/dist/api/tasks.js.map +1 -0
- package/dist/api/terminal.d.ts +7 -0
- package/dist/api/terminal.d.ts.map +1 -0
- package/dist/api/terminal.js +16 -0
- package/dist/api/terminal.js.map +1 -0
- package/dist/api/worktrees.d.ts +7 -0
- package/dist/api/worktrees.d.ts.map +1 -0
- package/dist/api/worktrees.js +26 -0
- package/dist/api/worktrees.js.map +1 -0
- package/dist/cli/arg-parser.d.ts +3 -0
- package/dist/cli/arg-parser.d.ts.map +1 -0
- package/dist/cli/arg-parser.js +243 -0
- package/dist/cli/arg-parser.js.map +1 -0
- package/dist/cli/config-resolver.d.ts +29 -0
- package/dist/cli/config-resolver.d.ts.map +1 -0
- package/dist/cli/config-resolver.js +139 -0
- package/dist/cli/config-resolver.js.map +1 -0
- package/dist/cli/config.d.ts +5 -0
- package/dist/cli/config.d.ts.map +1 -0
- package/dist/cli/config.js +224 -0
- package/dist/cli/config.js.map +1 -0
- package/dist/cli/constants.d.ts +7 -0
- package/dist/cli/constants.d.ts.map +1 -0
- package/dist/cli/constants.js +15 -0
- package/dist/cli/constants.js.map +1 -0
- package/dist/cli/help.d.ts +3 -0
- package/dist/cli/help.d.ts.map +1 -0
- package/dist/cli/help.js +35 -0
- package/dist/cli/help.js.map +1 -0
- package/dist/cli/index.d.ts +23 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +23 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/plans-command.d.ts +3 -0
- package/dist/cli/plans-command.d.ts.map +1 -0
- package/dist/cli/plans-command.js +151 -0
- package/dist/cli/plans-command.js.map +1 -0
- package/dist/cli/server-starter.d.ts +26 -0
- package/dist/cli/server-starter.d.ts.map +1 -0
- package/dist/cli/server-starter.js +72 -0
- package/dist/cli/server-starter.js.map +1 -0
- package/dist/cli/types.d.ts +46 -0
- package/dist/cli/types.d.ts.map +1 -0
- package/dist/cli/types.js +2 -0
- package/dist/cli/types.js.map +1 -0
- package/dist/cli/validation.d.ts +14 -0
- package/dist/cli/validation.d.ts.map +1 -0
- package/dist/cli/validation.js +99 -0
- package/dist/cli/validation.js.map +1 -0
- package/dist/cli.d.ts +5 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +73 -0
- package/dist/cli.js.map +1 -0
- package/dist/config/agent-commands.d.ts +27 -0
- package/dist/config/agent-commands.d.ts.map +1 -0
- package/dist/config/agent-commands.js +56 -0
- package/dist/config/agent-commands.js.map +1 -0
- package/dist/config/constants.d.ts +35 -0
- package/dist/config/constants.d.ts.map +1 -0
- package/dist/config/constants.js +35 -0
- package/dist/config/constants.js.map +1 -0
- package/dist/config/developer-messages.d.ts +2 -0
- package/dist/config/developer-messages.d.ts.map +1 -0
- package/dist/config/developer-messages.js +43 -0
- package/dist/config/developer-messages.js.map +1 -0
- package/dist/core/agents.d.ts +23 -0
- package/dist/core/agents.d.ts.map +1 -0
- package/dist/core/agents.js +91 -0
- package/dist/core/agents.js.map +1 -0
- package/dist/core/auth.d.ts +3 -0
- package/dist/core/auth.d.ts.map +1 -0
- package/dist/core/auth.js +69 -0
- package/dist/core/auth.js.map +1 -0
- package/dist/core/automation/branch.d.ts +18 -0
- package/dist/core/automation/branch.d.ts.map +1 -0
- package/dist/core/automation/branch.js +29 -0
- package/dist/core/automation/branch.js.map +1 -0
- package/dist/core/automation/git-orchestration.d.ts +51 -0
- package/dist/core/automation/git-orchestration.d.ts.map +1 -0
- package/dist/core/automation/git-orchestration.js +25 -0
- package/dist/core/automation/git-orchestration.js.map +1 -0
- package/dist/core/automation/plan.d.ts +15 -0
- package/dist/core/automation/plan.d.ts.map +1 -0
- package/dist/core/automation/plan.js +25 -0
- package/dist/core/automation/plan.js.map +1 -0
- package/dist/core/automation/request-validation.d.ts +45 -0
- package/dist/core/automation/request-validation.d.ts.map +1 -0
- package/dist/core/automation/request-validation.js +144 -0
- package/dist/core/automation/request-validation.js.map +1 -0
- package/dist/core/automation/task-runner.d.ts +42 -0
- package/dist/core/automation/task-runner.d.ts.map +1 -0
- package/dist/core/automation/task-runner.js +215 -0
- package/dist/core/automation/task-runner.js.map +1 -0
- package/dist/core/branch-name.d.ts +13 -0
- package/dist/core/branch-name.d.ts.map +1 -0
- package/dist/core/branch-name.js +429 -0
- package/dist/core/branch-name.js.map +1 -0
- package/dist/core/default-branch.d.ts +12 -0
- package/dist/core/default-branch.d.ts.map +1 -0
- package/dist/core/default-branch.js +78 -0
- package/dist/core/default-branch.js.map +1 -0
- package/dist/core/event-bus.d.ts +73 -0
- package/dist/core/event-bus.d.ts.map +1 -0
- package/dist/core/event-bus.js +127 -0
- package/dist/core/event-bus.js.map +1 -0
- package/dist/core/git.d.ts +13 -0
- package/dist/core/git.d.ts.map +1 -0
- package/dist/core/git.js +15 -0
- package/dist/core/git.js.map +1 -0
- package/dist/core/github.d.ts +10 -0
- package/dist/core/github.d.ts.map +1 -0
- package/dist/core/github.js +245 -0
- package/dist/core/github.js.map +1 -0
- package/dist/core/plan-storage.d.ts +46 -0
- package/dist/core/plan-storage.d.ts.map +1 -0
- package/dist/core/plan-storage.js +237 -0
- package/dist/core/plan-storage.js.map +1 -0
- package/dist/core/plan.d.ts +23 -0
- package/dist/core/plan.d.ts.map +1 -0
- package/dist/core/plan.js +445 -0
- package/dist/core/plan.js.map +1 -0
- package/dist/core/repositories.d.ts +2 -0
- package/dist/core/repositories.d.ts.map +1 -0
- package/dist/core/repositories.js +58 -0
- package/dist/core/repositories.js.map +1 -0
- package/dist/core/repository-config.d.ts +9 -0
- package/dist/core/repository-config.d.ts.map +1 -0
- package/dist/core/repository-config.js +65 -0
- package/dist/core/repository-config.js.map +1 -0
- package/dist/core/task-store.d.ts +14 -0
- package/dist/core/task-store.d.ts.map +1 -0
- package/dist/core/task-store.js +105 -0
- package/dist/core/task-store.js.map +1 -0
- package/dist/core/tasks.d.ts +62 -0
- package/dist/core/tasks.d.ts.map +1 -0
- package/dist/core/tasks.js +582 -0
- package/dist/core/tasks.js.map +1 -0
- package/dist/core/terminal-sessions.d.ts +18 -0
- package/dist/core/terminal-sessions.d.ts.map +1 -0
- package/dist/core/terminal-sessions.js +539 -0
- package/dist/core/terminal-sessions.js.map +1 -0
- package/dist/core/tmux.d.ts +29 -0
- package/dist/core/tmux.d.ts.map +1 -0
- package/dist/core/tmux.js +151 -0
- package/dist/core/tmux.js.map +1 -0
- package/dist/core/workdir.d.ts +8 -0
- package/dist/core/workdir.d.ts.map +1 -0
- package/dist/core/workdir.js +26 -0
- package/dist/core/workdir.js.map +1 -0
- package/dist/domain/branch-validator.d.ts +51 -0
- package/dist/domain/branch-validator.d.ts.map +1 -0
- package/dist/domain/branch-validator.js +88 -0
- package/dist/domain/branch-validator.js.map +1 -0
- package/dist/domain/git-url-parser.d.ts +27 -0
- package/dist/domain/git-url-parser.d.ts.map +1 -0
- package/dist/domain/git-url-parser.js +84 -0
- package/dist/domain/git-url-parser.js.map +1 -0
- package/dist/domain/index.d.ts +8 -0
- package/dist/domain/index.d.ts.map +1 -0
- package/dist/domain/index.js +5 -0
- package/dist/domain/index.js.map +1 -0
- package/dist/domain/repository.d.ts +55 -0
- package/dist/domain/repository.d.ts.map +1 -0
- package/dist/domain/repository.js +73 -0
- package/dist/domain/repository.js.map +1 -0
- package/dist/domain/worktree.d.ts +43 -0
- package/dist/domain/worktree.d.ts.map +1 -0
- package/dist/domain/worktree.js +57 -0
- package/dist/domain/worktree.js.map +1 -0
- package/dist/infrastructure/cookies/cookie-manager.d.ts +18 -0
- package/dist/infrastructure/cookies/cookie-manager.d.ts.map +1 -0
- package/dist/infrastructure/cookies/cookie-manager.js +20 -0
- package/dist/infrastructure/cookies/cookie-manager.js.map +1 -0
- package/dist/infrastructure/cookies/cookie-parser.d.ts +43 -0
- package/dist/infrastructure/cookies/cookie-parser.d.ts.map +1 -0
- package/dist/infrastructure/cookies/cookie-parser.js +88 -0
- package/dist/infrastructure/cookies/cookie-parser.js.map +1 -0
- package/dist/infrastructure/cookies/cookie-security.d.ts +15 -0
- package/dist/infrastructure/cookies/cookie-security.d.ts.map +1 -0
- package/dist/infrastructure/cookies/cookie-security.js +35 -0
- package/dist/infrastructure/cookies/cookie-security.js.map +1 -0
- package/dist/infrastructure/cookies/index.d.ts +7 -0
- package/dist/infrastructure/cookies/index.d.ts.map +1 -0
- package/dist/infrastructure/cookies/index.js +4 -0
- package/dist/infrastructure/cookies/index.js.map +1 -0
- package/dist/infrastructure/errors/error-handler.d.ts +22 -0
- package/dist/infrastructure/errors/error-handler.d.ts.map +1 -0
- package/dist/infrastructure/errors/error-handler.js +89 -0
- package/dist/infrastructure/errors/error-handler.js.map +1 -0
- package/dist/infrastructure/errors/http-error.d.ts +30 -0
- package/dist/infrastructure/errors/http-error.d.ts.map +1 -0
- package/dist/infrastructure/errors/http-error.js +46 -0
- package/dist/infrastructure/errors/http-error.js.map +1 -0
- package/dist/infrastructure/errors/index.d.ts +5 -0
- package/dist/infrastructure/errors/index.d.ts.map +1 -0
- package/dist/infrastructure/errors/index.js +5 -0
- package/dist/infrastructure/errors/index.js.map +1 -0
- package/dist/infrastructure/errors/not-found-error.d.ts +8 -0
- package/dist/infrastructure/errors/not-found-error.d.ts.map +1 -0
- package/dist/infrastructure/errors/not-found-error.js +13 -0
- package/dist/infrastructure/errors/not-found-error.js.map +1 -0
- package/dist/infrastructure/errors/validation-error.d.ts +21 -0
- package/dist/infrastructure/errors/validation-error.d.ts.map +1 -0
- package/dist/infrastructure/errors/validation-error.js +31 -0
- package/dist/infrastructure/errors/validation-error.js.map +1 -0
- package/dist/infrastructure/logging/index.d.ts +3 -0
- package/dist/infrastructure/logging/index.d.ts.map +1 -0
- package/dist/infrastructure/logging/index.js +2 -0
- package/dist/infrastructure/logging/index.js.map +1 -0
- package/dist/infrastructure/logging/logger.d.ts +21 -0
- package/dist/infrastructure/logging/logger.d.ts.map +1 -0
- package/dist/infrastructure/logging/logger.js +49 -0
- package/dist/infrastructure/logging/logger.js.map +1 -0
- package/dist/repositories/git-repository.d.ts +67 -0
- package/dist/repositories/git-repository.d.ts.map +1 -0
- package/dist/repositories/git-repository.js +111 -0
- package/dist/repositories/git-repository.js.map +1 -0
- package/dist/repositories/git-status-repository.d.ts +22 -0
- package/dist/repositories/git-status-repository.d.ts.map +1 -0
- package/dist/repositories/git-status-repository.js +620 -0
- package/dist/repositories/git-status-repository.js.map +1 -0
- package/dist/repositories/repository-repository.d.ts +44 -0
- package/dist/repositories/repository-repository.d.ts.map +1 -0
- package/dist/repositories/repository-repository.js +155 -0
- package/dist/repositories/repository-repository.js.map +1 -0
- package/dist/repositories/worktree-repository.d.ts +66 -0
- package/dist/repositories/worktree-repository.d.ts.map +1 -0
- package/dist/repositories/worktree-repository.js +330 -0
- package/dist/repositories/worktree-repository.js.map +1 -0
- package/dist/server/cookies.d.ts +6 -0
- package/dist/server/cookies.d.ts.map +1 -0
- package/dist/server/cookies.js +6 -0
- package/dist/server/cookies.js.map +1 -0
- package/dist/server/events.d.ts +8 -0
- package/dist/server/events.d.ts.map +1 -0
- package/dist/server/events.js +128 -0
- package/dist/server/events.js.map +1 -0
- package/dist/server/index.d.ts +18 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +173 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/router.d.ts +16 -0
- package/dist/server/router.d.ts.map +1 -0
- package/dist/server/router.js +256 -0
- package/dist/server/router.js.map +1 -0
- package/dist/server/ui.d.ts +8 -0
- package/dist/server/ui.d.ts.map +1 -0
- package/dist/server/ui.js +211 -0
- package/dist/server/ui.js.map +1 -0
- package/dist/server/websocket.d.ts +9 -0
- package/dist/server/websocket.d.ts.map +1 -0
- package/dist/server/websocket.js +116 -0
- package/dist/server/websocket.js.map +1 -0
- package/dist/services/auth-service.d.ts +49 -0
- package/dist/services/auth-service.d.ts.map +1 -0
- package/dist/services/auth-service.js +53 -0
- package/dist/services/auth-service.js.map +1 -0
- package/dist/services/index.d.ts +11 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +6 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/repository-service.d.ts +57 -0
- package/dist/services/repository-service.d.ts.map +1 -0
- package/dist/services/repository-service.js +62 -0
- package/dist/services/repository-service.js.map +1 -0
- package/dist/services/session-service.d.ts +31 -0
- package/dist/services/session-service.d.ts.map +1 -0
- package/dist/services/session-service.js +134 -0
- package/dist/services/session-service.js.map +1 -0
- package/dist/services/terminal-service.d.ts +43 -0
- package/dist/services/terminal-service.d.ts.map +1 -0
- package/dist/services/terminal-service.js +85 -0
- package/dist/services/terminal-service.js.map +1 -0
- package/dist/services/worktree-service.d.ts +39 -0
- package/dist/services/worktree-service.d.ts.map +1 -0
- package/dist/services/worktree-service.js +208 -0
- package/dist/services/worktree-service.js.map +1 -0
- package/dist/types/auth.d.ts +35 -0
- package/dist/types/auth.d.ts.map +1 -0
- package/dist/types/auth.js +2 -0
- package/dist/types/auth.js.map +1 -0
- package/dist/types/config.d.ts +46 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types/config.js +5 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/git.d.ts +190 -0
- package/dist/types/git.d.ts.map +1 -0
- package/dist/types/git.js +5 -0
- package/dist/types/git.js.map +1 -0
- package/dist/types/http.d.ts +46 -0
- package/dist/types/http.d.ts.map +1 -0
- package/dist/types/http.js +2 -0
- package/dist/types/http.js.map +1 -0
- package/dist/types/index.d.ts +8 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/plan.d.ts +31 -0
- package/dist/types/plan.d.ts.map +1 -0
- package/dist/types/plan.js +5 -0
- package/dist/types/plan.js.map +1 -0
- package/dist/types/services.d.ts +99 -0
- package/dist/types/services.d.ts.map +1 -0
- package/dist/types/services.js +2 -0
- package/dist/types/services.js.map +1 -0
- package/dist/types/tasks.d.ts +68 -0
- package/dist/types/tasks.d.ts.map +1 -0
- package/dist/types/tasks.js +5 -0
- package/dist/types/tasks.js.map +1 -0
- package/dist/types/terminal.d.ts +60 -0
- package/dist/types/terminal.d.ts.map +1 -0
- package/dist/types/terminal.js +2 -0
- package/dist/types/terminal.js.map +1 -0
- package/dist/utils/cookies.d.ts +7 -0
- package/dist/utils/cookies.d.ts.map +1 -0
- package/dist/utils/cookies.js +6 -0
- package/dist/utils/cookies.js.map +1 -0
- package/dist/utils/http.d.ts +23 -0
- package/dist/utils/http.d.ts.map +1 -0
- package/dist/utils/http.js +58 -0
- package/dist/utils/http.js.map +1 -0
- package/dist/utils/random.d.ts +12 -0
- package/dist/utils/random.d.ts.map +1 -0
- package/dist/utils/random.js +25 -0
- package/dist/utils/random.js.map +1 -0
- package/dist/utils/repository-cache.d.ts +8 -0
- package/dist/utils/repository-cache.d.ts.map +1 -0
- package/dist/utils/repository-cache.js +13 -0
- package/dist/utils/repository-cache.js.map +1 -0
- package/dist/validation/index.d.ts +9 -0
- package/dist/validation/index.d.ts.map +1 -0
- package/dist/validation/index.js +6 -0
- package/dist/validation/index.js.map +1 -0
- package/dist/validation/request-validator.d.ts +99 -0
- package/dist/validation/request-validator.d.ts.map +1 -0
- package/dist/validation/request-validator.js +189 -0
- package/dist/validation/request-validator.js.map +1 -0
- package/dist/validation/schemas/repository-schema.d.ts +26 -0
- package/dist/validation/schemas/repository-schema.d.ts.map +1 -0
- package/dist/validation/schemas/repository-schema.js +31 -0
- package/dist/validation/schemas/repository-schema.js.map +1 -0
- package/dist/validation/schemas/terminal-schema.d.ts +21 -0
- package/dist/validation/schemas/terminal-schema.d.ts.map +1 -0
- package/dist/validation/schemas/terminal-schema.js +38 -0
- package/dist/validation/schemas/terminal-schema.js.map +1 -0
- package/dist/validation/schemas/worktree-schema.d.ts +21 -0
- package/dist/validation/schemas/worktree-schema.d.ts.map +1 -0
- package/dist/validation/schemas/worktree-schema.js +29 -0
- package/dist/validation/schemas/worktree-schema.js.map +1 -0
- package/package.json +79 -0
- package/ui/dist/assets/index-BDDrbP3l.js +354 -0
- package/ui/dist/assets/index-CwB7gOl4.css +41 -0
- package/ui/dist/index.html +13 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base-handler.js","sourceRoot":"","sources":["../../src/api/base-handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AA8CjE;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,aAAa,CAC3B,OAAwC;IAExC,MAAM,EACJ,OAAO,EACP,SAAS,EACT,WAAW,GAAG,GAAG,EACjB,QAAQ,GAAG,OAAO,CAAC,SAAS,CAAC,EAC7B,mBAAmB,GACpB,GAAG,OAAO,CAAC;IAEZ,OAAO,YAAY,CAAC,KAAK,EAAE,OAAuB,EAAE,EAAE;QACpD,IAAI,KAAa,CAAC;QAElB,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,YAAY,EAAE,CAAC;YAC7C,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAE,OAAkB,CAAC;QAC/D,CAAC;aAAM,CAAC;YACN,KAAK,GAAG,SAAmB,CAAC;QAC9B,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QAE7C,MAAM,QAAQ,GAAG,mBAAmB;YAClC,CAAC,CAAC,mBAAmB,CAAC,MAAM,CAAC;YAC7B,CAAC,CAAC,MAAM,CAAC;QAEX,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,mBAAmB,CACjC,OAAsD,EACtD,UAAwF,EAAE;IAE1F,OAAO,aAAa,CAAC;QACnB,OAAO,EAAE,KAAK,EAAE,MAAY,EAAE,OAAuB,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;QAC1E,QAAQ,EAAE,KAAK;QACf,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,kBAAkB,CAChC,OAAsD,EACtD,UAAwF,EAAE;IAE1F,OAAO,YAAY,CAAC,KAAK,EAAE,OAAuB,EAAE,EAAE;QACpD,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,CAAC;QACtC,MAAM,QAAQ,GAAG,OAAO,CAAC,mBAAmB;YAC1C,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC,MAAM,CAAC;YACrC,CAAC,CAAC,MAAM,CAAC;QACX,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,WAAW,IAAI,GAAG,EAAE,QAAQ,CAAC,CAAC;IAC9D,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { AgentCommands } from '../config/agent-commands.js';
|
|
2
|
+
export declare function createConfigHandlers(agentCommands: AgentCommands): {
|
|
3
|
+
commands: (context: import("../types/http.js").RequestContext) => Promise<void>;
|
|
4
|
+
};
|
|
5
|
+
//# sourceMappingURL=config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/api/config.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAEjE,wBAAgB,oBAAoB,CAAC,aAAa,EAAE,aAAa;;EAehE"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { createSimpleHandler } from './base-handler.js';
|
|
2
|
+
export function createConfigHandlers(agentCommands) {
|
|
3
|
+
const resolved = {
|
|
4
|
+
codex: agentCommands?.codex || '',
|
|
5
|
+
codexDangerous: agentCommands?.codexDangerous || '',
|
|
6
|
+
claude: agentCommands?.claude || '',
|
|
7
|
+
claudeDangerous: agentCommands?.claudeDangerous || '',
|
|
8
|
+
cursor: agentCommands?.cursor || '',
|
|
9
|
+
vscode: agentCommands?.vscode || '',
|
|
10
|
+
};
|
|
11
|
+
const commands = createSimpleHandler(async () => ({ commands: resolved }));
|
|
12
|
+
return { commands };
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/api/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAGxD,MAAM,UAAU,oBAAoB,CAAC,aAA4B;IAC/D,MAAM,QAAQ,GAAG;QACf,KAAK,EAAE,aAAa,EAAE,KAAK,IAAI,EAAE;QACjC,cAAc,EAAE,aAAa,EAAE,cAAc,IAAI,EAAE;QACnD,MAAM,EAAE,aAAa,EAAE,MAAM,IAAI,EAAE;QACnC,eAAe,EAAE,aAAa,EAAE,eAAe,IAAI,EAAE;QACrD,MAAM,EAAE,aAAa,EAAE,MAAM,IAAI,EAAE;QACnC,MAAM,EAAE,aAAa,EAAE,MAAM,IAAI,EAAE;KACpC,CAAC;IAEF,MAAM,QAAQ,GAAG,mBAAmB,CAClC,KAAK,IAAI,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CACrC,CAAC;IAEF,OAAO,EAAE,QAAQ,EAAE,CAAC;AACtB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { RequestContext } from '../types/http.js';
|
|
2
|
+
import type { PlanService } from '../types/plan.js';
|
|
3
|
+
export declare function createPlanHandlers({ planService: providedPlanService }?: {
|
|
4
|
+
planService?: PlanService;
|
|
5
|
+
}): {
|
|
6
|
+
create: (context: RequestContext) => Promise<void>;
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=create-plan.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-plan.d.ts","sourceRoot":"","sources":["../../src/api/create-plan.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAEpD,wBAAgB,kBAAkB,CAAC,EAAE,WAAW,EAAE,mBAAmB,EAAE,GAAE;IAAE,WAAW,CAAC,EAAE,WAAW,CAAA;CAAO;sBAG1E,cAAc,KAAG,OAAO,CAAC,IAAI,CAAC;EA8E9D"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { sendJson } from '../utils/http.js';
|
|
2
|
+
import { ensureRepository } from '../core/git.js';
|
|
3
|
+
export function createPlanHandlers({ planService: providedPlanService } = {}) {
|
|
4
|
+
const planService = providedPlanService;
|
|
5
|
+
async function create(context) {
|
|
6
|
+
let payload;
|
|
7
|
+
try {
|
|
8
|
+
payload = await context.readJsonBody();
|
|
9
|
+
}
|
|
10
|
+
catch (error) {
|
|
11
|
+
const err = error;
|
|
12
|
+
sendJson(context.res, 400, { error: err.message });
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
const prompt = typeof payload['prompt'] === 'string' ? payload['prompt'] : '';
|
|
16
|
+
if (!prompt.trim()) {
|
|
17
|
+
sendJson(context.res, 400, { error: 'prompt is required' });
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
const rawPrompt = payload && typeof payload['rawPrompt'] === 'boolean' ? payload['rawPrompt'] : false;
|
|
21
|
+
const dangerousMode = payload && typeof payload['dangerousMode'] === 'boolean' ? payload['dangerousMode'] : false;
|
|
22
|
+
if (!planService || !planService.isConfigured) {
|
|
23
|
+
sendJson(context.res, 500, {
|
|
24
|
+
error: 'Plan generation is not configured. Configure a local LLM command (set planLlm in config.json).',
|
|
25
|
+
});
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
const org = typeof payload['org'] === 'string' ? payload['org'].trim() : '';
|
|
29
|
+
const repo = typeof payload['repo'] === 'string' ? payload['repo'].trim() : '';
|
|
30
|
+
let commandCwd = '';
|
|
31
|
+
if ((org && !repo) || (!org && repo)) {
|
|
32
|
+
sendJson(context.res, 400, {
|
|
33
|
+
error: 'Both org and repo must be provided when specifying repository context.',
|
|
34
|
+
});
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
if (org && repo) {
|
|
38
|
+
const workdir = typeof context.workdir === 'string' ? context.workdir : '';
|
|
39
|
+
if (!workdir) {
|
|
40
|
+
sendJson(context.res, 500, {
|
|
41
|
+
error: 'Server workdir is not configured.',
|
|
42
|
+
});
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
try {
|
|
46
|
+
const { repositoryPath } = await ensureRepository(workdir, org, repo);
|
|
47
|
+
commandCwd = repositoryPath;
|
|
48
|
+
}
|
|
49
|
+
catch (error) {
|
|
50
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
51
|
+
sendJson(context.res, 404, { error: message });
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
let planText;
|
|
56
|
+
try {
|
|
57
|
+
const options = commandCwd
|
|
58
|
+
? { prompt, cwd: commandCwd, rawPrompt, dangerousMode }
|
|
59
|
+
: { prompt, rawPrompt, dangerousMode };
|
|
60
|
+
planText = await planService.createPlanText(options);
|
|
61
|
+
}
|
|
62
|
+
catch (error) {
|
|
63
|
+
if (error instanceof Error && error.message === 'prompt is required') {
|
|
64
|
+
sendJson(context.res, 400, { error: error.message });
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
68
|
+
sendJson(context.res, 502, {
|
|
69
|
+
error: message,
|
|
70
|
+
});
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
sendJson(context.res, 200, { plan: planText });
|
|
74
|
+
}
|
|
75
|
+
return { create };
|
|
76
|
+
}
|
|
77
|
+
//# sourceMappingURL=create-plan.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-plan.js","sourceRoot":"","sources":["../../src/api/create-plan.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { RequestContext } from '../types/http.js';
|
|
2
|
+
export declare function createGitStatusHandlers(workdir: string): {
|
|
3
|
+
read: (context: RequestContext) => Promise<void>;
|
|
4
|
+
diff: (context: RequestContext) => Promise<void>;
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=git-status.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"git-status.d.ts","sourceRoot":"","sources":["../../src/api/git-status.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAiBvD,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,MAAM;;;EA+CtD"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { getWorktreeStatus, getWorktreeFileDiff } from '../core/git.js';
|
|
2
|
+
import { createQueryHandler } from './base-handler.js';
|
|
3
|
+
import { extractWorktreeParams } from '../validation/index.js';
|
|
4
|
+
import { ValidationError } from '../infrastructure/errors/index.js';
|
|
5
|
+
function parseOptionalInteger(value, fallback) {
|
|
6
|
+
if (typeof value !== 'string') {
|
|
7
|
+
return fallback;
|
|
8
|
+
}
|
|
9
|
+
const trimmed = value.trim();
|
|
10
|
+
if (!trimmed) {
|
|
11
|
+
return fallback;
|
|
12
|
+
}
|
|
13
|
+
const parsed = Number.parseInt(trimmed, 10);
|
|
14
|
+
if (!Number.isFinite(parsed) || parsed < 0) {
|
|
15
|
+
return fallback;
|
|
16
|
+
}
|
|
17
|
+
return parsed;
|
|
18
|
+
}
|
|
19
|
+
export function createGitStatusHandlers(workdir) {
|
|
20
|
+
if (!workdir) {
|
|
21
|
+
throw new Error('workdir is required');
|
|
22
|
+
}
|
|
23
|
+
const read = createQueryHandler(async (context) => {
|
|
24
|
+
const { org, repo, branch } = extractWorktreeParams(context.url.searchParams);
|
|
25
|
+
const entryLimit = parseOptionalInteger(context.url.searchParams.get('entryLimit'), undefined);
|
|
26
|
+
const commitLimit = parseOptionalInteger(context.url.searchParams.get('commitLimit'), undefined);
|
|
27
|
+
const status = await getWorktreeStatus(workdir, org, repo, branch, {
|
|
28
|
+
entryLimit,
|
|
29
|
+
commitLimit,
|
|
30
|
+
});
|
|
31
|
+
context.res.setHeader('Cache-Control', 'no-store');
|
|
32
|
+
return { status };
|
|
33
|
+
});
|
|
34
|
+
const diff = createQueryHandler(async (context) => {
|
|
35
|
+
const payload = await context.readJsonBody();
|
|
36
|
+
const { org, repo, branch } = extractWorktreeParams(new URLSearchParams({
|
|
37
|
+
org: typeof payload['org'] === 'string' ? payload['org'] : '',
|
|
38
|
+
repo: typeof payload['repo'] === 'string' ? payload['repo'] : '',
|
|
39
|
+
branch: typeof payload['branch'] === 'string' ? payload['branch'] : '',
|
|
40
|
+
}));
|
|
41
|
+
const filePath = typeof payload['path'] === 'string' ? payload['path'] : '';
|
|
42
|
+
if (!filePath) {
|
|
43
|
+
throw new ValidationError('path is required');
|
|
44
|
+
}
|
|
45
|
+
const previousPath = typeof payload['previousPath'] === 'string' ? payload['previousPath'] : undefined;
|
|
46
|
+
const mode = typeof payload['mode'] === 'string' ? payload['mode'] : undefined;
|
|
47
|
+
const status = typeof payload['status'] === 'string' ? payload['status'] : undefined;
|
|
48
|
+
return await getWorktreeFileDiff(workdir, org, repo, branch, {
|
|
49
|
+
path: filePath,
|
|
50
|
+
previousPath,
|
|
51
|
+
mode,
|
|
52
|
+
status,
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
return { read, diff };
|
|
56
|
+
}
|
|
57
|
+
//# sourceMappingURL=git-status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"git-status.js","sourceRoot":"","sources":["../../src/api/git-status.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACxE,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAGpE,SAAS,oBAAoB,CAAC,KAAoB,EAAE,QAA4B;IAC9E,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,OAAO,QAAQ,CAAC;IAClB,CAAC;IACD,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC;IAC7B,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,QAAQ,CAAC;IAClB,CAAC;IACD,MAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IAC5C,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3C,OAAO,QAAQ,CAAC;IAClB,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,UAAU,uBAAuB,CAAC,OAAe;IACrD,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;IACzC,CAAC;IAED,MAAM,IAAI,GAAG,kBAAkB,CAAC,KAAK,EAAE,OAAuB,EAAE,EAAE;QAChE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,qBAAqB,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAC9E,MAAM,UAAU,GAAG,oBAAoB,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,SAAS,CAAC,CAAC;QAC/F,MAAM,WAAW,GAAG,oBAAoB,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,SAAS,CAAC,CAAC;QAEjG,MAAM,MAAM,GAAG,MAAM,iBAAiB,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE;YACjE,UAAU;YACV,WAAW;SACZ,CAAC,CAAC;QAEH,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;QACnD,OAAO,EAAE,MAAM,EAAE,CAAC;IACpB,CAAC,CAAC,CAAC;IAEH,MAAM,IAAI,GAAG,kBAAkB,CAAC,KAAK,EAAE,OAAuB,EAAE,EAAE;QAChE,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,YAAY,EAAE,CAAC;QAC7C,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,qBAAqB,CACjD,IAAI,eAAe,CAAC;YAClB,GAAG,EAAE,OAAO,OAAO,CAAC,KAAK,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;YAC7D,IAAI,EAAE,OAAO,OAAO,CAAC,MAAM,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE;YAChE,MAAM,EAAE,OAAO,OAAO,CAAC,QAAQ,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE;SACvE,CAAC,CACH,CAAC;QAEF,MAAM,QAAQ,GAAG,OAAO,OAAO,CAAC,MAAM,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5E,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,IAAI,eAAe,CAAC,kBAAkB,CAAC,CAAC;QAChD,CAAC;QAED,MAAM,YAAY,GAAG,OAAO,OAAO,CAAC,cAAc,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QACvG,MAAM,IAAI,GAAG,OAAO,OAAO,CAAC,MAAM,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAC/E,MAAM,MAAM,GAAG,OAAO,OAAO,CAAC,QAAQ,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAErF,OAAO,MAAM,mBAAmB,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE;YAC3D,IAAI,EAAE,QAAQ;YACd,YAAY;YACZ,IAAI;YACJ,MAAM;SACP,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;AACxB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { RequestContext } from '../types/http.js';
|
|
2
|
+
export declare function createPlanArtifactHandlers(workdir: string): {
|
|
3
|
+
list: (context: RequestContext) => Promise<void>;
|
|
4
|
+
read: (context: RequestContext) => Promise<void>;
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=plans.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"plans.d.ts","sourceRoot":"","sources":["../../src/api/plans.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAqCvD,wBAAgB,0BAA0B,CAAC,OAAO,EAAE,MAAM;oBAC3B,cAAc,KAAG,OAAO,CAAC,IAAI,CAAC;oBAmB9B,cAAc,KAAG,OAAO,CAAC,IAAI,CAAC;EA0B5D"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { getWorktreePath } from '../core/git.js';
|
|
2
|
+
import { listPlansForWorktree, readPlanFromWorktree } from '../core/plan-storage.js';
|
|
3
|
+
import { sendJson } from '../utils/http.js';
|
|
4
|
+
import { extractWorktreeParams } from '../validation/index.js';
|
|
5
|
+
import { ValidationError, extractErrorMessage } from '../infrastructure/errors/index.js';
|
|
6
|
+
function parseCommonParams(context) {
|
|
7
|
+
try {
|
|
8
|
+
const { org, repo, branch } = extractWorktreeParams(context.url.searchParams);
|
|
9
|
+
const limitParam = context.url.searchParams.get('limit');
|
|
10
|
+
const limit = limitParam ? Number.parseInt(limitParam, 10) : undefined;
|
|
11
|
+
if (limitParam && (Number.isNaN(limit) || (limit && limit < 1))) {
|
|
12
|
+
sendJson(context.res, 400, { error: 'limit must be a positive integer' });
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
return { org, repo, branch, limit };
|
|
16
|
+
}
|
|
17
|
+
catch (error) {
|
|
18
|
+
const message = error instanceof ValidationError ? error.message : extractErrorMessage(error, 'Invalid parameters');
|
|
19
|
+
sendJson(context.res, 400, { error: message });
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
function handleResolutionError(res, error) {
|
|
24
|
+
const message = extractErrorMessage(error, 'Unknown error');
|
|
25
|
+
if (/not found/i.test(message)) {
|
|
26
|
+
sendJson(res, 404, { error: message });
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
sendJson(res, 500, { error: message });
|
|
30
|
+
}
|
|
31
|
+
export function createPlanArtifactHandlers(workdir) {
|
|
32
|
+
async function list(context) {
|
|
33
|
+
const parsed = parseCommonParams(context);
|
|
34
|
+
if (!parsed) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
try {
|
|
38
|
+
const { worktreePath } = await getWorktreePath(workdir, parsed.org, parsed.repo, parsed.branch);
|
|
39
|
+
const plans = await listPlansForWorktree({
|
|
40
|
+
worktreePath,
|
|
41
|
+
branch: parsed.branch,
|
|
42
|
+
limit: parsed.limit,
|
|
43
|
+
});
|
|
44
|
+
sendJson(context.res, 200, { data: plans });
|
|
45
|
+
}
|
|
46
|
+
catch (error) {
|
|
47
|
+
handleResolutionError(context.res, error);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
async function read(context) {
|
|
51
|
+
const parsed = parseCommonParams(context);
|
|
52
|
+
if (!parsed) {
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
const planId = (context.url.searchParams.get('planId') || '').trim();
|
|
56
|
+
if (!planId) {
|
|
57
|
+
sendJson(context.res, 400, { error: 'planId is required' });
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
try {
|
|
61
|
+
const { worktreePath } = await getWorktreePath(workdir, parsed.org, parsed.repo, parsed.branch);
|
|
62
|
+
const plan = await readPlanFromWorktree({
|
|
63
|
+
worktreePath,
|
|
64
|
+
branch: parsed.branch,
|
|
65
|
+
id: planId,
|
|
66
|
+
});
|
|
67
|
+
sendJson(context.res, 200, { data: plan });
|
|
68
|
+
}
|
|
69
|
+
catch (error) {
|
|
70
|
+
handleResolutionError(context.res, error);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
return { list, read };
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=plans.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"plans.js","sourceRoot":"","sources":["../../src/api/plans.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ensureRepository, countLocalWorktrees } from '../core/git.js';
|
|
2
|
+
import { createGithubClient } from '../core/github.js';
|
|
3
|
+
import type { RequestContext } from '../types/http.js';
|
|
4
|
+
export interface RepoDashboardOverrides {
|
|
5
|
+
githubClient?: ReturnType<typeof createGithubClient>;
|
|
6
|
+
ensureRepo?: typeof ensureRepository;
|
|
7
|
+
worktreeCounter?: typeof countLocalWorktrees;
|
|
8
|
+
now?: () => Date;
|
|
9
|
+
}
|
|
10
|
+
export declare function createRepoDashboardHandlers(workdir: string, overrides?: RepoDashboardOverrides): {
|
|
11
|
+
read: (context: RequestContext) => Promise<void>;
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=repo-dashboard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repo-dashboard.d.ts","sourceRoot":"","sources":["../../src/api/repo-dashboard.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAKvD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAEvD,MAAM,WAAW,sBAAsB;IACrC,YAAY,CAAC,EAAE,UAAU,CAAC,OAAO,kBAAkB,CAAC,CAAC;IACrD,UAAU,CAAC,EAAE,OAAO,gBAAgB,CAAC;IACrC,eAAe,CAAC,EAAE,OAAO,mBAAmB,CAAC;IAC7C,GAAG,CAAC,EAAE,MAAM,IAAI,CAAC;CAClB;AAED,wBAAgB,2BAA2B,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,GAAE,sBAA2B;;EAkDlG"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { ensureRepository, countLocalWorktrees } from '../core/git.js';
|
|
2
|
+
import { createGithubClient } from '../core/github.js';
|
|
3
|
+
import { sendJson, handleHeadRequest } from '../utils/http.js';
|
|
4
|
+
import { extractRepositoryParams } from '../validation/index.js';
|
|
5
|
+
import { createQueryHandler } from './base-handler.js';
|
|
6
|
+
import { extractErrorMessage } from '../infrastructure/errors/error-handler.js';
|
|
7
|
+
export function createRepoDashboardHandlers(workdir, overrides = {}) {
|
|
8
|
+
const { githubClient = createGithubClient(), ensureRepo = ensureRepository, worktreeCounter = countLocalWorktrees, now = () => new Date(), } = overrides;
|
|
9
|
+
const read = createQueryHandler(async (context) => {
|
|
10
|
+
const { org, repo } = extractRepositoryParams(context.url.searchParams);
|
|
11
|
+
let repositoryPath;
|
|
12
|
+
try {
|
|
13
|
+
({ repositoryPath } = await ensureRepo(workdir, org, repo));
|
|
14
|
+
}
|
|
15
|
+
catch (error) {
|
|
16
|
+
const message = extractErrorMessage(error, 'Repository not found');
|
|
17
|
+
const statusCode = message.includes('not found') ? 404 : 500;
|
|
18
|
+
sendJson(context.res, statusCode, { error: message });
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
if (context.method === 'HEAD') {
|
|
22
|
+
handleHeadRequest(context.res);
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const [openPullRequests, openIssues, openIssueDetails, runningWorkflows] = await Promise.all([
|
|
26
|
+
githubClient.countOpenPullRequests(org, repo),
|
|
27
|
+
githubClient.countOpenIssues(org, repo),
|
|
28
|
+
githubClient.listOpenIssues(org, repo),
|
|
29
|
+
githubClient.countRunningWorkflows(org, repo),
|
|
30
|
+
]);
|
|
31
|
+
const worktreeCount = await worktreeCounter(repositoryPath, { includeMain: false });
|
|
32
|
+
const fetchedAt = now().toISOString();
|
|
33
|
+
return {
|
|
34
|
+
data: {
|
|
35
|
+
org,
|
|
36
|
+
repo,
|
|
37
|
+
fetchedAt,
|
|
38
|
+
pullRequests: { open: openPullRequests },
|
|
39
|
+
issues: { open: openIssues, items: openIssueDetails },
|
|
40
|
+
workflows: { running: runningWorkflows },
|
|
41
|
+
worktrees: { local: worktreeCount },
|
|
42
|
+
},
|
|
43
|
+
};
|
|
44
|
+
});
|
|
45
|
+
return { read };
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=repo-dashboard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repo-dashboard.js","sourceRoot":"","sources":["../../src/api/repo-dashboard.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAC/D,OAAO,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAC;AACjE,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,EAAE,mBAAmB,EAAE,MAAM,2CAA2C,CAAC;AAUhF,MAAM,UAAU,2BAA2B,CAAC,OAAe,EAAE,YAAoC,EAAE;IACjG,MAAM,EACJ,YAAY,GAAG,kBAAkB,EAAE,EACnC,UAAU,GAAG,gBAAgB,EAC7B,eAAe,GAAG,mBAAmB,EACrC,GAAG,GAAG,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE,GACvB,GAAG,SAAS,CAAC;IAEd,MAAM,IAAI,GAAG,kBAAkB,CAAC,KAAK,EAAE,OAAuB,EAAE,EAAE;QAChE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,uBAAuB,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAExE,IAAI,cAAc,CAAC;QACnB,IAAI,CAAC;YACH,CAAC,EAAE,cAAc,EAAE,GAAG,MAAM,UAAU,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;QAC9D,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,MAAM,OAAO,GAAG,mBAAmB,CAAC,KAAK,EAAE,sBAAsB,CAAC,CAAC;YACnE,MAAM,UAAU,GAAG,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;YAC7D,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,UAAU,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;YACtD,OAAO;QACT,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,KAAK,MAAM,EAAE,CAAC;YAC9B,iBAAiB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAC/B,OAAO;QACT,CAAC;QAED,MAAM,CAAC,gBAAgB,EAAE,UAAU,EAAE,gBAAgB,EAAE,gBAAgB,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YAC3F,YAAY,CAAC,qBAAqB,CAAC,GAAG,EAAE,IAAI,CAAC;YAC7C,YAAY,CAAC,eAAe,CAAC,GAAG,EAAE,IAAI,CAAC;YACvC,YAAY,CAAC,cAAc,CAAC,GAAG,EAAE,IAAI,CAAC;YACtC,YAAY,CAAC,qBAAqB,CAAC,GAAG,EAAE,IAAI,CAAC;SAC9C,CAAC,CAAC;QAEH,MAAM,aAAa,GAAG,MAAM,eAAe,CAAC,cAAc,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC;QACpF,MAAM,SAAS,GAAG,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC;QAEtC,OAAO;YACL,IAAI,EAAE;gBACJ,GAAG;gBACH,IAAI;gBACJ,SAAS;gBACT,YAAY,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE;gBACxC,MAAM,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,gBAAgB,EAAE;gBACrD,SAAS,EAAE,EAAE,OAAO,EAAE,gBAAgB,EAAE;gBACxC,SAAS,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE;aACpC;SACF,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,OAAO,EAAE,IAAI,EAAE,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { ensureRepository } from '../core/git.js';
|
|
2
|
+
import { createGithubClient } from '../core/github.js';
|
|
3
|
+
import type { RequestContext } from '../types/http.js';
|
|
4
|
+
export interface RepoIssueOverrides {
|
|
5
|
+
githubClient?: ReturnType<typeof createGithubClient>;
|
|
6
|
+
ensureRepo?: typeof ensureRepository;
|
|
7
|
+
now?: () => Date;
|
|
8
|
+
}
|
|
9
|
+
export declare function createRepoIssueHandlers(workdir: string, overrides?: RepoIssueOverrides): {
|
|
10
|
+
read: (context: RequestContext) => Promise<void>;
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=repo-issue.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repo-issue.d.ts","sourceRoot":"","sources":["../../src/api/repo-issue.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAKvD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAEvD,MAAM,WAAW,kBAAkB;IACjC,YAAY,CAAC,EAAE,UAAU,CAAC,OAAO,kBAAkB,CAAC,CAAC;IACrD,UAAU,CAAC,EAAE,OAAO,gBAAgB,CAAC;IACrC,GAAG,CAAC,EAAE,MAAM,IAAI,CAAC;CAClB;AAED,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,GAAE,kBAAuB;;EAkD1F"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { ensureRepository } from '../core/git.js';
|
|
2
|
+
import { createGithubClient } from '../core/github.js';
|
|
3
|
+
import { sendJson, handleHeadRequest } from '../utils/http.js';
|
|
4
|
+
import { extractRepositoryParams } from '../validation/index.js';
|
|
5
|
+
import { extractErrorMessage } from '../infrastructure/errors/index.js';
|
|
6
|
+
import { createQueryHandler } from './base-handler.js';
|
|
7
|
+
export function createRepoIssueHandlers(workdir, overrides = {}) {
|
|
8
|
+
const { githubClient = createGithubClient(), ensureRepo = ensureRepository, now = () => new Date(), } = overrides;
|
|
9
|
+
const read = createQueryHandler(async (context) => {
|
|
10
|
+
const { org, repo } = extractRepositoryParams(context.url.searchParams);
|
|
11
|
+
const issueParam = context.url.searchParams.get('issue')?.trim() || '';
|
|
12
|
+
if (!issueParam) {
|
|
13
|
+
sendJson(context.res, 400, { error: 'issue query parameter is required' });
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
const issueNumber = Number.parseInt(issueParam, 10);
|
|
17
|
+
if (!Number.isInteger(issueNumber) || issueNumber <= 0) {
|
|
18
|
+
sendJson(context.res, 400, { error: 'issue query parameter must be a positive integer' });
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
try {
|
|
22
|
+
await ensureRepo(workdir, org, repo);
|
|
23
|
+
}
|
|
24
|
+
catch (error) {
|
|
25
|
+
const message = extractErrorMessage(error, 'Repository not found');
|
|
26
|
+
const statusCode = message.includes('not found') ? 404 : 500;
|
|
27
|
+
sendJson(context.res, statusCode, { error: message });
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
if (context.method === 'HEAD') {
|
|
31
|
+
handleHeadRequest(context.res);
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
const issue = await githubClient.getIssue(org, repo, issueNumber);
|
|
35
|
+
const fetchedAt = now().toISOString();
|
|
36
|
+
return {
|
|
37
|
+
data: {
|
|
38
|
+
org,
|
|
39
|
+
repo,
|
|
40
|
+
issue,
|
|
41
|
+
fetchedAt,
|
|
42
|
+
},
|
|
43
|
+
};
|
|
44
|
+
});
|
|
45
|
+
return { read };
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=repo-issue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repo-issue.js","sourceRoot":"","sources":["../../src/api/repo-issue.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAC/D,OAAO,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AASvD,MAAM,UAAU,uBAAuB,CAAC,OAAe,EAAE,YAAgC,EAAE;IACzF,MAAM,EACJ,YAAY,GAAG,kBAAkB,EAAE,EACnC,UAAU,GAAG,gBAAgB,EAC7B,GAAG,GAAG,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE,GACvB,GAAG,SAAS,CAAC;IAEd,MAAM,IAAI,GAAG,kBAAkB,CAAC,KAAK,EAAE,OAAuB,EAAE,EAAE;QAChE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,uBAAuB,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QACxE,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QAEvE,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,KAAK,EAAE,mCAAmC,EAAE,CAAC,CAAC;YAC3E,OAAO;QACT,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,CAAC,QAAQ,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;QACpD,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,WAAW,IAAI,CAAC,EAAE,CAAC;YACvD,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,KAAK,EAAE,kDAAkD,EAAE,CAAC,CAAC;YAC1F,OAAO;QACT,CAAC;QAED,IAAI,CAAC;YACH,MAAM,UAAU,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QACvC,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,MAAM,OAAO,GAAG,mBAAmB,CAAC,KAAK,EAAE,sBAAsB,CAAC,CAAC;YACnE,MAAM,UAAU,GAAG,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;YAC7D,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,UAAU,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;YACtD,OAAO;QACT,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,KAAK,MAAM,EAAE,CAAC;YAC9B,iBAAiB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAC/B,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,MAAM,YAAY,CAAC,QAAQ,CAAC,GAAG,EAAE,IAAI,EAAE,WAAW,CAAC,CAAC;QAClE,MAAM,SAAS,GAAG,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC;QAEtC,OAAO;YACL,IAAI,EAAE;gBACJ,GAAG;gBACH,IAAI;gBACJ,KAAK;gBACL,SAAS;aACV;SACF,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,OAAO,EAAE,IAAI,EAAE,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { RequestContext } from '../types/http.js';
|
|
2
|
+
export declare function createRepoHandlers(workdir: string): {
|
|
3
|
+
list: (context: RequestContext) => Promise<void>;
|
|
4
|
+
create: (context: RequestContext) => Promise<void>;
|
|
5
|
+
delete: (context: RequestContext) => Promise<void>;
|
|
6
|
+
destroy: (context: RequestContext) => Promise<void>;
|
|
7
|
+
updateInitCommand: (context: RequestContext) => Promise<void>;
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=repos.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repos.d.ts","sourceRoot":"","sources":["../../src/api/repos.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAOvD,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,MAAM;;;;;;EA8CjD"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { createRepositoryService } from '../services/index.js';
|
|
2
|
+
import { handleHeadRequest } from '../utils/http.js';
|
|
3
|
+
import { asyncHandler } from '../infrastructure/errors/index.js';
|
|
4
|
+
import { createHandler } from './base-handler.js';
|
|
5
|
+
import { validateRepositoryCreate, validateRepositoryDelete, validateInitCommandUpdate, } from '../validation/index.js';
|
|
6
|
+
export function createRepoHandlers(workdir) {
|
|
7
|
+
const repositoryService = createRepositoryService(workdir);
|
|
8
|
+
const list = asyncHandler(async (context) => {
|
|
9
|
+
if (context.method === 'HEAD') {
|
|
10
|
+
handleHeadRequest(context.res);
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
const data = await repositoryService.listRepositories();
|
|
14
|
+
context.res.setHeader('Cache-Control', 'no-store');
|
|
15
|
+
context.res.statusCode = 200;
|
|
16
|
+
context.res.setHeader('Content-Type', 'application/json; charset=utf-8');
|
|
17
|
+
context.res.end(JSON.stringify({ data }));
|
|
18
|
+
});
|
|
19
|
+
const create = createHandler({
|
|
20
|
+
validator: validateRepositoryCreate,
|
|
21
|
+
handler: async (input) => repositoryService.addRepository(input.url, input.initCommand),
|
|
22
|
+
});
|
|
23
|
+
const deleteRepo = createHandler({
|
|
24
|
+
validator: validateRepositoryDelete,
|
|
25
|
+
handler: async (input) => {
|
|
26
|
+
const data = await repositoryService.deleteRepository(input.org, input.repo);
|
|
27
|
+
return { data };
|
|
28
|
+
},
|
|
29
|
+
});
|
|
30
|
+
const updateInitCommand = createHandler({
|
|
31
|
+
validator: validateInitCommandUpdate,
|
|
32
|
+
handler: async (input) => {
|
|
33
|
+
const data = await repositoryService.updateInitCommand(input.org, input.repo, input.initCommand);
|
|
34
|
+
return { data };
|
|
35
|
+
},
|
|
36
|
+
});
|
|
37
|
+
return {
|
|
38
|
+
list,
|
|
39
|
+
create,
|
|
40
|
+
delete: deleteRepo,
|
|
41
|
+
// Deprecated alias for backward compatibility
|
|
42
|
+
destroy: deleteRepo,
|
|
43
|
+
updateInitCommand
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=repos.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repos.js","sourceRoot":"","sources":["../../src/api/repos.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,OAAO,EACL,wBAAwB,EACxB,wBAAwB,EACxB,yBAAyB,GAC1B,MAAM,wBAAwB,CAAC;AAEhC,MAAM,UAAU,kBAAkB,CAAC,OAAe;IAChD,MAAM,iBAAiB,GAAG,uBAAuB,CAAC,OAAO,CAAC,CAAC;IAE3D,MAAM,IAAI,GAAG,YAAY,CAAC,KAAK,EAAE,OAAuB,EAAE,EAAE;QAC1D,IAAI,OAAO,CAAC,MAAM,KAAK,MAAM,EAAE,CAAC;YAC9B,iBAAiB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAC/B,OAAO;QACT,CAAC;QAED,MAAM,IAAI,GAAG,MAAM,iBAAiB,CAAC,gBAAgB,EAAE,CAAC;QACxD,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;QACnD,OAAO,CAAC,GAAG,CAAC,UAAU,GAAG,GAAG,CAAC;QAC7B,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,iCAAiC,CAAC,CAAC;QACzE,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,aAAa,CAAC;QAC3B,SAAS,EAAE,wBAAwB;QACnC,OAAO,EAAE,KAAK,EAAE,KAA2C,EAAE,EAAE,CAC7D,iBAAiB,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,WAAW,CAAC;KAChE,CAAC,CAAC;IAEH,MAAM,UAAU,GAAG,aAAa,CAAC;QAC/B,SAAS,EAAE,wBAAwB;QACnC,OAAO,EAAE,KAAK,EAAE,KAAoC,EAAE,EAAE;YACtD,MAAM,IAAI,GAAG,MAAM,iBAAiB,CAAC,gBAAgB,CAAC,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;YAC7E,OAAO,EAAE,IAAI,EAAE,CAAC;QAClB,CAAC;KACF,CAAC,CAAC;IAEH,MAAM,iBAAiB,GAAG,aAAa,CAAC;QACtC,SAAS,EAAE,yBAAyB;QACpC,OAAO,EAAE,KAAK,EAAE,KAAyD,EAAE,EAAE;YAC3E,MAAM,IAAI,GAAG,MAAM,iBAAiB,CAAC,iBAAiB,CAAC,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC;YACjG,OAAO,EAAE,IAAI,EAAE,CAAC;QAClB,CAAC;KACF,CAAC,CAAC;IAEH,OAAO;QACL,IAAI;QACJ,MAAM;QACN,MAAM,EAAE,UAAU;QAClB,8CAA8C;QAC9C,OAAO,EAAE,UAAU;QACnB,iBAAiB;KAClB,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessions.d.ts","sourceRoot":"","sources":["../../src/api/sessions.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAEvD,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,MAAM;;EAiBpD"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { createSessionService } from '../services/session-service.js';
|
|
2
|
+
import { handleHeadRequest } from '../utils/http.js';
|
|
3
|
+
import { asyncHandler } from '../infrastructure/errors/index.js';
|
|
4
|
+
export function createSessionHandlers(workdir) {
|
|
5
|
+
const sessionService = createSessionService(workdir);
|
|
6
|
+
const list = asyncHandler(async (context) => {
|
|
7
|
+
if (context.method === 'HEAD') {
|
|
8
|
+
handleHeadRequest(context.res);
|
|
9
|
+
return;
|
|
10
|
+
}
|
|
11
|
+
const sessions = await sessionService.listSessions();
|
|
12
|
+
context.res.setHeader('Cache-Control', 'no-store');
|
|
13
|
+
context.res.statusCode = 200;
|
|
14
|
+
context.res.setHeader('Content-Type', 'application/json; charset=utf-8');
|
|
15
|
+
context.res.end(JSON.stringify({ sessions }));
|
|
16
|
+
});
|
|
17
|
+
return { list };
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=sessions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessions.js","sourceRoot":"","sources":["../../src/api/sessions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AACtE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AAGjE,MAAM,UAAU,qBAAqB,CAAC,OAAe;IACnD,MAAM,cAAc,GAAG,oBAAoB,CAAC,OAAO,CAAC,CAAC;IAErD,MAAM,IAAI,GAAG,YAAY,CAAC,KAAK,EAAE,OAAuB,EAAE,EAAE;QAC1D,IAAI,OAAO,CAAC,MAAM,KAAK,MAAM,EAAE,CAAC;YAC9B,iBAAiB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAC/B,OAAO;QACT,CAAC;QAED,MAAM,QAAQ,GAAG,MAAM,cAAc,CAAC,YAAY,EAAE,CAAC;QACrD,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;QACnD,OAAO,CAAC,GAAG,CAAC,UAAU,GAAG,GAAG,CAAC;QAC7B,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,iCAAiC,CAAC,CAAC;QACzE,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;IAEH,OAAO,EAAE,IAAI,EAAE,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tasks.d.ts","sourceRoot":"","sources":["../../src/api/tasks.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAEvD,wBAAgB,kBAAkB;;oBAKH,cAAc,UAAU,MAAM,KAAG,OAAO,CAAC,IAAI,CAAC;EAgB5E"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { getTaskById, listTasks } from '../core/tasks.js';
|
|
2
|
+
import { sendJson } from '../utils/http.js';
|
|
3
|
+
import { createSimpleHandler } from './base-handler.js';
|
|
4
|
+
export function createTaskHandlers() {
|
|
5
|
+
const list = createSimpleHandler(async () => ({ tasks: listTasks() }));
|
|
6
|
+
async function read(context, taskId) {
|
|
7
|
+
const ctx = context;
|
|
8
|
+
const id = typeof taskId === 'string' && taskId ? taskId : ctx?.params?.id;
|
|
9
|
+
if (!id) {
|
|
10
|
+
sendJson(context.res, 400, { error: 'Task identifier is required' });
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
const task = getTaskById(id);
|
|
14
|
+
if (!task) {
|
|
15
|
+
sendJson(context.res, 404, { error: 'Task not found' });
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
sendJson(context.res, 200, { task });
|
|
19
|
+
}
|
|
20
|
+
return { list, read };
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=tasks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tasks.js","sourceRoot":"","sources":["../../src/api/tasks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC1D,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAGxD,MAAM,UAAU,kBAAkB;IAChC,MAAM,IAAI,GAAG,mBAAmB,CAC9B,KAAK,IAAI,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,CAAC,CACrC,CAAC;IAEF,KAAK,UAAU,IAAI,CAAC,OAAuB,EAAE,MAAc;QACzD,MAAM,GAAG,GAAG,OAAwD,CAAC;QACrE,MAAM,EAAE,GAAG,OAAO,MAAM,KAAK,QAAQ,IAAI,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC;QAC3E,IAAI,CAAC,EAAE,EAAE,CAAC;YACR,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,KAAK,EAAE,6BAA6B,EAAE,CAAC,CAAC;YACrE,OAAO;QACT,CAAC;QACD,MAAM,IAAI,GAAG,WAAW,CAAC,EAAE,CAAC,CAAC;QAC7B,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,KAAK,EAAE,gBAAgB,EAAE,CAAC,CAAC;YACxD,OAAO;QACT,CAAC;QACD,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC;IACvC,CAAC;IAED,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;AACxB,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export declare function createTerminalHandlers(workdir: string, options?: {
|
|
2
|
+
mode?: string;
|
|
3
|
+
}): {
|
|
4
|
+
open: (context: import("../types/http.js").RequestContext) => Promise<void>;
|
|
5
|
+
send: (context: import("../types/http.js").RequestContext) => Promise<void>;
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=terminal.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"terminal.d.ts","sourceRoot":"","sources":["../../src/api/terminal.ts"],"names":[],"mappings":"AAKA,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,GAAE;IAAE,IAAI,CAAC,EAAE,MAAM,CAAA;CAAO;;;EActF"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { createTerminalService } from '../services/index.js';
|
|
2
|
+
import { createHandler } from './base-handler.js';
|
|
3
|
+
import { validateTerminalOpen, validateTerminalSend } from '../validation/index.js';
|
|
4
|
+
export function createTerminalHandlers(workdir, options = {}) {
|
|
5
|
+
const terminalService = createTerminalService(workdir, options);
|
|
6
|
+
const open = createHandler({
|
|
7
|
+
validator: validateTerminalOpen,
|
|
8
|
+
handler: async (input) => terminalService.openTerminal(input),
|
|
9
|
+
});
|
|
10
|
+
const send = createHandler({
|
|
11
|
+
validator: validateTerminalSend,
|
|
12
|
+
handler: async (input) => terminalService.sendInput(input),
|
|
13
|
+
});
|
|
14
|
+
return { open, send };
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=terminal.js.map
|