devchain-cli 0.14.0 → 0.15.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +6 -4
- package/dist/cli.js +5 -11
- package/dist/drizzle/0065_next_lady_bullseye.sql +11 -0
- package/dist/drizzle/meta/0065_snapshot.json +5691 -0
- package/dist/drizzle/meta/_journal.json +7 -0
- package/dist/node_modules/@devchain/codebase-overview/tsconfig.tsbuildinfo +1 -1
- package/dist/node_modules/@devchain/codebase-overview/types.d.ts.map +1 -1
- package/dist/node_modules/@devchain/shared/__fixtures__/phase2-frames.d.ts +20 -0
- package/dist/node_modules/@devchain/shared/__fixtures__/phase2-frames.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/__fixtures__/phase2-frames.js +77 -0
- package/dist/node_modules/@devchain/shared/__fixtures__/phase2-frames.js.map +1 -0
- package/dist/node_modules/@devchain/shared/device-key/index.d.ts +2 -0
- package/dist/node_modules/@devchain/shared/device-key/index.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/device-key/index.js +2 -0
- package/dist/node_modules/@devchain/shared/device-key/index.js.map +1 -0
- package/dist/node_modules/@devchain/shared/device-key/keypair.d.ts +23 -0
- package/dist/node_modules/@devchain/shared/device-key/keypair.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/device-key/keypair.js +54 -0
- package/dist/node_modules/@devchain/shared/device-key/keypair.js.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/aad.d.ts +3 -0
- package/dist/node_modules/@devchain/shared/e2ee/aad.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/aad.js +0 -0
- package/dist/node_modules/@devchain/shared/e2ee/aad.js.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/base64.d.ts +6 -0
- package/dist/node_modules/@devchain/shared/e2ee/base64.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/base64.js +69 -0
- package/dist/node_modules/@devchain/shared/e2ee/base64.js.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/crypto-envelope.service.d.ts +9 -0
- package/dist/node_modules/@devchain/shared/e2ee/crypto-envelope.service.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/crypto-envelope.service.js +78 -0
- package/dist/node_modules/@devchain/shared/e2ee/crypto-envelope.service.js.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/envelope.d.ts +63 -0
- package/dist/node_modules/@devchain/shared/e2ee/envelope.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/envelope.js +64 -0
- package/dist/node_modules/@devchain/shared/e2ee/envelope.js.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/index.d.ts +10 -0
- package/dist/node_modules/@devchain/shared/e2ee/index.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/index.js +10 -0
- package/dist/node_modules/@devchain/shared/e2ee/index.js.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/key-exchange.d.ts +17 -0
- package/dist/node_modules/@devchain/shared/e2ee/key-exchange.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/key-exchange.js +72 -0
- package/dist/node_modules/@devchain/shared/e2ee/key-exchange.js.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/keypair.d.ts +13 -0
- package/dist/node_modules/@devchain/shared/e2ee/keypair.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/keypair.js +34 -0
- package/dist/node_modules/@devchain/shared/e2ee/keypair.js.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/negotiation.d.ts +30 -0
- package/dist/node_modules/@devchain/shared/e2ee/negotiation.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/negotiation.js +70 -0
- package/dist/node_modules/@devchain/shared/e2ee/negotiation.js.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/safety-number.d.ts +3 -0
- package/dist/node_modules/@devchain/shared/e2ee/safety-number.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/safety-number.js +33 -0
- package/dist/node_modules/@devchain/shared/e2ee/safety-number.js.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/trust.d.ts +22 -0
- package/dist/node_modules/@devchain/shared/e2ee/trust.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/e2ee/trust.js +25 -0
- package/dist/node_modules/@devchain/shared/e2ee/trust.js.map +1 -0
- package/dist/node_modules/@devchain/shared/index.d.ts +3 -0
- package/dist/node_modules/@devchain/shared/index.d.ts.map +1 -1
- package/dist/node_modules/@devchain/shared/index.js +3 -0
- package/dist/node_modules/@devchain/shared/index.js.map +1 -1
- package/dist/node_modules/@devchain/shared/schemas/export-schema.d.ts +14 -6
- package/dist/node_modules/@devchain/shared/schemas/export-schema.d.ts.map +1 -1
- package/dist/node_modules/@devchain/shared/schemas/export-schema.js +1 -0
- package/dist/node_modules/@devchain/shared/schemas/export-schema.js.map +1 -1
- package/dist/node_modules/@devchain/shared/tsconfig.tsbuildinfo +1 -1
- package/dist/node_modules/@devchain/shared/tunnel-protocol.d.ts +99 -0
- package/dist/node_modules/@devchain/shared/tunnel-protocol.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/tunnel-protocol.js +148 -0
- package/dist/node_modules/@devchain/shared/tunnel-protocol.js.map +1 -0
- package/dist/server/app.main.module.js +2 -0
- package/dist/server/app.main.module.js.map +1 -1
- package/dist/server/app.normal.module.js +2 -0
- package/dist/server/app.normal.module.js.map +1 -1
- package/dist/server/common/config/env.config.js +5 -7
- package/dist/server/common/config/env.config.js.map +1 -1
- package/dist/server/common/test/app-bootstrap.helper.js +5 -1
- package/dist/server/common/test/app-bootstrap.helper.js.map +1 -1
- package/dist/server/modules/agent-message-delivery/adapters/legacy-delivery-formatter.adapter.js +4 -0
- package/dist/server/modules/agent-message-delivery/adapters/legacy-delivery-formatter.adapter.js.map +1 -1
- package/dist/server/modules/agent-message-delivery/agent-message-delivery.service.d.ts +3 -1
- package/dist/server/modules/agent-message-delivery/agent-message-delivery.service.js +16 -3
- package/dist/server/modules/agent-message-delivery/agent-message-delivery.service.js.map +1 -1
- package/dist/server/modules/agent-message-delivery/dtos/delivery.types.d.ts +4 -0
- package/dist/server/modules/agents/agents.module.js +2 -1
- package/dist/server/modules/agents/agents.module.js.map +1 -1
- package/dist/server/modules/agents/controllers/agents.controller.d.ts +3 -1
- package/dist/server/modules/agents/controllers/agents.controller.js +12 -2
- package/dist/server/modules/agents/controllers/agents.controller.js.map +1 -1
- package/dist/server/modules/cloud/cloud.module.js +8 -1
- package/dist/server/modules/cloud/cloud.module.js.map +1 -1
- package/dist/server/modules/cloud/controllers/auth-callback.controller.js +5 -4
- package/dist/server/modules/cloud/controllers/auth-callback.controller.js.map +1 -1
- package/dist/server/modules/cloud/controllers/devices-proxy.controller.js +1 -1
- package/dist/server/modules/cloud/controllers/devices-proxy.controller.js.map +1 -1
- package/dist/server/modules/cloud/controllers/preferences-proxy.controller.js +1 -1
- package/dist/server/modules/cloud/controllers/preferences-proxy.controller.js.map +1 -1
- package/dist/server/modules/cloud/controllers/qr-initiate-proxy.controller.js +1 -1
- package/dist/server/modules/cloud/controllers/qr-initiate-proxy.controller.js.map +1 -1
- package/dist/server/modules/cloud/controllers/store-tokens-error.d.ts +4 -0
- package/dist/server/modules/cloud/controllers/store-tokens-error.js +103 -0
- package/dist/server/modules/cloud/controllers/store-tokens-error.js.map +1 -0
- package/dist/server/modules/cloud/services/cloud-session-manager.service.js +18 -8
- package/dist/server/modules/cloud/services/cloud-session-manager.service.js.map +1 -1
- package/dist/server/modules/cloud/services/egress-queue.service.js +2 -2
- package/dist/server/modules/cloud/services/egress-queue.service.js.map +1 -1
- package/dist/server/modules/cloud/services/event-mapper.service.d.ts +9 -1
- package/dist/server/modules/cloud/services/event-mapper.service.js +18 -2
- package/dist/server/modules/cloud/services/event-mapper.service.js.map +1 -1
- package/dist/server/modules/cloud/services/project-activity-reporter.service.js +1 -1
- package/dist/server/modules/cloud/services/project-activity-reporter.service.js.map +1 -1
- package/dist/server/modules/cloud-tunnel/cloud-tunnel.module.js +57 -2
- package/dist/server/modules/cloud-tunnel/cloud-tunnel.module.js.map +1 -1
- package/dist/server/modules/cloud-tunnel/services/ask-user-question-push-gate.service.d.ts +20 -0
- package/dist/server/modules/cloud-tunnel/services/ask-user-question-push-gate.service.js +84 -0
- package/dist/server/modules/cloud-tunnel/services/ask-user-question-push-gate.service.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/epic-dto.util.d.ts +3 -0
- package/dist/server/modules/cloud-tunnel/services/epic-dto.util.js +43 -0
- package/dist/server/modules/cloud-tunnel/services/epic-dto.util.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/jsonrpc-error.util.d.ts +11 -0
- package/dist/server/modules/cloud-tunnel/services/jsonrpc-error.util.js +32 -0
- package/dist/server/modules/cloud-tunnel/services/jsonrpc-error.util.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/lifecycle-operation-tracker.d.ts +30 -0
- package/dist/server/modules/cloud-tunnel/services/lifecycle-operation-tracker.js +80 -0
- package/dist/server/modules/cloud-tunnel/services/lifecycle-operation-tracker.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/mobile-board-rpc.service.d.ts +16 -0
- package/dist/server/modules/cloud-tunnel/services/mobile-board-rpc.service.js +78 -0
- package/dist/server/modules/cloud-tunnel/services/mobile-board-rpc.service.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/mobile-chat-rpc.service.d.ts +112 -0
- package/dist/server/modules/cloud-tunnel/services/mobile-chat-rpc.service.js +457 -0
- package/dist/server/modules/cloud-tunnel/services/mobile-chat-rpc.service.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.d.ts +28 -2
- package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.js +143 -5
- package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.js.map +1 -1
- package/dist/server/modules/cloud-tunnel/services/tunnel-event-forwarder.service.d.ts +21 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-event-forwarder.service.js +171 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-event-forwarder.service.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.d.ts +9 -4
- package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.js +194 -52
- package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.js.map +1 -1
- package/dist/server/modules/cloud-tunnel/services/tunnel-push-crypto.service.d.ts +21 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-push-crypto.service.js +117 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-push-crypto.service.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-rpc-crypto.service.d.ts +41 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-rpc-crypto.service.js +116 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-rpc-crypto.service.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-viewport-crypto.service.d.ts +20 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-viewport-crypto.service.js +114 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-viewport-crypto.service.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/viewport-frame-sink.d.ts +6 -0
- package/dist/server/modules/cloud-tunnel/services/viewport-frame-sink.js +7 -0
- package/dist/server/modules/cloud-tunnel/services/viewport-frame-sink.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/viewport-streamer.service.d.ts +30 -0
- package/dist/server/modules/cloud-tunnel/services/viewport-streamer.service.js +228 -0
- package/dist/server/modules/cloud-tunnel/services/viewport-streamer.service.js.map +1 -0
- package/dist/server/modules/e2ee/controllers/e2ee-pairing.controller.d.ts +18 -0
- package/dist/server/modules/e2ee/controllers/e2ee-pairing.controller.js +62 -0
- package/dist/server/modules/e2ee/controllers/e2ee-pairing.controller.js.map +1 -0
- package/dist/server/modules/e2ee/controllers/e2ee-trust.controller.d.ts +19 -0
- package/dist/server/modules/e2ee/controllers/e2ee-trust.controller.js +85 -0
- package/dist/server/modules/e2ee/controllers/e2ee-trust.controller.js.map +1 -0
- package/dist/server/modules/e2ee/e2ee.module.d.ts +2 -0
- package/dist/server/modules/e2ee/e2ee.module.js +27 -0
- package/dist/server/modules/e2ee/e2ee.module.js.map +1 -0
- package/dist/server/modules/e2ee/services/e2ee-device-store.service.d.ts +29 -0
- package/dist/server/modules/e2ee/services/e2ee-device-store.service.js +138 -0
- package/dist/server/modules/e2ee/services/e2ee-device-store.service.js.map +1 -0
- package/dist/server/modules/e2ee/services/e2ee-keypair.service.d.ts +21 -0
- package/dist/server/modules/e2ee/services/e2ee-keypair.service.js +152 -0
- package/dist/server/modules/e2ee/services/e2ee-keypair.service.js.map +1 -0
- package/dist/server/modules/e2ee/services/e2ee-pairing.service.d.ts +28 -0
- package/dist/server/modules/e2ee/services/e2ee-pairing.service.js +107 -0
- package/dist/server/modules/e2ee/services/e2ee-pairing.service.js.map +1 -0
- package/dist/server/modules/e2ee/services/e2ee-trust.service.d.ts +36 -0
- package/dist/server/modules/e2ee/services/e2ee-trust.service.js +118 -0
- package/dist/server/modules/e2ee/services/e2ee-trust.service.js.map +1 -0
- package/dist/server/modules/epics/services/epics.service.d.ts +1 -0
- package/dist/server/modules/epics/services/epics.service.js +10 -0
- package/dist/server/modules/epics/services/epics.service.js.map +1 -1
- package/dist/server/modules/events/catalog/broadcast-metadata.d.ts +6 -2
- package/dist/server/modules/events/catalog/broadcast-registry.d.ts +2 -2
- package/dist/server/modules/events/catalog/broadcast-registry.js +58 -1
- package/dist/server/modules/events/catalog/broadcast-registry.js.map +1 -1
- package/dist/server/modules/events/catalog/claude.hooks.ask_user_question.pending.d.ts +122 -0
- package/dist/server/modules/events/catalog/claude.hooks.ask_user_question.pending.js +28 -0
- package/dist/server/modules/events/catalog/claude.hooks.ask_user_question.pending.js.map +1 -0
- package/dist/server/modules/events/catalog/claude.hooks.ask_user_question.resolved.d.ts +18 -0
- package/dist/server/modules/events/catalog/claude.hooks.ask_user_question.resolved.js +13 -0
- package/dist/server/modules/events/catalog/claude.hooks.ask_user_question.resolved.js.map +1 -0
- package/dist/server/modules/events/catalog/index.d.ts +90 -0
- package/dist/server/modules/events/catalog/index.js +4 -0
- package/dist/server/modules/events/catalog/index.js.map +1 -1
- package/dist/server/modules/events/catalog/project-broadcast.d.ts +7 -0
- package/dist/server/modules/events/catalog/project-broadcast.js +10 -0
- package/dist/server/modules/events/catalog/project-broadcast.js.map +1 -0
- package/dist/server/modules/events/catalog/session.transcript.discovered.d.ts +3 -0
- package/dist/server/modules/events/catalog/session.transcript.discovered.js +1 -0
- package/dist/server/modules/events/catalog/session.transcript.discovered.js.map +1 -1
- package/dist/server/modules/events/services/catalog-broadcaster.service.js +3 -4
- package/dist/server/modules/events/services/catalog-broadcaster.service.js.map +1 -1
- package/dist/server/modules/hooks/dtos/ask-user-question.dto.d.ts +5 -0
- package/dist/server/modules/hooks/dtos/ask-user-question.dto.js +51 -0
- package/dist/server/modules/hooks/dtos/ask-user-question.dto.js.map +1 -0
- package/dist/server/modules/hooks/dtos/hook-event.dto.d.ts +206 -5
- package/dist/server/modules/hooks/dtos/hook-event.dto.js +40 -8
- package/dist/server/modules/hooks/dtos/hook-event.dto.js.map +1 -1
- package/dist/server/modules/hooks/hooks.module.js +3 -2
- package/dist/server/modules/hooks/hooks.module.js.map +1 -1
- package/dist/server/modules/hooks/services/hooks-config.service.d.ts +1 -0
- package/dist/server/modules/hooks/services/hooks-config.service.js +52 -33
- package/dist/server/modules/hooks/services/hooks-config.service.js.map +1 -1
- package/dist/server/modules/hooks/services/hooks.service.d.ts +5 -1
- package/dist/server/modules/hooks/services/hooks.service.js +68 -2
- package/dist/server/modules/hooks/services/hooks.service.js.map +1 -1
- package/dist/server/modules/hooks/services/pending-ask-user-question.service.d.ts +38 -0
- package/dist/server/modules/hooks/services/pending-ask-user-question.service.js +105 -0
- package/dist/server/modules/hooks/services/pending-ask-user-question.service.js.map +1 -0
- package/dist/server/modules/orchestrator/worktrees/services/worktrees.service.js +3 -0
- package/dist/server/modules/orchestrator/worktrees/services/worktrees.service.js.map +1 -1
- package/dist/server/modules/projects/controllers/projects.controller.d.ts +7 -0
- package/dist/server/modules/projects/dtos/export.dto.d.ts +8 -0
- package/dist/server/modules/projects/dtos/export.dto.js +1 -0
- package/dist/server/modules/projects/dtos/export.dto.js.map +1 -1
- package/dist/server/modules/projects/helpers/project-export.d.ts +1 -0
- package/dist/server/modules/projects/helpers/project-export.js +19 -5
- package/dist/server/modules/projects/helpers/project-export.js.map +1 -1
- package/dist/server/modules/projects/helpers/project-import-sessions.d.ts +11 -0
- package/dist/server/modules/projects/helpers/project-import-sessions.js +47 -0
- package/dist/server/modules/projects/helpers/project-import-sessions.js.map +1 -0
- package/dist/server/modules/projects/helpers/project-import.d.ts +4 -0
- package/dist/server/modules/projects/helpers/project-import.js +12 -2
- package/dist/server/modules/projects/helpers/project-import.js.map +1 -1
- package/dist/server/modules/projects/services/projects.service.d.ts +5 -0
- package/dist/server/modules/providers/adapters/claude.adapter.d.ts +1 -0
- package/dist/server/modules/providers/adapters/claude.adapter.js +1 -0
- package/dist/server/modules/providers/adapters/claude.adapter.js.map +1 -1
- package/dist/server/modules/providers/adapters/opencode.adapter.d.ts +4 -1
- package/dist/server/modules/providers/adapters/opencode.adapter.js +3 -0
- package/dist/server/modules/providers/adapters/opencode.adapter.js.map +1 -1
- package/dist/server/modules/providers/adapters/provider-adapter.interface.d.ts +2 -0
- package/dist/server/modules/providers/controllers/providers.controller.d.ts +50 -3
- package/dist/server/modules/providers/controllers/providers.controller.js +12 -3
- package/dist/server/modules/providers/controllers/providers.controller.js.map +1 -1
- package/dist/server/modules/providers/services/provider-state-manager.service.d.ts +2 -1
- package/dist/server/modules/providers/services/provider-state-manager.service.js +43 -1
- package/dist/server/modules/providers/services/provider-state-manager.service.js.map +1 -1
- package/dist/server/modules/registry/controllers/templates.controller.d.ts +2 -1
- package/dist/server/modules/registry/services/template-cache.service.d.ts +2 -0
- package/dist/server/modules/registry/services/template-cache.service.js +5 -0
- package/dist/server/modules/registry/services/template-cache.service.js.map +1 -1
- package/dist/server/modules/registry/services/unified-template.service.d.ts +1 -0
- package/dist/server/modules/registry/services/unified-template.service.js +9 -1
- package/dist/server/modules/registry/services/unified-template.service.js.map +1 -1
- package/dist/server/modules/session-reader/__fixtures__/opencode-fixture-db.d.ts +44 -0
- package/dist/server/modules/session-reader/__fixtures__/opencode-fixture-db.js +85 -0
- package/dist/server/modules/session-reader/__fixtures__/opencode-fixture-db.js.map +1 -0
- package/dist/server/modules/session-reader/adapters/opencode-session-reader.adapter.d.ts +23 -0
- package/dist/server/modules/session-reader/adapters/opencode-session-reader.adapter.js +150 -0
- package/dist/server/modules/session-reader/adapters/opencode-session-reader.adapter.js.map +1 -0
- package/dist/server/modules/session-reader/adapters/session-reader-adapter.interface.d.ts +16 -2
- package/dist/server/modules/session-reader/adapters/session-reader-adapter.interface.js +39 -0
- package/dist/server/modules/session-reader/adapters/session-reader-adapter.interface.js.map +1 -1
- package/dist/server/modules/session-reader/adapters/utils/coalesce-turns.d.ts +11 -0
- package/dist/server/modules/session-reader/adapters/utils/coalesce-turns.js +81 -0
- package/dist/server/modules/session-reader/adapters/utils/coalesce-turns.js.map +1 -0
- package/dist/server/modules/session-reader/adapters/utils/tool-result-fold.d.ts +2 -0
- package/dist/server/modules/session-reader/adapters/utils/tool-result-fold.js +9 -0
- package/dist/server/modules/session-reader/adapters/utils/tool-result-fold.js.map +1 -0
- package/dist/server/modules/session-reader/builders/chunk-builder.js +0 -2
- package/dist/server/modules/session-reader/builders/chunk-builder.js.map +1 -1
- package/dist/server/modules/session-reader/builders/semantic-step-extractor.js +2 -0
- package/dist/server/modules/session-reader/builders/semantic-step-extractor.js.map +1 -1
- package/dist/server/modules/session-reader/controllers/session-reader.controller.d.ts +1 -0
- package/dist/server/modules/session-reader/data/pricing.json +387 -34
- package/dist/server/modules/session-reader/dtos/unified-message.types.d.ts +1 -0
- package/dist/server/modules/session-reader/dtos/unified-session.types.js.map +1 -1
- package/dist/server/modules/session-reader/parsers/claude-jsonl.parser.js +46 -0
- package/dist/server/modules/session-reader/parsers/claude-jsonl.parser.js.map +1 -1
- package/dist/server/modules/session-reader/parsers/codex-jsonl.parser.js +35 -17
- package/dist/server/modules/session-reader/parsers/codex-jsonl.parser.js.map +1 -1
- package/dist/server/modules/session-reader/readers/opencode-sqlite.reader.d.ts +69 -0
- package/dist/server/modules/session-reader/readers/opencode-sqlite.reader.js +378 -0
- package/dist/server/modules/session-reader/readers/opencode-sqlite.reader.js.map +1 -0
- package/dist/server/modules/session-reader/services/session-cache.service.d.ts +12 -3
- package/dist/server/modules/session-reader/services/session-cache.service.js +104 -19
- package/dist/server/modules/session-reader/services/session-cache.service.js.map +1 -1
- package/dist/server/modules/session-reader/services/session-reader.service.d.ts +5 -0
- package/dist/server/modules/session-reader/services/session-reader.service.js +51 -16
- package/dist/server/modules/session-reader/services/session-reader.service.js.map +1 -1
- package/dist/server/modules/session-reader/services/transcript-path-validator.service.js +1 -0
- package/dist/server/modules/session-reader/services/transcript-path-validator.service.js.map +1 -1
- package/dist/server/modules/session-reader/services/transcript-persistence.listener.d.ts +3 -0
- package/dist/server/modules/session-reader/services/transcript-persistence.listener.js +70 -1
- package/dist/server/modules/session-reader/services/transcript-persistence.listener.js.map +1 -1
- package/dist/server/modules/session-reader/services/transcript-watcher-rehydrator.service.d.ts +10 -0
- package/dist/server/modules/session-reader/services/transcript-watcher-rehydrator.service.js +47 -0
- package/dist/server/modules/session-reader/services/transcript-watcher-rehydrator.service.js.map +1 -0
- package/dist/server/modules/session-reader/services/transcript-watcher.service.d.ts +7 -1
- package/dist/server/modules/session-reader/services/transcript-watcher.service.js +177 -28
- package/dist/server/modules/session-reader/services/transcript-watcher.service.js.map +1 -1
- package/dist/server/modules/session-reader/session-reader.module.d.ts +3 -1
- package/dist/server/modules/session-reader/session-reader.module.js +10 -2
- package/dist/server/modules/session-reader/session-reader.module.js.map +1 -1
- package/dist/server/modules/sessions/controllers/sessions.controller.js +2 -22
- package/dist/server/modules/sessions/controllers/sessions.controller.js.map +1 -1
- package/dist/server/modules/sessions/dtos/sessions.dto.d.ts +1 -0
- package/dist/server/modules/sessions/dtos/sessions.dto.js.map +1 -1
- package/dist/server/modules/sessions/services/active-session-lookup.service.d.ts +5 -0
- package/dist/server/modules/sessions/services/active-session-lookup.service.js +12 -0
- package/dist/server/modules/sessions/services/active-session-lookup.service.js.map +1 -1
- package/dist/server/modules/sessions/services/message-enqueue.service.d.ts +2 -0
- package/dist/server/modules/sessions/services/message-enqueue.service.js +2 -0
- package/dist/server/modules/sessions/services/message-enqueue.service.js.map +1 -1
- package/dist/server/modules/sessions/services/message-pool.types.d.ts +2 -0
- package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.js +1 -1
- package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.js.map +1 -1
- package/dist/server/modules/sessions/services/session-lifecycle-facade.service.d.ts +18 -0
- package/dist/server/modules/sessions/services/session-lifecycle-facade.service.js +74 -0
- package/dist/server/modules/sessions/services/session-lifecycle-facade.service.js.map +1 -0
- package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.d.ts +4 -2
- package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.js +4 -2
- package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.js.map +1 -1
- package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.js +2 -2
- package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.js.map +1 -1
- package/dist/server/modules/sessions/services/session-runtime/session-restore-pipeline.service.js +2 -2
- package/dist/server/modules/sessions/services/session-runtime/session-restore-pipeline.service.js.map +1 -1
- package/dist/server/modules/sessions/services/sessions-message-pool.service.js +15 -3
- package/dist/server/modules/sessions/services/sessions-message-pool.service.js.map +1 -1
- package/dist/server/modules/sessions/services/sessions.service.d.ts +8 -0
- package/dist/server/modules/sessions/services/sessions.service.js +52 -1
- package/dist/server/modules/sessions/services/sessions.service.js.map +1 -1
- package/dist/server/modules/sessions/sessions-lifecycle.module.d.ts +2 -0
- package/dist/server/modules/sessions/sessions-lifecycle.module.js +23 -0
- package/dist/server/modules/sessions/sessions-lifecycle.module.js.map +1 -0
- package/dist/server/modules/settings/local/delegates/core-settings.delegate.js.map +1 -1
- package/dist/server/modules/settings/local/delegates/preset-settings.delegate.d.ts +1 -0
- package/dist/server/modules/settings/local/delegates/preset-settings.delegate.js +36 -0
- package/dist/server/modules/settings/local/delegates/preset-settings.delegate.js.map +1 -1
- package/dist/server/modules/settings/services/settings.service.d.ts +1 -0
- package/dist/server/modules/settings/services/settings.service.js +3 -0
- package/dist/server/modules/settings/services/settings.service.js.map +1 -1
- package/dist/server/modules/storage/db/schema.d.ts +83 -0
- package/dist/server/modules/storage/db/schema.js +15 -2
- package/dist/server/modules/storage/db/schema.js.map +1 -1
- package/dist/server/modules/storage/interfaces/storage.interface.d.ts +13 -2
- package/dist/server/modules/storage/interfaces/storage.interface.js.map +1 -1
- package/dist/server/modules/storage/local/delegates/epic.delegate.d.ts +1 -0
- package/dist/server/modules/storage/local/delegates/epic.delegate.js +8 -0
- package/dist/server/modules/storage/local/delegates/epic.delegate.js.map +1 -1
- package/dist/server/modules/storage/local/delegates/provider.delegate.d.ts +5 -1
- package/dist/server/modules/storage/local/delegates/provider.delegate.js +122 -0
- package/dist/server/modules/storage/local/delegates/provider.delegate.js.map +1 -1
- package/dist/server/modules/storage/local/delegates/session.delegate.d.ts +9 -0
- package/dist/server/modules/storage/local/delegates/session.delegate.js +115 -0
- package/dist/server/modules/storage/local/delegates/session.delegate.js.map +1 -0
- package/dist/server/modules/storage/local/local-storage.service.d.ts +10 -0
- package/dist/server/modules/storage/local/local-storage.service.js +20 -0
- package/dist/server/modules/storage/local/local-storage.service.js.map +1 -1
- package/dist/server/modules/storage/models/domain.models.d.ts +1 -0
- package/dist/server/modules/subscribers/services/automation-scheduler.service.js.map +1 -1
- package/dist/server/modules/teams/services/teams.service.d.ts +31 -3
- package/dist/server/modules/teams/services/teams.service.js +193 -2
- package/dist/server/modules/teams/services/teams.service.js.map +1 -1
- package/dist/server/modules/teams/storage/teams.store.d.ts +5 -0
- package/dist/server/modules/teams/storage/teams.store.js +34 -0
- package/dist/server/modules/teams/storage/teams.store.js.map +1 -1
- package/dist/server/modules/teams/teams.module.js +2 -1
- package/dist/server/modules/teams/teams.module.js.map +1 -1
- package/dist/server/modules/terminal/gateways/terminal.gateway.d.ts +5 -0
- package/dist/server/modules/terminal/gateways/terminal.gateway.js +45 -7
- package/dist/server/modules/terminal/gateways/terminal.gateway.js.map +1 -1
- package/dist/server/modules/terminal/services/pty.service.js +11 -3
- package/dist/server/modules/terminal/services/pty.service.js.map +1 -1
- package/dist/server/modules/terminal/services/terminal-io/terminal-io.service.d.ts +1 -1
- package/dist/server/modules/terminal/services/terminal-io/terminal-io.service.js +9 -2
- package/dist/server/modules/terminal/services/terminal-io/terminal-io.service.js.map +1 -1
- package/dist/server/modules/terminal/services/terminal-io/viewport-capture.d.ts +12 -0
- package/dist/server/modules/terminal/services/terminal-io/viewport-capture.js +50 -0
- package/dist/server/modules/terminal/services/terminal-io/viewport-capture.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-seed.service.js +1 -1
- package/dist/server/modules/terminal/services/terminal-seed.service.js.map +1 -1
- package/dist/server/modules/terminal/services/terminal-session/terminal-session.d.ts +9 -0
- package/dist/server/modules/terminal/services/terminal-session/terminal-session.js +24 -7
- package/dist/server/modules/terminal/services/terminal-session/terminal-session.js.map +1 -1
- package/dist/server/modules/terminal/services/terminal-viewport/terminal-viewport.facade.d.ts +12 -0
- package/dist/server/modules/terminal/services/terminal-viewport/terminal-viewport.facade.js +55 -0
- package/dist/server/modules/terminal/services/terminal-viewport/terminal-viewport.facade.js.map +1 -0
- package/dist/server/modules/terminal/terminal-viewport.module.d.ts +2 -0
- package/dist/server/modules/terminal/terminal-viewport.module.js +24 -0
- package/dist/server/modules/terminal/terminal-viewport.module.js.map +1 -0
- package/dist/server/modules/terminal/utils/normalize-line-endings.d.ts +1 -0
- package/dist/server/modules/terminal/utils/normalize-line-endings.js +8 -0
- package/dist/server/modules/terminal/utils/normalize-line-endings.js.map +1 -1
- package/dist/server/templates/3-agents-dev.json +33 -28
- package/dist/server/templates/teams-dev.json +189 -261
- package/dist/server/tsconfig.tsbuildinfo +1 -1
- package/dist/server/ui/assets/{ReviewDetailPage-C_XRFo7X.js → ReviewDetailPage-BpPjTAgL.js} +1 -1
- package/dist/server/ui/assets/{ReviewsPage-DUxJp7iE.js → ReviewsPage-CAs14WVx.js} +1 -1
- package/dist/server/ui/assets/index-CzMrWNAV.css +32 -0
- package/dist/server/ui/assets/index-DhGz-UAr.js +1100 -0
- package/dist/server/ui/assets/{useReviewSubscription-DJzltHrV.js → useReviewSubscription-CscSQD7B.js} +1 -1
- package/dist/server/ui/favicon.svg +2 -16
- package/dist/server/ui/index.html +2 -2
- package/dist/templates/3-agents-dev.json +33 -28
- package/dist/templates/teams-dev.json +189 -261
- package/package.json +28 -8
- package/dist/server/ui/assets/index-C_ZOt0it.css +0 -32
- package/dist/server/ui/assets/index-DS51wECY.js +0 -1095
|
@@ -1,15 +1,132 @@
|
|
|
1
1
|
import { z } from 'zod';
|
|
2
|
-
export declare const
|
|
3
|
-
hookEventName: z.ZodString;
|
|
2
|
+
export declare const SessionStartHookSchema: z.ZodObject<{
|
|
4
3
|
claudeSessionId: z.ZodString;
|
|
4
|
+
tmuxSessionName: z.ZodString;
|
|
5
|
+
projectId: z.ZodString;
|
|
6
|
+
agentId: z.ZodNullable<z.ZodString>;
|
|
7
|
+
sessionId: z.ZodNullable<z.ZodString>;
|
|
8
|
+
model: z.ZodOptional<z.ZodString>;
|
|
9
|
+
permissionMode: z.ZodOptional<z.ZodString>;
|
|
10
|
+
transcriptPath: z.ZodOptional<z.ZodString>;
|
|
11
|
+
hookEventName: z.ZodLiteral<"SessionStart">;
|
|
5
12
|
source: z.ZodString;
|
|
13
|
+
}, "strict", z.ZodTypeAny, {
|
|
14
|
+
projectId: string;
|
|
15
|
+
agentId: string | null;
|
|
16
|
+
source: string;
|
|
17
|
+
sessionId: string | null;
|
|
18
|
+
tmuxSessionName: string;
|
|
19
|
+
claudeSessionId: string;
|
|
20
|
+
hookEventName: "SessionStart";
|
|
21
|
+
transcriptPath?: string | undefined;
|
|
22
|
+
model?: string | undefined;
|
|
23
|
+
permissionMode?: string | undefined;
|
|
24
|
+
}, {
|
|
25
|
+
projectId: string;
|
|
26
|
+
agentId: string | null;
|
|
27
|
+
source: string;
|
|
28
|
+
sessionId: string | null;
|
|
29
|
+
tmuxSessionName: string;
|
|
30
|
+
claudeSessionId: string;
|
|
31
|
+
hookEventName: "SessionStart";
|
|
32
|
+
transcriptPath?: string | undefined;
|
|
33
|
+
model?: string | undefined;
|
|
34
|
+
permissionMode?: string | undefined;
|
|
35
|
+
}>;
|
|
36
|
+
export declare const PreToolUseHookSchema: z.ZodObject<{
|
|
37
|
+
claudeSessionId: z.ZodString;
|
|
38
|
+
tmuxSessionName: z.ZodString;
|
|
39
|
+
projectId: z.ZodString;
|
|
40
|
+
agentId: z.ZodNullable<z.ZodString>;
|
|
41
|
+
sessionId: z.ZodNullable<z.ZodString>;
|
|
6
42
|
model: z.ZodOptional<z.ZodString>;
|
|
7
43
|
permissionMode: z.ZodOptional<z.ZodString>;
|
|
8
44
|
transcriptPath: z.ZodOptional<z.ZodString>;
|
|
45
|
+
hookEventName: z.ZodLiteral<"PreToolUse">;
|
|
46
|
+
toolName: z.ZodString;
|
|
47
|
+
toolInput: z.ZodRecord<z.ZodString, z.ZodUnknown>;
|
|
48
|
+
toolUseId: z.ZodString;
|
|
49
|
+
}, "strict", z.ZodTypeAny, {
|
|
50
|
+
projectId: string;
|
|
51
|
+
agentId: string | null;
|
|
52
|
+
sessionId: string | null;
|
|
53
|
+
tmuxSessionName: string;
|
|
54
|
+
claudeSessionId: string;
|
|
55
|
+
toolUseId: string;
|
|
56
|
+
hookEventName: "PreToolUse";
|
|
57
|
+
toolName: string;
|
|
58
|
+
toolInput: Record<string, unknown>;
|
|
59
|
+
transcriptPath?: string | undefined;
|
|
60
|
+
model?: string | undefined;
|
|
61
|
+
permissionMode?: string | undefined;
|
|
62
|
+
}, {
|
|
63
|
+
projectId: string;
|
|
64
|
+
agentId: string | null;
|
|
65
|
+
sessionId: string | null;
|
|
66
|
+
tmuxSessionName: string;
|
|
67
|
+
claudeSessionId: string;
|
|
68
|
+
toolUseId: string;
|
|
69
|
+
hookEventName: "PreToolUse";
|
|
70
|
+
toolName: string;
|
|
71
|
+
toolInput: Record<string, unknown>;
|
|
72
|
+
transcriptPath?: string | undefined;
|
|
73
|
+
model?: string | undefined;
|
|
74
|
+
permissionMode?: string | undefined;
|
|
75
|
+
}>;
|
|
76
|
+
export declare const PostToolUseHookSchema: z.ZodObject<{
|
|
77
|
+
claudeSessionId: z.ZodString;
|
|
9
78
|
tmuxSessionName: z.ZodString;
|
|
10
79
|
projectId: z.ZodString;
|
|
11
80
|
agentId: z.ZodNullable<z.ZodString>;
|
|
12
81
|
sessionId: z.ZodNullable<z.ZodString>;
|
|
82
|
+
model: z.ZodOptional<z.ZodString>;
|
|
83
|
+
permissionMode: z.ZodOptional<z.ZodString>;
|
|
84
|
+
transcriptPath: z.ZodOptional<z.ZodString>;
|
|
85
|
+
hookEventName: z.ZodLiteral<"PostToolUse">;
|
|
86
|
+
toolName: z.ZodString;
|
|
87
|
+
toolInput: z.ZodRecord<z.ZodString, z.ZodUnknown>;
|
|
88
|
+
toolUseId: z.ZodString;
|
|
89
|
+
toolResponse: z.ZodOptional<z.ZodUnion<[z.ZodString, z.ZodRecord<z.ZodString, z.ZodUnknown>]>>;
|
|
90
|
+
}, "strict", z.ZodTypeAny, {
|
|
91
|
+
projectId: string;
|
|
92
|
+
agentId: string | null;
|
|
93
|
+
sessionId: string | null;
|
|
94
|
+
tmuxSessionName: string;
|
|
95
|
+
claudeSessionId: string;
|
|
96
|
+
toolUseId: string;
|
|
97
|
+
hookEventName: "PostToolUse";
|
|
98
|
+
toolName: string;
|
|
99
|
+
toolInput: Record<string, unknown>;
|
|
100
|
+
transcriptPath?: string | undefined;
|
|
101
|
+
model?: string | undefined;
|
|
102
|
+
permissionMode?: string | undefined;
|
|
103
|
+
toolResponse?: string | Record<string, unknown> | undefined;
|
|
104
|
+
}, {
|
|
105
|
+
projectId: string;
|
|
106
|
+
agentId: string | null;
|
|
107
|
+
sessionId: string | null;
|
|
108
|
+
tmuxSessionName: string;
|
|
109
|
+
claudeSessionId: string;
|
|
110
|
+
toolUseId: string;
|
|
111
|
+
hookEventName: "PostToolUse";
|
|
112
|
+
toolName: string;
|
|
113
|
+
toolInput: Record<string, unknown>;
|
|
114
|
+
transcriptPath?: string | undefined;
|
|
115
|
+
model?: string | undefined;
|
|
116
|
+
permissionMode?: string | undefined;
|
|
117
|
+
toolResponse?: string | Record<string, unknown> | undefined;
|
|
118
|
+
}>;
|
|
119
|
+
export declare const HookEventSchema: z.ZodDiscriminatedUnion<"hookEventName", [z.ZodObject<{
|
|
120
|
+
claudeSessionId: z.ZodString;
|
|
121
|
+
tmuxSessionName: z.ZodString;
|
|
122
|
+
projectId: z.ZodString;
|
|
123
|
+
agentId: z.ZodNullable<z.ZodString>;
|
|
124
|
+
sessionId: z.ZodNullable<z.ZodString>;
|
|
125
|
+
model: z.ZodOptional<z.ZodString>;
|
|
126
|
+
permissionMode: z.ZodOptional<z.ZodString>;
|
|
127
|
+
transcriptPath: z.ZodOptional<z.ZodString>;
|
|
128
|
+
hookEventName: z.ZodLiteral<"SessionStart">;
|
|
129
|
+
source: z.ZodString;
|
|
13
130
|
}, "strict", z.ZodTypeAny, {
|
|
14
131
|
projectId: string;
|
|
15
132
|
agentId: string | null;
|
|
@@ -17,7 +134,7 @@ export declare const HookEventSchema: z.ZodObject<{
|
|
|
17
134
|
sessionId: string | null;
|
|
18
135
|
tmuxSessionName: string;
|
|
19
136
|
claudeSessionId: string;
|
|
20
|
-
hookEventName:
|
|
137
|
+
hookEventName: "SessionStart";
|
|
21
138
|
transcriptPath?: string | undefined;
|
|
22
139
|
model?: string | undefined;
|
|
23
140
|
permissionMode?: string | undefined;
|
|
@@ -28,11 +145,95 @@ export declare const HookEventSchema: z.ZodObject<{
|
|
|
28
145
|
sessionId: string | null;
|
|
29
146
|
tmuxSessionName: string;
|
|
30
147
|
claudeSessionId: string;
|
|
31
|
-
hookEventName:
|
|
148
|
+
hookEventName: "SessionStart";
|
|
32
149
|
transcriptPath?: string | undefined;
|
|
33
150
|
model?: string | undefined;
|
|
34
151
|
permissionMode?: string | undefined;
|
|
35
|
-
}
|
|
152
|
+
}>, z.ZodObject<{
|
|
153
|
+
claudeSessionId: z.ZodString;
|
|
154
|
+
tmuxSessionName: z.ZodString;
|
|
155
|
+
projectId: z.ZodString;
|
|
156
|
+
agentId: z.ZodNullable<z.ZodString>;
|
|
157
|
+
sessionId: z.ZodNullable<z.ZodString>;
|
|
158
|
+
model: z.ZodOptional<z.ZodString>;
|
|
159
|
+
permissionMode: z.ZodOptional<z.ZodString>;
|
|
160
|
+
transcriptPath: z.ZodOptional<z.ZodString>;
|
|
161
|
+
hookEventName: z.ZodLiteral<"PreToolUse">;
|
|
162
|
+
toolName: z.ZodString;
|
|
163
|
+
toolInput: z.ZodRecord<z.ZodString, z.ZodUnknown>;
|
|
164
|
+
toolUseId: z.ZodString;
|
|
165
|
+
}, "strict", z.ZodTypeAny, {
|
|
166
|
+
projectId: string;
|
|
167
|
+
agentId: string | null;
|
|
168
|
+
sessionId: string | null;
|
|
169
|
+
tmuxSessionName: string;
|
|
170
|
+
claudeSessionId: string;
|
|
171
|
+
toolUseId: string;
|
|
172
|
+
hookEventName: "PreToolUse";
|
|
173
|
+
toolName: string;
|
|
174
|
+
toolInput: Record<string, unknown>;
|
|
175
|
+
transcriptPath?: string | undefined;
|
|
176
|
+
model?: string | undefined;
|
|
177
|
+
permissionMode?: string | undefined;
|
|
178
|
+
}, {
|
|
179
|
+
projectId: string;
|
|
180
|
+
agentId: string | null;
|
|
181
|
+
sessionId: string | null;
|
|
182
|
+
tmuxSessionName: string;
|
|
183
|
+
claudeSessionId: string;
|
|
184
|
+
toolUseId: string;
|
|
185
|
+
hookEventName: "PreToolUse";
|
|
186
|
+
toolName: string;
|
|
187
|
+
toolInput: Record<string, unknown>;
|
|
188
|
+
transcriptPath?: string | undefined;
|
|
189
|
+
model?: string | undefined;
|
|
190
|
+
permissionMode?: string | undefined;
|
|
191
|
+
}>, z.ZodObject<{
|
|
192
|
+
claudeSessionId: z.ZodString;
|
|
193
|
+
tmuxSessionName: z.ZodString;
|
|
194
|
+
projectId: z.ZodString;
|
|
195
|
+
agentId: z.ZodNullable<z.ZodString>;
|
|
196
|
+
sessionId: z.ZodNullable<z.ZodString>;
|
|
197
|
+
model: z.ZodOptional<z.ZodString>;
|
|
198
|
+
permissionMode: z.ZodOptional<z.ZodString>;
|
|
199
|
+
transcriptPath: z.ZodOptional<z.ZodString>;
|
|
200
|
+
hookEventName: z.ZodLiteral<"PostToolUse">;
|
|
201
|
+
toolName: z.ZodString;
|
|
202
|
+
toolInput: z.ZodRecord<z.ZodString, z.ZodUnknown>;
|
|
203
|
+
toolUseId: z.ZodString;
|
|
204
|
+
toolResponse: z.ZodOptional<z.ZodUnion<[z.ZodString, z.ZodRecord<z.ZodString, z.ZodUnknown>]>>;
|
|
205
|
+
}, "strict", z.ZodTypeAny, {
|
|
206
|
+
projectId: string;
|
|
207
|
+
agentId: string | null;
|
|
208
|
+
sessionId: string | null;
|
|
209
|
+
tmuxSessionName: string;
|
|
210
|
+
claudeSessionId: string;
|
|
211
|
+
toolUseId: string;
|
|
212
|
+
hookEventName: "PostToolUse";
|
|
213
|
+
toolName: string;
|
|
214
|
+
toolInput: Record<string, unknown>;
|
|
215
|
+
transcriptPath?: string | undefined;
|
|
216
|
+
model?: string | undefined;
|
|
217
|
+
permissionMode?: string | undefined;
|
|
218
|
+
toolResponse?: string | Record<string, unknown> | undefined;
|
|
219
|
+
}, {
|
|
220
|
+
projectId: string;
|
|
221
|
+
agentId: string | null;
|
|
222
|
+
sessionId: string | null;
|
|
223
|
+
tmuxSessionName: string;
|
|
224
|
+
claudeSessionId: string;
|
|
225
|
+
toolUseId: string;
|
|
226
|
+
hookEventName: "PostToolUse";
|
|
227
|
+
toolName: string;
|
|
228
|
+
toolInput: Record<string, unknown>;
|
|
229
|
+
transcriptPath?: string | undefined;
|
|
230
|
+
model?: string | undefined;
|
|
231
|
+
permissionMode?: string | undefined;
|
|
232
|
+
toolResponse?: string | Record<string, unknown> | undefined;
|
|
233
|
+
}>]>;
|
|
234
|
+
export type SessionStartHookEvent = z.infer<typeof SessionStartHookSchema>;
|
|
235
|
+
export type PreToolUseHookEvent = z.infer<typeof PreToolUseHookSchema>;
|
|
236
|
+
export type PostToolUseHookEvent = z.infer<typeof PostToolUseHookSchema>;
|
|
36
237
|
export type HookEventData = z.infer<typeof HookEventSchema>;
|
|
37
238
|
export interface HookEventResponse {
|
|
38
239
|
ok: boolean;
|
|
@@ -1,19 +1,51 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.HookEventSchema = void 0;
|
|
3
|
+
exports.HookEventSchema = exports.PostToolUseHookSchema = exports.PreToolUseHookSchema = exports.SessionStartHookSchema = void 0;
|
|
4
4
|
const zod_1 = require("zod");
|
|
5
|
-
|
|
6
|
-
.object({
|
|
7
|
-
hookEventName: zod_1.z.string().min(1),
|
|
5
|
+
const injectedFields = {
|
|
8
6
|
claudeSessionId: zod_1.z.string().min(1),
|
|
9
|
-
source: zod_1.z.string().min(1),
|
|
10
|
-
model: zod_1.z.string().max(200).optional(),
|
|
11
|
-
permissionMode: zod_1.z.string().max(100).optional(),
|
|
12
|
-
transcriptPath: zod_1.z.string().max(1000).optional(),
|
|
13
7
|
tmuxSessionName: zod_1.z.string().min(1),
|
|
14
8
|
projectId: zod_1.z.string().uuid(),
|
|
15
9
|
agentId: zod_1.z.string().uuid().nullable(),
|
|
16
10
|
sessionId: zod_1.z.string().uuid().nullable(),
|
|
11
|
+
};
|
|
12
|
+
const claudeMetaFields = {
|
|
13
|
+
model: zod_1.z.string().max(200).optional(),
|
|
14
|
+
permissionMode: zod_1.z.string().max(100).optional(),
|
|
15
|
+
transcriptPath: zod_1.z.string().max(1000).optional(),
|
|
16
|
+
};
|
|
17
|
+
exports.SessionStartHookSchema = zod_1.z
|
|
18
|
+
.object({
|
|
19
|
+
hookEventName: zod_1.z.literal('SessionStart'),
|
|
20
|
+
source: zod_1.z.string().min(1),
|
|
21
|
+
...claudeMetaFields,
|
|
22
|
+
...injectedFields,
|
|
23
|
+
})
|
|
24
|
+
.strict();
|
|
25
|
+
exports.PreToolUseHookSchema = zod_1.z
|
|
26
|
+
.object({
|
|
27
|
+
hookEventName: zod_1.z.literal('PreToolUse'),
|
|
28
|
+
toolName: zod_1.z.string().min(1),
|
|
29
|
+
toolInput: zod_1.z.record(zod_1.z.unknown()),
|
|
30
|
+
toolUseId: zod_1.z.string().min(1),
|
|
31
|
+
...claudeMetaFields,
|
|
32
|
+
...injectedFields,
|
|
33
|
+
})
|
|
34
|
+
.strict();
|
|
35
|
+
exports.PostToolUseHookSchema = zod_1.z
|
|
36
|
+
.object({
|
|
37
|
+
hookEventName: zod_1.z.literal('PostToolUse'),
|
|
38
|
+
toolName: zod_1.z.string().min(1),
|
|
39
|
+
toolInput: zod_1.z.record(zod_1.z.unknown()),
|
|
40
|
+
toolUseId: zod_1.z.string().min(1),
|
|
41
|
+
toolResponse: zod_1.z.union([zod_1.z.string(), zod_1.z.record(zod_1.z.unknown())]).optional(),
|
|
42
|
+
...claudeMetaFields,
|
|
43
|
+
...injectedFields,
|
|
17
44
|
})
|
|
18
45
|
.strict();
|
|
46
|
+
exports.HookEventSchema = zod_1.z.discriminatedUnion('hookEventName', [
|
|
47
|
+
exports.SessionStartHookSchema,
|
|
48
|
+
exports.PreToolUseHookSchema,
|
|
49
|
+
exports.PostToolUseHookSchema,
|
|
50
|
+
]);
|
|
19
51
|
//# sourceMappingURL=hook-event.dto.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hook-event.dto.js","sourceRoot":"","sources":["../../../../src/modules/hooks/dtos/hook-event.dto.ts"],"names":[],"mappings":";;;AAAA,6BAAwB;
|
|
1
|
+
{"version":3,"file":"hook-event.dto.js","sourceRoot":"","sources":["../../../../src/modules/hooks/dtos/hook-event.dto.ts"],"names":[],"mappings":";;;AAAA,6BAAwB;AAgBxB,MAAM,cAAc,GAAG;IAErB,eAAe,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAElC,eAAe,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAElC,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE;IAE5B,OAAO,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,CAAC,QAAQ,EAAE;IAErC,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,CAAC,QAAQ,EAAE;CAC/B,CAAC;AAGX,MAAM,gBAAgB,GAAG;IAEvB,KAAK,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE;IAErC,cAAc,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE;IAE9C,cAAc,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE;CACvC,CAAC;AAEE,QAAA,sBAAsB,GAAG,OAAC;KACpC,MAAM,CAAC;IACN,aAAa,EAAE,OAAC,CAAC,OAAO,CAAC,cAAc,CAAC;IAExC,MAAM,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IACzB,GAAG,gBAAgB;IACnB,GAAG,cAAc;CAClB,CAAC;KACD,MAAM,EAAE,CAAC;AAEC,QAAA,oBAAoB,GAAG,OAAC;KAClC,MAAM,CAAC;IACN,aAAa,EAAE,OAAC,CAAC,OAAO,CAAC,YAAY,CAAC;IAEtC,QAAQ,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAE3B,SAAS,EAAE,OAAC,CAAC,MAAM,CAAC,OAAC,CAAC,OAAO,EAAE,CAAC;IAEhC,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAC5B,GAAG,gBAAgB;IACnB,GAAG,cAAc;CAClB,CAAC;KACD,MAAM,EAAE,CAAC;AAEC,QAAA,qBAAqB,GAAG,OAAC;KACnC,MAAM,CAAC;IACN,aAAa,EAAE,OAAC,CAAC,OAAO,CAAC,aAAa,CAAC;IACvC,QAAQ,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAC3B,SAAS,EAAE,OAAC,CAAC,MAAM,CAAC,OAAC,CAAC,OAAO,EAAE,CAAC;IAChC,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAE5B,YAAY,EAAE,OAAC,CAAC,KAAK,CAAC,CAAC,OAAC,CAAC,MAAM,EAAE,EAAE,OAAC,CAAC,MAAM,CAAC,OAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE;IACrE,GAAG,gBAAgB;IACnB,GAAG,cAAc;CAClB,CAAC;KACD,MAAM,EAAE,CAAC;AAEC,QAAA,eAAe,GAAG,OAAC,CAAC,kBAAkB,CAAC,eAAe,EAAE;IACnE,8BAAsB;IACtB,4BAAoB;IACpB,6BAAqB;CACtB,CAAC,CAAC"}
|
|
@@ -11,6 +11,7 @@ const common_1 = require("@nestjs/common");
|
|
|
11
11
|
const hooks_controller_1 = require("./controllers/hooks.controller");
|
|
12
12
|
const hooks_service_1 = require("./services/hooks.service");
|
|
13
13
|
const hooks_config_service_1 = require("./services/hooks-config.service");
|
|
14
|
+
const pending_ask_user_question_service_1 = require("./services/pending-ask-user-question.service");
|
|
14
15
|
const storage_module_1 = require("../storage/storage.module");
|
|
15
16
|
const events_core_module_1 = require("../events/events-core.module");
|
|
16
17
|
let HooksModule = class HooksModule {
|
|
@@ -20,8 +21,8 @@ exports.HooksModule = HooksModule = __decorate([
|
|
|
20
21
|
(0, common_1.Module)({
|
|
21
22
|
imports: [storage_module_1.StorageModule, events_core_module_1.EventsCoreModule],
|
|
22
23
|
controllers: [hooks_controller_1.HooksController],
|
|
23
|
-
providers: [hooks_service_1.HooksService, hooks_config_service_1.HooksConfigService],
|
|
24
|
-
exports: [hooks_service_1.HooksService, hooks_config_service_1.HooksConfigService],
|
|
24
|
+
providers: [hooks_service_1.HooksService, hooks_config_service_1.HooksConfigService, pending_ask_user_question_service_1.PendingAskUserQuestionService],
|
|
25
|
+
exports: [hooks_service_1.HooksService, hooks_config_service_1.HooksConfigService, pending_ask_user_question_service_1.PendingAskUserQuestionService],
|
|
25
26
|
})
|
|
26
27
|
], HooksModule);
|
|
27
28
|
//# sourceMappingURL=hooks.module.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.module.js","sourceRoot":"","sources":["../../../src/modules/hooks/hooks.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,qEAAiE;AACjE,4DAAwD;AACxD,0EAAqE;AACrE,8DAA0D;AAC1D,qEAAgE;AAQzD,IAAM,WAAW,GAAjB,MAAM,WAAW;CAAG,CAAA;AAAd,kCAAW;sBAAX,WAAW;IANvB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,8BAAa,EAAE,qCAAgB,CAAC;QAC1C,WAAW,EAAE,CAAC,kCAAe,CAAC;QAC9B,SAAS,EAAE,CAAC,4BAAY,EAAE,yCAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"hooks.module.js","sourceRoot":"","sources":["../../../src/modules/hooks/hooks.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,qEAAiE;AACjE,4DAAwD;AACxD,0EAAqE;AACrE,oGAA6F;AAC7F,8DAA0D;AAC1D,qEAAgE;AAQzD,IAAM,WAAW,GAAjB,MAAM,WAAW;CAAG,CAAA;AAAd,kCAAW;sBAAX,WAAW;IANvB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,8BAAa,EAAE,qCAAgB,CAAC;QAC1C,WAAW,EAAE,CAAC,kCAAe,CAAC;QAC9B,SAAS,EAAE,CAAC,4BAAY,EAAE,yCAAkB,EAAE,iEAA6B,CAAC;QAC5E,OAAO,EAAE,CAAC,4BAAY,EAAE,yCAAkB,EAAE,iEAA6B,CAAC;KAC3E,CAAC;GACW,WAAW,CAAG"}
|
|
@@ -44,7 +44,11 @@ if [ -z "$TMUX_SESSION" ]; then
|
|
|
44
44
|
exit 0
|
|
45
45
|
fi
|
|
46
46
|
|
|
47
|
-
# Build combined payload: Claude Code fields + DevChain env vars
|
|
47
|
+
# Build combined payload: Claude Code fields + DevChain env vars.
|
|
48
|
+
# Tool fields (PreToolUse/PostToolUse) are forwarded with --argjson so the
|
|
49
|
+
# questions OBJECT is preserved (never stringified). tool_response is size-capped
|
|
50
|
+
# (may be string OR object). source/tool fields are added conditionally so each
|
|
51
|
+
# discriminated-union variant stays strict-clean.
|
|
48
52
|
PAYLOAD="$(echo "$INPUT" | jq \\
|
|
49
53
|
--arg hookEventName "$HOOK_EVENT_NAME" \\
|
|
50
54
|
--arg claudeSessionId "$(echo "$INPUT" | jq -r '.session_id // empty')" \\
|
|
@@ -52,22 +56,34 @@ PAYLOAD="$(echo "$INPUT" | jq \\
|
|
|
52
56
|
--arg model "$(echo "$INPUT" | jq -r '.model // empty')" \\
|
|
53
57
|
--arg permissionMode "$(echo "$INPUT" | jq -r '.permission_mode // empty')" \\
|
|
54
58
|
--arg transcriptPath "$(echo "$INPUT" | jq -r '.transcript_path // empty')" \\
|
|
59
|
+
--arg toolName "$(echo "$INPUT" | jq -r '.tool_name // empty')" \\
|
|
60
|
+
--arg toolUseId "$(echo "$INPUT" | jq -r '.tool_use_id // empty')" \\
|
|
61
|
+
--argjson toolInput "$(echo "$INPUT" | jq -c '.tool_input // null')" \\
|
|
62
|
+
--argjson toolResponse "$(echo "$INPUT" | jq -c '
|
|
63
|
+
(.tool_response // null) as \$r
|
|
64
|
+
| if \$r == null then null
|
|
65
|
+
elif ((\$r | tostring | length) > 10000) then {truncated: true, length: (\$r | tostring | length)}
|
|
66
|
+
else \$r end')" \\
|
|
55
67
|
--arg tmuxSessionName "$TMUX_SESSION" \\
|
|
56
68
|
--arg projectId "\${DEVCHAIN_PROJECT_ID:-}" \\
|
|
57
69
|
--arg agentId "\${DEVCHAIN_AGENT_ID:-}" \\
|
|
58
70
|
--arg sessionId "\${DEVCHAIN_SESSION_ID:-}" \\
|
|
59
71
|
'{
|
|
60
|
-
hookEventName:
|
|
61
|
-
claudeSessionId:
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
sessionId: (if $sessionId == "" then null else $sessionId end)
|
|
72
|
+
hookEventName: \$hookEventName,
|
|
73
|
+
claudeSessionId: \$claudeSessionId,
|
|
74
|
+
tmuxSessionName: \$tmuxSessionName,
|
|
75
|
+
projectId: \$projectId,
|
|
76
|
+
agentId: (if \$agentId == "" then null else \$agentId end),
|
|
77
|
+
sessionId: (if \$sessionId == "" then null else \$sessionId end)
|
|
67
78
|
}
|
|
68
|
-
+ (if
|
|
69
|
-
+ (if
|
|
70
|
-
+ (if
|
|
79
|
+
+ (if \$source != "" then {source: \$source} else {} end)
|
|
80
|
+
+ (if \$model != "" then {model: \$model} else {} end)
|
|
81
|
+
+ (if \$permissionMode != "" then {permissionMode: \$permissionMode} else {} end)
|
|
82
|
+
+ (if \$transcriptPath != "" then {transcriptPath: \$transcriptPath} else {} end)
|
|
83
|
+
+ (if \$toolName != "" then {toolName: \$toolName} else {} end)
|
|
84
|
+
+ (if \$toolInput != null then {toolInput: \$toolInput} else {} end)
|
|
85
|
+
+ (if \$toolUseId != "" then {toolUseId: \$toolUseId} else {} end)
|
|
86
|
+
+ (if \$toolResponse != null then {toolResponse: \$toolResponse} else {} end)
|
|
71
87
|
')" || exit 0
|
|
72
88
|
|
|
73
89
|
# POST to DevChain API, capture response
|
|
@@ -164,28 +180,9 @@ let HooksConfigService = class HooksConfigService {
|
|
|
164
180
|
settings.hooks = {};
|
|
165
181
|
}
|
|
166
182
|
const hooks = settings.hooks;
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
const updatedEntries = sessionStartEntries.map((entry) => {
|
|
171
|
-
if (!isMatcherGroup(entry))
|
|
172
|
-
return entry;
|
|
173
|
-
const hasDevchain = entry.hooks?.some((h) => isHookEntry(h) && typeof h.command === 'string' && h.command.includes(devchainMarker));
|
|
174
|
-
if (hasDevchain) {
|
|
175
|
-
devchainGroupFound = true;
|
|
176
|
-
return {
|
|
177
|
-
...entry,
|
|
178
|
-
hooks: [devchainHook],
|
|
179
|
-
};
|
|
180
|
-
}
|
|
181
|
-
return entry;
|
|
182
|
-
});
|
|
183
|
-
if (!devchainGroupFound) {
|
|
184
|
-
updatedEntries.push({
|
|
185
|
-
hooks: [devchainHook],
|
|
186
|
-
});
|
|
187
|
-
}
|
|
188
|
-
hooks.SessionStart = updatedEntries;
|
|
183
|
+
this.mergeHookGroup(hooks, 'SessionStart', undefined, devchainHook);
|
|
184
|
+
this.mergeHookGroup(hooks, 'PreToolUse', 'AskUserQuestion', devchainHook);
|
|
185
|
+
this.mergeHookGroup(hooks, 'PostToolUse', 'AskUserQuestion', devchainHook);
|
|
189
186
|
const output = JSON.stringify(settings, null, 2) + '\n';
|
|
190
187
|
try {
|
|
191
188
|
await (0, promises_1.writeFile)(tempPath, output, { encoding: 'utf-8', mode: SETTINGS_FILE_MODE });
|
|
@@ -201,6 +198,28 @@ let HooksConfigService = class HooksConfigService {
|
|
|
201
198
|
throw error;
|
|
202
199
|
}
|
|
203
200
|
}
|
|
201
|
+
mergeHookGroup(hooks, eventName, matcher, devchainHook) {
|
|
202
|
+
const existing = Array.isArray(hooks[eventName]) ? hooks[eventName] : [];
|
|
203
|
+
const devchainMarker = 'devchain-relay.sh';
|
|
204
|
+
let devchainGroupFound = false;
|
|
205
|
+
const updated = existing.map((entry) => {
|
|
206
|
+
if (!isMatcherGroup(entry))
|
|
207
|
+
return entry;
|
|
208
|
+
const hasDevchain = entry.hooks?.some((h) => isHookEntry(h) && typeof h.command === 'string' && h.command.includes(devchainMarker));
|
|
209
|
+
if (hasDevchain && entry.matcher === matcher) {
|
|
210
|
+
devchainGroupFound = true;
|
|
211
|
+
return {
|
|
212
|
+
...(matcher !== undefined ? { matcher } : {}),
|
|
213
|
+
hooks: [devchainHook],
|
|
214
|
+
};
|
|
215
|
+
}
|
|
216
|
+
return entry;
|
|
217
|
+
});
|
|
218
|
+
if (!devchainGroupFound) {
|
|
219
|
+
updated.push(matcher !== undefined ? { matcher, hooks: [devchainHook] } : { hooks: [devchainHook] });
|
|
220
|
+
}
|
|
221
|
+
hooks[eventName] = updated;
|
|
222
|
+
}
|
|
204
223
|
};
|
|
205
224
|
exports.HooksConfigService = HooksConfigService;
|
|
206
225
|
exports.HooksConfigService = HooksConfigService = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hooks-config.service.js","sourceRoot":"","sources":["../../../../src/modules/hooks/services/hooks-config.service.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA4C;AAC5C,0CAAgF;AAChF,+BAA4B;AAC5B,2DAA8D;AAE9D,MAAM,MAAM,GAAG,IAAA,qBAAY,EAAC,oBAAoB,CAAC,CAAC;AAElD,MAAM,kBAAkB,GAAG,KAAK,CAAC;AACjC,MAAM,gBAAgB,GAAG,KAAK,CAAC;AAiB/B,MAAM,oBAAoB,GAAG
|
|
1
|
+
{"version":3,"file":"hooks-config.service.js","sourceRoot":"","sources":["../../../../src/modules/hooks/services/hooks-config.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
import { type AgentStorage } from '../../storage/interfaces/storage.interface';
|
|
2
2
|
import { EventsService } from '../../events/services/events.service';
|
|
3
3
|
import type { HookEventData, HookEventResponse } from '../dtos/hook-event.dto';
|
|
4
|
+
import { PendingAskUserQuestionService } from './pending-ask-user-question.service';
|
|
4
5
|
export declare class HooksService {
|
|
5
6
|
private readonly storage;
|
|
6
7
|
private readonly events;
|
|
7
|
-
|
|
8
|
+
private readonly pendingAskQuestions;
|
|
9
|
+
constructor(storage: AgentStorage, events: EventsService, pendingAskQuestions: PendingAskUserQuestionService);
|
|
8
10
|
handleHookEvent(data: HookEventData): Promise<HookEventResponse>;
|
|
11
|
+
private handlePreToolUse;
|
|
12
|
+
private handlePostToolUse;
|
|
9
13
|
private handleSessionStart;
|
|
10
14
|
private warnOversizedFields;
|
|
11
15
|
}
|
|
@@ -16,13 +16,16 @@ exports.HooksService = void 0;
|
|
|
16
16
|
const common_1 = require("@nestjs/common");
|
|
17
17
|
const storage_interface_1 = require("../../storage/interfaces/storage.interface");
|
|
18
18
|
const events_service_1 = require("../../events/services/events.service");
|
|
19
|
+
const ask_user_question_dto_1 = require("../dtos/ask-user-question.dto");
|
|
20
|
+
const pending_ask_user_question_service_1 = require("./pending-ask-user-question.service");
|
|
19
21
|
const logger_1 = require("../../../common/logging/logger");
|
|
20
22
|
const logger = (0, logger_1.createLogger)('HooksService');
|
|
21
23
|
const FIELD_WARN_LENGTH = 2000;
|
|
22
24
|
let HooksService = class HooksService {
|
|
23
|
-
constructor(storage, events) {
|
|
25
|
+
constructor(storage, events, pendingAskQuestions) {
|
|
24
26
|
this.storage = storage;
|
|
25
27
|
this.events = events;
|
|
28
|
+
this.pendingAskQuestions = pendingAskQuestions;
|
|
26
29
|
}
|
|
27
30
|
async handleHookEvent(data) {
|
|
28
31
|
const { hookEventName } = data;
|
|
@@ -31,11 +34,73 @@ let HooksService = class HooksService {
|
|
|
31
34
|
switch (hookEventName) {
|
|
32
35
|
case 'SessionStart':
|
|
33
36
|
return this.handleSessionStart(data);
|
|
37
|
+
case 'PreToolUse':
|
|
38
|
+
return this.handlePreToolUse(data);
|
|
39
|
+
case 'PostToolUse':
|
|
40
|
+
return this.handlePostToolUse(data);
|
|
34
41
|
default:
|
|
35
42
|
logger.info({ hookEventName }, 'Unhandled hook event type — returning ok');
|
|
36
43
|
return { ok: true, handled: false, data: {} };
|
|
37
44
|
}
|
|
38
45
|
}
|
|
46
|
+
async handlePreToolUse(data) {
|
|
47
|
+
if (data.toolName !== ask_user_question_dto_1.ASK_USER_QUESTION_TOOL) {
|
|
48
|
+
return { ok: true, handled: false, data: {} };
|
|
49
|
+
}
|
|
50
|
+
if (!data.sessionId) {
|
|
51
|
+
logger.warn({ toolUseId: data.toolUseId }, 'PreToolUse AskUserQuestion without a DevChain sessionId — cannot store pending');
|
|
52
|
+
return { ok: true, handled: false, data: {} };
|
|
53
|
+
}
|
|
54
|
+
const questions = (0, ask_user_question_dto_1.normalizeAskUserQuestions)(data.toolInput);
|
|
55
|
+
if (!questions) {
|
|
56
|
+
logger.warn({ toolUseId: data.toolUseId }, 'PreToolUse AskUserQuestion has malformed questions — skipping store');
|
|
57
|
+
return { ok: true, handled: false, data: {} };
|
|
58
|
+
}
|
|
59
|
+
const entry = this.pendingAskQuestions.set({
|
|
60
|
+
projectId: data.projectId,
|
|
61
|
+
agentId: data.agentId,
|
|
62
|
+
sessionId: data.sessionId,
|
|
63
|
+
claudeSessionId: data.claudeSessionId,
|
|
64
|
+
toolUseId: data.toolUseId,
|
|
65
|
+
questions,
|
|
66
|
+
});
|
|
67
|
+
try {
|
|
68
|
+
await this.events.publish('claude.hooks.ask_user_question.pending', {
|
|
69
|
+
projectId: entry.projectId,
|
|
70
|
+
agentId: entry.agentId,
|
|
71
|
+
sessionId: entry.sessionId,
|
|
72
|
+
claudeSessionId: entry.claudeSessionId,
|
|
73
|
+
toolUseId: entry.toolUseId,
|
|
74
|
+
questions: entry.questions,
|
|
75
|
+
createdAt: entry.createdAt,
|
|
76
|
+
expiresAt: entry.expiresAt,
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
catch (error) {
|
|
80
|
+
logger.error({ error, hookEventName: 'PreToolUse' }, 'Failed to publish ask_user_question.pending — responding ok anyway');
|
|
81
|
+
}
|
|
82
|
+
return { ok: true, handled: true, data: {} };
|
|
83
|
+
}
|
|
84
|
+
async handlePostToolUse(data) {
|
|
85
|
+
if (data.toolName !== ask_user_question_dto_1.ASK_USER_QUESTION_TOOL) {
|
|
86
|
+
return { ok: true, handled: false, data: {} };
|
|
87
|
+
}
|
|
88
|
+
if (!data.sessionId) {
|
|
89
|
+
return { ok: true, handled: false, data: {} };
|
|
90
|
+
}
|
|
91
|
+
const cleared = this.pendingAskQuestions.clearByToolUseId(data.sessionId, data.toolUseId);
|
|
92
|
+
try {
|
|
93
|
+
await this.events.publish('claude.hooks.ask_user_question.resolved', {
|
|
94
|
+
projectId: data.projectId,
|
|
95
|
+
sessionId: data.sessionId,
|
|
96
|
+
toolUseId: data.toolUseId,
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
catch (error) {
|
|
100
|
+
logger.error({ error, hookEventName: 'PostToolUse' }, 'Failed to publish ask_user_question.resolved — responding ok anyway');
|
|
101
|
+
}
|
|
102
|
+
return { ok: true, handled: true, data: { cleared } };
|
|
103
|
+
}
|
|
39
104
|
async handleSessionStart(data) {
|
|
40
105
|
let agentName = null;
|
|
41
106
|
if (data.agentId) {
|
|
@@ -78,6 +143,7 @@ exports.HooksService = HooksService;
|
|
|
78
143
|
exports.HooksService = HooksService = __decorate([
|
|
79
144
|
(0, common_1.Injectable)(),
|
|
80
145
|
__param(0, (0, common_1.Inject)(storage_interface_1.STORAGE_SERVICE)),
|
|
81
|
-
__metadata("design:paramtypes", [Object, events_service_1.EventsService
|
|
146
|
+
__metadata("design:paramtypes", [Object, events_service_1.EventsService,
|
|
147
|
+
pending_ask_user_question_service_1.PendingAskUserQuestionService])
|
|
82
148
|
], HooksService);
|
|
83
149
|
//# sourceMappingURL=hooks.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.service.js","sourceRoot":"","sources":["../../../../src/modules/hooks/services/hooks.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAoD;AACpD,kFAAgG;AAChG,yEAAqE;
|
|
1
|
+
{"version":3,"file":"hooks.service.js","sourceRoot":"","sources":["../../../../src/modules/hooks/services/hooks.service.ts"],"names":[],"mappings":"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"}
|