devchain-cli 0.14.1 → 0.16.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 +11 -8
- package/dist/cli.js +19 -16
- 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/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 +12 -5
- package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.js +209 -54
- 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 +45 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-rpc-crypto.service.js +126 -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/core/core-normal.module.js +2 -9
- package/dist/server/modules/core/core-normal.module.js.map +1 -1
- package/dist/server/modules/core/services/antigravity-trusted-workspaces.module.d.ts +2 -0
- package/dist/server/modules/core/services/antigravity-trusted-workspaces.module.js +21 -0
- package/dist/server/modules/core/services/antigravity-trusted-workspaces.module.js.map +1 -0
- package/dist/server/modules/core/services/antigravity-trusted-workspaces.service.d.ts +21 -0
- package/dist/server/modules/core/services/antigravity-trusted-workspaces.service.js +249 -0
- package/dist/server/modules/core/services/antigravity-trusted-workspaces.service.js.map +1 -0
- package/dist/server/modules/core/services/copilot-auth-probe.module.d.ts +2 -0
- package/dist/server/modules/core/services/copilot-auth-probe.module.js +21 -0
- package/dist/server/modules/core/services/copilot-auth-probe.module.js.map +1 -0
- package/dist/server/modules/core/services/copilot-auth-probe.service.d.ts +7 -0
- package/dist/server/modules/core/services/copilot-auth-probe.service.js +63 -0
- package/dist/server/modules/core/services/copilot-auth-probe.service.js.map +1 -0
- package/dist/server/modules/core/services/copilot-trusted-folders.module.d.ts +2 -0
- package/dist/server/modules/core/services/{gemini-trusted-folders.module.js → copilot-trusted-folders.module.js} +9 -9
- package/dist/server/modules/core/services/copilot-trusted-folders.module.js.map +1 -0
- package/dist/server/modules/core/services/copilot-trusted-folders.service.d.ts +22 -0
- package/dist/server/modules/core/services/copilot-trusted-folders.service.js +228 -0
- package/dist/server/modules/core/services/copilot-trusted-folders.service.js.map +1 -0
- package/dist/server/modules/core/services/preflight.service.d.ts +1 -0
- package/dist/server/modules/core/services/preflight.service.js +35 -3
- package/dist/server/modules/core/services/preflight.service.js.map +1 -1
- package/dist/server/modules/core/services/trust-folders-logic.d.ts +11 -0
- package/dist/server/modules/core/services/trust-folders-logic.js +33 -0
- package/dist/server/modules/core/services/trust-folders-logic.js.map +1 -0
- package/dist/server/modules/e2ee/controllers/e2ee-pairing.controller.d.ts +19 -0
- package/dist/server/modules/e2ee/controllers/e2ee-pairing.controller.js +63 -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 +36 -0
- package/dist/server/modules/e2ee/services/e2ee-device-store.service.js +165 -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 +29 -0
- package/dist/server/modules/e2ee/services/e2ee-pairing.service.js +108 -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 +121 -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/claude.hooks.session.started.d.ts +6 -0
- package/dist/server/modules/events/catalog/claude.hooks.session.started.js +2 -0
- package/dist/server/modules/events/catalog/claude.hooks.session.started.js.map +1 -1
- package/dist/server/modules/events/catalog/index.d.ts +106 -10
- 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.activity.changed.d.ts +2 -2
- package/dist/server/modules/events/catalog/session.transcript.discovered.d.ts +5 -2
- 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/catalog/session.transcript.ended.d.ts +2 -2
- package/dist/server/modules/events/catalog/session.transcript.updated.d.ts +2 -2
- package/dist/server/modules/events/catalog/terminal.watcher.triggered.d.ts +2 -2
- 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 +324 -7
- package/dist/server/modules/hooks/dtos/hook-event.dto.js +57 -9
- package/dist/server/modules/hooks/dtos/hook-event.dto.js.map +1 -1
- package/dist/server/modules/hooks/hooks.module.js +14 -2
- package/dist/server/modules/hooks/hooks.module.js.map +1 -1
- package/dist/server/modules/hooks/services/copilot-hooks-config.service.d.ts +13 -0
- package/dist/server/modules/hooks/services/copilot-hooks-config.service.js +185 -0
- package/dist/server/modules/hooks/services/copilot-hooks-config.service.js.map +1 -0
- 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 +6 -1
- package/dist/server/modules/hooks/services/hooks.service.js +86 -3
- 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/mcp/dtos/mcp.dto.d.ts +2 -2
- package/dist/server/modules/orchestrator/docker/services/docker.service.js +16 -3
- package/dist/server/modules/orchestrator/docker/services/docker.service.js.map +1 -1
- 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/antigravity.adapter.d.ts +22 -0
- package/dist/server/modules/providers/adapters/antigravity.adapter.js +81 -0
- package/dist/server/modules/providers/adapters/antigravity.adapter.js.map +1 -0
- package/dist/server/modules/providers/adapters/capabilities/index.d.ts +2 -2
- package/dist/server/modules/providers/adapters/capabilities/index.js +3 -1
- package/dist/server/modules/providers/adapters/capabilities/index.js.map +1 -1
- package/dist/server/modules/providers/adapters/capabilities/type-guards.d.ts +16 -1
- package/dist/server/modules/providers/adapters/capabilities/type-guards.js +8 -0
- package/dist/server/modules/providers/adapters/capabilities/type-guards.js.map +1 -1
- 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/codex.adapter.d.ts +1 -0
- package/dist/server/modules/providers/adapters/codex.adapter.js +10 -4
- package/dist/server/modules/providers/adapters/codex.adapter.js.map +1 -1
- package/dist/server/modules/providers/adapters/copilot.adapter.d.ts +31 -0
- package/dist/server/modules/providers/adapters/copilot.adapter.js +122 -0
- package/dist/server/modules/providers/adapters/copilot.adapter.js.map +1 -0
- package/dist/server/modules/providers/adapters/index.d.ts +1 -1
- package/dist/server/modules/providers/adapters/index.js +1 -1
- package/dist/server/modules/providers/adapters/index.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.factory.d.ts +3 -2
- package/dist/server/modules/providers/adapters/provider-adapter.factory.js +8 -5
- package/dist/server/modules/providers/adapters/provider-adapter.factory.js.map +1 -1
- package/dist/server/modules/providers/adapters/provider-adapter.interface.d.ts +6 -0
- package/dist/server/modules/providers/adapters/provider-adapters.module.js +19 -4
- package/dist/server/modules/providers/adapters/provider-adapters.module.js.map +1 -1
- package/dist/server/modules/providers/controllers/provider-models.controller.js +3 -2
- package/dist/server/modules/providers/controllers/provider-models.controller.js.map +1 -1
- 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/providers.module.js +1 -0
- package/dist/server/modules/providers/providers.module.js.map +1 -1
- package/dist/server/modules/providers/services/mcp-registration/antigravity-mcp-registration.adapter.d.ts +17 -0
- package/dist/server/modules/providers/services/mcp-registration/antigravity-mcp-registration.adapter.js +264 -0
- package/dist/server/modules/providers/services/mcp-registration/antigravity-mcp-registration.adapter.js.map +1 -0
- package/dist/server/modules/providers/services/mcp-registration/cli-mcp-registration.adapter.js +5 -6
- package/dist/server/modules/providers/services/mcp-registration/cli-mcp-registration.adapter.js.map +1 -1
- package/dist/server/modules/providers/services/mcp-registration/index.d.ts +1 -0
- package/dist/server/modules/providers/services/mcp-registration/index.js +3 -1
- package/dist/server/modules/providers/services/mcp-registration/index.js.map +1 -1
- package/dist/server/modules/providers/services/mcp-registration/mcp-registration.port.d.ts +3 -1
- package/dist/server/modules/providers/services/mcp-registration/mcp-registration.port.js +6 -1
- package/dist/server/modules/providers/services/mcp-registration/mcp-registration.port.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/seeders/seeders/0009_seed_remove_gemini_provider.d.ts +3 -0
- package/dist/server/modules/seeders/seeders/0009_seed_remove_gemini_provider.js +64 -0
- package/dist/server/modules/seeders/seeders/0009_seed_remove_gemini_provider.js.map +1 -0
- package/dist/server/modules/seeders/services/data-seeder.service.js +2 -0
- package/dist/server/modules/seeders/services/data-seeder.service.js.map +1 -1
- package/dist/server/modules/session-reader/__fixtures__/antigravity-fixture-db.d.ts +12 -0
- package/dist/server/modules/session-reader/__fixtures__/antigravity-fixture-db.js +41 -0
- package/dist/server/modules/session-reader/__fixtures__/antigravity-fixture-db.js.map +1 -0
- 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/antigravity-session-reader.adapter.d.ts +30 -0
- package/dist/server/modules/session-reader/adapters/antigravity-session-reader.adapter.js +268 -0
- package/dist/server/modules/session-reader/adapters/antigravity-session-reader.adapter.js.map +1 -0
- package/dist/server/modules/session-reader/adapters/{gemini-session-reader.adapter.d.ts → copilot-session-reader.adapter.d.ts} +4 -5
- package/dist/server/modules/session-reader/adapters/{gemini-session-reader.adapter.js → copilot-session-reader.adapter.js} +35 -68
- package/dist/server/modules/session-reader/adapters/copilot-session-reader.adapter.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.factory.js.map +1 -1
- 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 +513 -44
- package/dist/server/modules/session-reader/dtos/unified-message.types.d.ts +1 -0
- package/dist/server/modules/session-reader/dtos/unified-session.types.d.ts +6 -0
- package/dist/server/modules/session-reader/dtos/unified-session.types.js.map +1 -1
- package/dist/server/modules/session-reader/parsers/antigravity-jsonl.parser.d.ts +16 -0
- package/dist/server/modules/session-reader/parsers/antigravity-jsonl.parser.js +307 -0
- package/dist/server/modules/session-reader/parsers/antigravity-jsonl.parser.js.map +1 -0
- 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/parsers/{gemini-json.parser.d.ts → copilot-jsonl.parser.d.ts} +4 -3
- package/dist/server/modules/session-reader/parsers/copilot-jsonl.parser.js +432 -0
- package/dist/server/modules/session-reader/parsers/copilot-jsonl.parser.js.map +1 -0
- package/dist/server/modules/session-reader/readers/antigravity-metrics.reader.d.ts +25 -0
- package/dist/server/modules/session-reader/readers/antigravity-metrics.reader.js +142 -0
- package/dist/server/modules/session-reader/readers/antigravity-metrics.reader.js.map +1 -0
- package/dist/server/modules/session-reader/readers/antigravity-model-pricing.d.ts +6 -0
- package/dist/server/modules/session-reader/readers/antigravity-model-pricing.js +35 -0
- package/dist/server/modules/session-reader/readers/antigravity-model-pricing.js.map +1 -0
- package/dist/server/modules/session-reader/readers/antigravity-transcript.reader.d.ts +24 -0
- package/dist/server/modules/session-reader/readers/antigravity-transcript.reader.js +80 -0
- package/dist/server/modules/session-reader/readers/antigravity-transcript.reader.js.map +1 -0
- package/dist/server/modules/session-reader/readers/copilot-model-pricing.d.ts +10 -0
- package/dist/server/modules/session-reader/readers/copilot-model-pricing.js +37 -0
- package/dist/server/modules/session-reader/readers/copilot-model-pricing.js.map +1 -0
- 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/readers/protobuf-wire.d.ts +13 -0
- package/dist/server/modules/session-reader/readers/protobuf-wire.js +94 -0
- package/dist/server/modules/session-reader/readers/protobuf-wire.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 +3 -1
- 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 +4 -0
- package/dist/server/modules/session-reader/services/transcript-persistence.listener.js +109 -8
- 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 +7 -3
- package/dist/server/modules/session-reader/session-reader.module.js +21 -7
- 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.d.ts +2 -0
- package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.js +14 -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 +12 -2
- package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.js +12 -3
- 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.d.ts +5 -1
- package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.js +44 -7
- 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 +3 -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/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/events/event-fields-catalog.js +5 -3
- package/dist/server/modules/subscribers/events/event-fields-catalog.js.map +1 -1
- package/dist/server/modules/subscribers/services/automation-scheduler.service.js.map +1 -1
- package/dist/server/modules/teams/services/teams.service.d.ts +28 -2
- package/dist/server/modules/teams/services/teams.service.js +175 -0
- 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/terminal/gateways/terminal.gateway.d.ts +5 -0
- package/dist/server/modules/terminal/gateways/terminal.gateway.js +38 -0
- 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-session/terminal-session.d.ts +2 -0
- package/dist/server/modules/terminal/services/terminal-session/terminal-session.js +10 -4
- 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/templates/3-agents-dev.json +198 -160
- package/dist/server/templates/teams-dev.json +285 -225
- package/dist/server/tsconfig.tsbuildinfo +1 -1
- package/dist/server/ui/assets/{ReviewDetailPage-CobRKQBn.js → ReviewDetailPage-BDisSE9l.js} +1 -1
- package/dist/server/ui/assets/{ReviewsPage-Bb6ZmriH.js → ReviewsPage-3puoJiOQ.js} +1 -1
- package/dist/server/ui/assets/index-CzMrWNAV.css +32 -0
- package/dist/server/ui/assets/index-zlQ1ekQ2.js +1103 -0
- package/dist/server/ui/assets/{useReviewSubscription-DzaIaXy7.js → useReviewSubscription-wTrdkdi0.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 +198 -160
- package/dist/templates/teams-dev.json +285 -225
- package/package.json +31 -8
- package/dist/server/modules/core/services/gemini-trusted-folders.module.d.ts +0 -2
- package/dist/server/modules/core/services/gemini-trusted-folders.module.js.map +0 -1
- package/dist/server/modules/core/services/gemini-trusted-folders.service.d.ts +0 -26
- package/dist/server/modules/core/services/gemini-trusted-folders.service.js +0 -181
- package/dist/server/modules/core/services/gemini-trusted-folders.service.js.map +0 -1
- package/dist/server/modules/providers/adapters/gemini.adapter.d.ts +0 -27
- package/dist/server/modules/providers/adapters/gemini.adapter.js +0 -119
- package/dist/server/modules/providers/adapters/gemini.adapter.js.map +0 -1
- package/dist/server/modules/session-reader/adapters/gemini-session-reader.adapter.js.map +0 -1
- package/dist/server/modules/session-reader/parsers/gemini-json.parser.js +0 -380
- package/dist/server/modules/session-reader/parsers/gemini-json.parser.js.map +0 -1
- package/dist/server/ui/assets/index-BV_-Jlz8.js +0 -1095
- package/dist/server/ui/assets/index-C_ZOt0it.css +0 -32
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.CopilotHooksConfigService = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const os_1 = require("os");
|
|
12
|
+
const path_1 = require("path");
|
|
13
|
+
const promises_1 = require("fs/promises");
|
|
14
|
+
const crypto_1 = require("crypto");
|
|
15
|
+
const logger_1 = require("../../../common/logging/logger");
|
|
16
|
+
const logger = (0, logger_1.createLogger)('CopilotHooksConfigService');
|
|
17
|
+
const CONFIG_FILE_MODE = 0o600;
|
|
18
|
+
const SCRIPT_FILE_MODE = 0o755;
|
|
19
|
+
const HOOK_TIMEOUT_SEC = 10;
|
|
20
|
+
const RELAY_SCRIPT_CONTENT = `#!/bin/bash
|
|
21
|
+
# DevChain Copilot relay — bridges GitHub Copilot CLI lifecycle hooks to DevChain.
|
|
22
|
+
# Auto-generated by DevChain. Do not edit manually.
|
|
23
|
+
# Requires: jq, curl
|
|
24
|
+
|
|
25
|
+
set -euo pipefail
|
|
26
|
+
|
|
27
|
+
# ── Blast-radius guard ───────────────────────────────────────────────────────
|
|
28
|
+
# This config is USER-LEVEL, so copilot runs it for EVERY copilot session. Exit
|
|
29
|
+
# instantly (no read, no POST) unless this is a devchain-launched session.
|
|
30
|
+
if [ -z "\${DEVCHAIN_API_URL:-}" ]; then exit 0; fi
|
|
31
|
+
if [ -z "\${DEVCHAIN_SESSION_ID:-}" ]; then exit 0; fi
|
|
32
|
+
|
|
33
|
+
# ── Tooling guard (fail-open) ────────────────────────────────────────────────
|
|
34
|
+
# The relay must NEVER block copilot: if jq/curl are missing, no-op (exit 0)
|
|
35
|
+
# instead of dying under set -euo pipefail.
|
|
36
|
+
command -v jq >/dev/null 2>&1 || exit 0
|
|
37
|
+
command -v curl >/dev/null 2>&1 || exit 0
|
|
38
|
+
|
|
39
|
+
# The hook event name is supplied as the first arg by devchain.json.
|
|
40
|
+
HOOK_EVENT_NAME="\${1:-}"
|
|
41
|
+
case "$HOOK_EVENT_NAME" in
|
|
42
|
+
SessionStart|Stop) ;;
|
|
43
|
+
*) exit 0 ;;
|
|
44
|
+
esac
|
|
45
|
+
|
|
46
|
+
INPUT="$(cat)" || exit 0
|
|
47
|
+
|
|
48
|
+
# tmux session name (prefer the injected value; fall back to a live query).
|
|
49
|
+
TMUX_SESSION="\${DEVCHAIN_TMUX_SESSION_NAME:-}"
|
|
50
|
+
if [ -z "$TMUX_SESSION" ] && command -v tmux >/dev/null 2>&1; then
|
|
51
|
+
TMUX_SESSION="$(tmux display-message -p '#S' 2>/dev/null || true)"
|
|
52
|
+
fi
|
|
53
|
+
if [ -z "$TMUX_SESSION" ]; then exit 0; fi
|
|
54
|
+
|
|
55
|
+
# ── Provider-payload extraction (fail-open) ──────────────────────────────────
|
|
56
|
+
# EVERY jq read is guarded with "|| exit 0": malformed hook JSON (or any jq
|
|
57
|
+
# hiccup) no-ops silently — it must never crash under set -euo pipefail, and must
|
|
58
|
+
# never POST partial data. Fields are extracted ONCE here, then handed to the
|
|
59
|
+
# builder below as plain --arg values (no nested command substitution).
|
|
60
|
+
SESSION_ID="$(echo "$INPUT" | jq -r '.session_id // empty')" || exit 0
|
|
61
|
+
MODEL="$(echo "$INPUT" | jq -r '.model // empty')" || exit 0
|
|
62
|
+
TRANSCRIPT_PATH="$(echo "$INPUT" | jq -r '.transcript_path // empty')" || exit 0
|
|
63
|
+
|
|
64
|
+
# 'source' belongs ONLY to SessionStart (DTO is .strict()). It is required there,
|
|
65
|
+
# so default to "startup" — a lifecycle confirmation must never be dropped on a
|
|
66
|
+
# technicality (copilot does send a source; this is just a safety net).
|
|
67
|
+
SOURCE=""
|
|
68
|
+
if [ "$HOOK_EVENT_NAME" = "SessionStart" ]; then
|
|
69
|
+
SOURCE="$(echo "$INPUT" | jq -r '.source // empty')" || exit 0
|
|
70
|
+
if [ -z "$SOURCE" ]; then SOURCE="startup"; fi
|
|
71
|
+
fi
|
|
72
|
+
|
|
73
|
+
# 'stopReason' belongs ONLY to Stop (kept off SessionStart to stay strict-clean).
|
|
74
|
+
STOP_REASON=""
|
|
75
|
+
if [ "$HOOK_EVENT_NAME" = "Stop" ]; then
|
|
76
|
+
STOP_REASON="$(echo "$INPUT" | jq -r '.stop_reason // empty')" || exit 0
|
|
77
|
+
fi
|
|
78
|
+
|
|
79
|
+
# Normalize copilot's snake_case payload into DevChain's hook-event shape.
|
|
80
|
+
# providerName=copilot + providerSessionId (from session_id) select the
|
|
81
|
+
# provider-neutral ingestion path; sessionId/projectId/agentId come from the
|
|
82
|
+
# injected DEVCHAIN_* env. Each optional key is added conditionally so both the
|
|
83
|
+
# SessionStart and Stop .strict() variants stay clean.
|
|
84
|
+
PAYLOAD="$(jq -n \\
|
|
85
|
+
--arg hookEventName "$HOOK_EVENT_NAME" \\
|
|
86
|
+
--arg providerName "copilot" \\
|
|
87
|
+
--arg providerSessionId "$SESSION_ID" \\
|
|
88
|
+
--arg source "$SOURCE" \\
|
|
89
|
+
--arg model "$MODEL" \\
|
|
90
|
+
--arg transcriptPath "$TRANSCRIPT_PATH" \\
|
|
91
|
+
--arg stopReason "$STOP_REASON" \\
|
|
92
|
+
--arg tmuxSessionName "$TMUX_SESSION" \\
|
|
93
|
+
--arg projectId "\${DEVCHAIN_PROJECT_ID:-}" \\
|
|
94
|
+
--arg agentId "\${DEVCHAIN_AGENT_ID:-}" \\
|
|
95
|
+
--arg sessionId "\${DEVCHAIN_SESSION_ID:-}" \\
|
|
96
|
+
'{
|
|
97
|
+
hookEventName: \$hookEventName,
|
|
98
|
+
providerName: \$providerName,
|
|
99
|
+
tmuxSessionName: \$tmuxSessionName,
|
|
100
|
+
projectId: \$projectId,
|
|
101
|
+
agentId: (if \$agentId == "" then null else \$agentId end),
|
|
102
|
+
sessionId: (if \$sessionId == "" then null else \$sessionId end)
|
|
103
|
+
}
|
|
104
|
+
+ (if \$providerSessionId != "" then {providerSessionId: \$providerSessionId} else {} end)
|
|
105
|
+
+ (if \$source != "" then {source: \$source} else {} end)
|
|
106
|
+
+ (if \$model != "" then {model: \$model} else {} end)
|
|
107
|
+
+ (if \$transcriptPath != "" then {transcriptPath: \$transcriptPath} else {} end)
|
|
108
|
+
+ (if \$stopReason != "" then {stopReason: \$stopReason} else {} end)
|
|
109
|
+
')" || exit 0
|
|
110
|
+
|
|
111
|
+
# Fire-and-forget POST. Fail-open: any curl error exits 0 so copilot never blocks.
|
|
112
|
+
curl -s -f -X POST \\
|
|
113
|
+
-H "Content-Type: application/json" \\
|
|
114
|
+
-d "$PAYLOAD" \\
|
|
115
|
+
"\${DEVCHAIN_API_URL}/api/hooks/events" \\
|
|
116
|
+
--max-time 10 \\
|
|
117
|
+
>/dev/null 2>&1 || exit 0
|
|
118
|
+
|
|
119
|
+
exit 0
|
|
120
|
+
`;
|
|
121
|
+
let CopilotHooksConfigService = class CopilotHooksConfigService {
|
|
122
|
+
constructor() {
|
|
123
|
+
this.providerName = 'copilot';
|
|
124
|
+
}
|
|
125
|
+
get hooksDir() {
|
|
126
|
+
return (0, path_1.join)((0, os_1.homedir)(), '.copilot', 'hooks');
|
|
127
|
+
}
|
|
128
|
+
get relayScriptPath() {
|
|
129
|
+
return (0, path_1.join)(this.hooksDir, 'devchain-relay.sh');
|
|
130
|
+
}
|
|
131
|
+
get configPath() {
|
|
132
|
+
return (0, path_1.join)(this.hooksDir, 'devchain.json');
|
|
133
|
+
}
|
|
134
|
+
async ensureHooksConfig(_projectRootPath) {
|
|
135
|
+
try {
|
|
136
|
+
await (0, promises_1.mkdir)(this.hooksDir, { recursive: true, mode: 0o700 });
|
|
137
|
+
await this.materializeRelayScript();
|
|
138
|
+
await this.writeHookConfig();
|
|
139
|
+
logger.info('Copilot hooks config ensured successfully');
|
|
140
|
+
}
|
|
141
|
+
catch (error) {
|
|
142
|
+
logger.error({ error }, 'Failed to ensure copilot hooks config (non-fatal)');
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
async materializeRelayScript() {
|
|
146
|
+
await this.atomicWrite(this.relayScriptPath, RELAY_SCRIPT_CONTENT, SCRIPT_FILE_MODE);
|
|
147
|
+
await (0, promises_1.chmod)(this.relayScriptPath, SCRIPT_FILE_MODE);
|
|
148
|
+
logger.debug({ scriptPath: this.relayScriptPath }, 'Copilot relay script materialized');
|
|
149
|
+
}
|
|
150
|
+
async writeHookConfig() {
|
|
151
|
+
const quotedRelay = `"${this.relayScriptPath}"`;
|
|
152
|
+
const config = {
|
|
153
|
+
version: 1,
|
|
154
|
+
hooks: {
|
|
155
|
+
SessionStart: [
|
|
156
|
+
{ type: 'command', bash: `${quotedRelay} SessionStart`, timeoutSec: HOOK_TIMEOUT_SEC },
|
|
157
|
+
],
|
|
158
|
+
Stop: [{ type: 'command', bash: `${quotedRelay} Stop`, timeoutSec: HOOK_TIMEOUT_SEC }],
|
|
159
|
+
},
|
|
160
|
+
};
|
|
161
|
+
const output = JSON.stringify(config, null, 2) + '\n';
|
|
162
|
+
await this.atomicWrite(this.configPath, output, CONFIG_FILE_MODE);
|
|
163
|
+
logger.debug({ configPath: this.configPath }, 'Copilot hook config written');
|
|
164
|
+
}
|
|
165
|
+
async atomicWrite(filePath, content, mode) {
|
|
166
|
+
const tmpPath = `${filePath}.tmp.${process.pid}.${(0, crypto_1.randomBytes)(8).toString('hex')}`;
|
|
167
|
+
try {
|
|
168
|
+
await (0, promises_1.writeFile)(tmpPath, content, { encoding: 'utf-8', mode });
|
|
169
|
+
await (0, promises_1.rename)(tmpPath, filePath);
|
|
170
|
+
}
|
|
171
|
+
catch (error) {
|
|
172
|
+
try {
|
|
173
|
+
await (0, promises_1.unlink)(tmpPath);
|
|
174
|
+
}
|
|
175
|
+
catch {
|
|
176
|
+
}
|
|
177
|
+
throw error;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
};
|
|
181
|
+
exports.CopilotHooksConfigService = CopilotHooksConfigService;
|
|
182
|
+
exports.CopilotHooksConfigService = CopilotHooksConfigService = __decorate([
|
|
183
|
+
(0, common_1.Injectable)()
|
|
184
|
+
], CopilotHooksConfigService);
|
|
185
|
+
//# sourceMappingURL=copilot-hooks-config.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"copilot-hooks-config.service.js","sourceRoot":"","sources":["../../../../src/modules/hooks/services/copilot-hooks-config.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -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":";;;;;;;;;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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+F5B,CAAC;AAkBK,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAM7B,KAAK,CAAC,iBAAiB,CAAC,eAAuB;QAC7C,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,sBAAsB,CAAC,eAAe,CAAC,CAAC;YACnD,MAAM,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC;YAC/C,MAAM,CAAC,IAAI,CAAC,EAAE,eAAe,EAAE,EAAE,mCAAmC,CAAC,CAAC;QACxE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,eAAe,EAAE,EAAE,2CAA2C,CAAC,CAAC;QACxF,CAAC;IACH,CAAC;IAMO,KAAK,CAAC,sBAAsB,CAAC,eAAuB;QAC1D,MAAM,QAAQ,GAAG,IAAA,WAAI,EAAC,eAAe,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAC3D,MAAM,UAAU,GAAG,IAAA,WAAI,EAAC,QAAQ,EAAE,mBAAmB,CAAC,CAAC;QACvD,MAAM,QAAQ,GAAG,GAAG,UAAU,QAAQ,OAAO,CAAC,GAAG,IAAI,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;QAElE,MAAM,IAAA,gBAAK,EAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAE3C,IAAI,CAAC;YACH,MAAM,IAAA,oBAAS,EAAC,QAAQ,EAAE,oBAAoB,EAAE;gBAC9C,QAAQ,EAAE,OAAO;gBACjB,IAAI,EAAE,gBAAgB;aACvB,CAAC,CAAC;YACH,MAAM,IAAA,iBAAM,EAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;YAEnC,MAAM,IAAA,gBAAK,EAAC,UAAU,EAAE,gBAAgB,CAAC,CAAC;YAC1C,MAAM,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE,EAAE,2BAA2B,CAAC,CAAC;QAC5D,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC;gBACH,MAAM,IAAA,iBAAM,EAAC,QAAQ,CAAC,CAAC;YACzB,CAAC;YAAC,MAAM,CAAC;YAET,CAAC;YACD,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAOO,KAAK,CAAC,kBAAkB,CAAC,eAAuB;QACtD,MAAM,WAAW,GAAG,IAAA,WAAI,EAAC,eAAe,EAAE,SAAS,CAAC,CAAC;QACrD,MAAM,YAAY,GAAG,IAAA,WAAI,EAAC,WAAW,EAAE,qBAAqB,CAAC,CAAC;QAC9D,MAAM,QAAQ,GAAG,GAAG,YAAY,QAAQ,OAAO,CAAC,GAAG,IAAI,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;QACpE,MAAM,eAAe,GAAG,IAAA,WAAI,EAAC,eAAe,EAAE,SAAS,EAAE,OAAO,EAAE,mBAAmB,CAAC,CAAC;QAEvF,MAAM,IAAA,gBAAK,EAAC,WAAW,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAG9C,IAAI,QAA6B,CAAC;QAClC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAA,mBAAQ,EAAC,YAAY,EAAE,OAAO,CAAC,CAAC;YACtD,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC/B,IAAI,OAAO,QAAQ,KAAK,QAAQ,IAAI,QAAQ,KAAK,IAAI,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACjF,MAAM,CAAC,IAAI,CACT,EAAE,YAAY,EAAE,EAChB,8DAA8D,CAC/D,CAAC;gBACF,QAAQ,GAAG,EAAE,CAAC;YAChB,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAK,KAA+B,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;gBACvD,QAAQ,GAAG,EAAE,CAAC;YAChB,CAAC;iBAAM,IAAI,KAAK,YAAY,WAAW,EAAE,CAAC;gBACxC,MAAM,CAAC,IAAI,CAAC,EAAE,YAAY,EAAE,EAAE,sDAAsD,CAAC,CAAC;gBACtF,QAAQ,GAAG,EAAE,CAAC;YAChB,CAAC;iBAAM,CAAC;gBACN,MAAM,KAAK,CAAC;YACd,CAAC;QACH,CAAC;QAGD,MAAM,YAAY,GAAG;YACnB,IAAI,EAAE,SAAkB;YACxB,OAAO,EAAE,IAAI,eAAe,GAAG;YAC/B,OAAO,EAAE,EAAE;SACZ,CAAC;QAGF,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,OAAO,QAAQ,CAAC,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC1D,QAAQ,CAAC,KAAK,GAAG,EAAE,CAAC;QACtB,CAAC;QAKD,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAgC,CAAC;QACxD,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,YAAY,CAAC,CAAC;QACpE,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,YAAY,EAAE,iBAAiB,EAAE,YAAY,CAAC,CAAC;QAC1E,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,aAAa,EAAE,iBAAiB,EAAE,YAAY,CAAC,CAAC;QAG3E,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC;QACxD,IAAI,CAAC;YACH,MAAM,IAAA,oBAAS,EAAC,QAAQ,EAAE,MAAM,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC,CAAC;YACnF,MAAM,IAAA,iBAAM,EAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;YACrC,MAAM,CAAC,KAAK,CAAC,EAAE,YAAY,EAAE,EAAE,uBAAuB,CAAC,CAAC;QAC1D,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC;gBACH,MAAM,IAAA,iBAAM,EAAC,QAAQ,CAAC,CAAC;YACzB,CAAC;YAAC,MAAM,CAAC;YAET,CAAC;YACD,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAUO,cAAc,CACpB,KAA8B,EAC9B,SAAiB,EACjB,OAA2B,EAC3B,YAAmE;QAEnE,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAE,KAAK,CAAC,SAAS,CAAe,CAAC,CAAC,CAAC,EAAE,CAAC;QACxF,MAAM,cAAc,GAAG,mBAAmB,CAAC;QAC3C,IAAI,kBAAkB,GAAG,KAAK,CAAC;QAE/B,MAAM,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAc,EAAE,EAAE;YAC9C,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;gBAAE,OAAO,KAAK,CAAC;YACzC,MAAM,WAAW,GAAG,KAAK,CAAC,KAAK,EAAE,IAAI,CACnC,CAAC,CAAU,EAAE,EAAE,CACb,WAAW,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,CAAC,OAAO,KAAK,QAAQ,IAAI,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,CACxF,CAAC;YACF,IAAI,WAAW,IAAI,KAAK,CAAC,OAAO,KAAK,OAAO,EAAE,CAAC;gBAC7C,kBAAkB,GAAG,IAAI,CAAC;gBAC1B,OAAO;oBACL,GAAG,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;oBAC7C,KAAK,EAAE,CAAC,YAAY,CAAC;iBACtB,CAAC;YACJ,CAAC;YACD,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,kBAAkB,EAAE,CAAC;YACxB,OAAO,CAAC,IAAI,CACV,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,YAAY,CAAC,EAAE,CACvF,CAAC;QACJ,CAAC;QAED,KAAK,CAAC,SAAS,CAAC,GAAG,OAAO,CAAC;IAC7B,CAAC;CACF,CAAA;AAhKY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,mBAAU,GAAE;GACA,kBAAkB,CAgK9B;AAED,SAAS,cAAc,CAAC,KAAc;IACpC,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;AAC9E,CAAC;AAED,SAAS,WAAW,CAAC,KAAc;IACjC,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;AAC9E,CAAC"}
|
|
@@ -1,11 +1,16 @@
|
|
|
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 handleStop;
|
|
12
|
+
private handlePreToolUse;
|
|
13
|
+
private handlePostToolUse;
|
|
9
14
|
private handleSessionStart;
|
|
10
15
|
private warnOversizedFields;
|
|
11
16
|
}
|
|
@@ -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,83 @@ let HooksService = class HooksService {
|
|
|
31
34
|
switch (hookEventName) {
|
|
32
35
|
case 'SessionStart':
|
|
33
36
|
return this.handleSessionStart(data);
|
|
37
|
+
case 'Stop':
|
|
38
|
+
return this.handleStop(data);
|
|
39
|
+
case 'PreToolUse':
|
|
40
|
+
return this.handlePreToolUse(data);
|
|
41
|
+
case 'PostToolUse':
|
|
42
|
+
return this.handlePostToolUse(data);
|
|
34
43
|
default:
|
|
35
44
|
logger.info({ hookEventName }, 'Unhandled hook event type — returning ok');
|
|
36
45
|
return { ok: true, handled: false, data: {} };
|
|
37
46
|
}
|
|
38
47
|
}
|
|
48
|
+
async handleStop(data) {
|
|
49
|
+
logger.debug({
|
|
50
|
+
providerName: data.providerName ?? 'claude',
|
|
51
|
+
sessionId: data.sessionId,
|
|
52
|
+
stopReason: data.stopReason,
|
|
53
|
+
}, 'Stop hook received — final-metrics handling deferred to a later phase');
|
|
54
|
+
return { ok: true, handled: false, data: {} };
|
|
55
|
+
}
|
|
56
|
+
async handlePreToolUse(data) {
|
|
57
|
+
if (data.toolName !== ask_user_question_dto_1.ASK_USER_QUESTION_TOOL) {
|
|
58
|
+
return { ok: true, handled: false, data: {} };
|
|
59
|
+
}
|
|
60
|
+
if (!data.sessionId) {
|
|
61
|
+
logger.warn({ toolUseId: data.toolUseId }, 'PreToolUse AskUserQuestion without a DevChain sessionId — cannot store pending');
|
|
62
|
+
return { ok: true, handled: false, data: {} };
|
|
63
|
+
}
|
|
64
|
+
const questions = (0, ask_user_question_dto_1.normalizeAskUserQuestions)(data.toolInput);
|
|
65
|
+
if (!questions) {
|
|
66
|
+
logger.warn({ toolUseId: data.toolUseId }, 'PreToolUse AskUserQuestion has malformed questions — skipping store');
|
|
67
|
+
return { ok: true, handled: false, data: {} };
|
|
68
|
+
}
|
|
69
|
+
const entry = this.pendingAskQuestions.set({
|
|
70
|
+
projectId: data.projectId,
|
|
71
|
+
agentId: data.agentId,
|
|
72
|
+
sessionId: data.sessionId,
|
|
73
|
+
claudeSessionId: data.claudeSessionId,
|
|
74
|
+
toolUseId: data.toolUseId,
|
|
75
|
+
questions,
|
|
76
|
+
});
|
|
77
|
+
try {
|
|
78
|
+
await this.events.publish('claude.hooks.ask_user_question.pending', {
|
|
79
|
+
projectId: entry.projectId,
|
|
80
|
+
agentId: entry.agentId,
|
|
81
|
+
sessionId: entry.sessionId,
|
|
82
|
+
claudeSessionId: entry.claudeSessionId,
|
|
83
|
+
toolUseId: entry.toolUseId,
|
|
84
|
+
questions: entry.questions,
|
|
85
|
+
createdAt: entry.createdAt,
|
|
86
|
+
expiresAt: entry.expiresAt,
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
catch (error) {
|
|
90
|
+
logger.error({ error, hookEventName: 'PreToolUse' }, 'Failed to publish ask_user_question.pending — responding ok anyway');
|
|
91
|
+
}
|
|
92
|
+
return { ok: true, handled: true, data: {} };
|
|
93
|
+
}
|
|
94
|
+
async handlePostToolUse(data) {
|
|
95
|
+
if (data.toolName !== ask_user_question_dto_1.ASK_USER_QUESTION_TOOL) {
|
|
96
|
+
return { ok: true, handled: false, data: {} };
|
|
97
|
+
}
|
|
98
|
+
if (!data.sessionId) {
|
|
99
|
+
return { ok: true, handled: false, data: {} };
|
|
100
|
+
}
|
|
101
|
+
const cleared = this.pendingAskQuestions.clearByToolUseId(data.sessionId, data.toolUseId);
|
|
102
|
+
try {
|
|
103
|
+
await this.events.publish('claude.hooks.ask_user_question.resolved', {
|
|
104
|
+
projectId: data.projectId,
|
|
105
|
+
sessionId: data.sessionId,
|
|
106
|
+
toolUseId: data.toolUseId,
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
catch (error) {
|
|
110
|
+
logger.error({ error, hookEventName: 'PostToolUse' }, 'Failed to publish ask_user_question.resolved — responding ok anyway');
|
|
111
|
+
}
|
|
112
|
+
return { ok: true, handled: true, data: { cleared } };
|
|
113
|
+
}
|
|
39
114
|
async handleSessionStart(data) {
|
|
40
115
|
let agentName = null;
|
|
41
116
|
if (data.agentId) {
|
|
@@ -47,9 +122,16 @@ let HooksService = class HooksService {
|
|
|
47
122
|
logger.warn({ agentId: data.agentId, error }, 'Failed to resolve agent name — continuing without it');
|
|
48
123
|
}
|
|
49
124
|
}
|
|
125
|
+
const providerSessionId = data.claudeSessionId ?? data.providerSessionId;
|
|
126
|
+
if (!providerSessionId) {
|
|
127
|
+
logger.warn({ projectId: data.projectId, providerName: data.providerName ?? 'claude' }, 'SessionStart hook missing both claudeSessionId and providerSessionId — skipping publish');
|
|
128
|
+
return { ok: true, handled: true, data: {} };
|
|
129
|
+
}
|
|
50
130
|
try {
|
|
51
131
|
await this.events.publish('claude.hooks.session.started', {
|
|
52
|
-
claudeSessionId:
|
|
132
|
+
claudeSessionId: providerSessionId,
|
|
133
|
+
providerName: data.providerName,
|
|
134
|
+
providerSessionId: data.providerSessionId,
|
|
53
135
|
source: data.source,
|
|
54
136
|
model: data.model,
|
|
55
137
|
permissionMode: data.permissionMode,
|
|
@@ -78,6 +160,7 @@ exports.HooksService = HooksService;
|
|
|
78
160
|
exports.HooksService = HooksService = __decorate([
|
|
79
161
|
(0, common_1.Injectable)(),
|
|
80
162
|
__param(0, (0, common_1.Inject)(storage_interface_1.STORAGE_SERVICE)),
|
|
81
|
-
__metadata("design:paramtypes", [Object, events_service_1.EventsService
|
|
163
|
+
__metadata("design:paramtypes", [Object, events_service_1.EventsService,
|
|
164
|
+
pending_ask_user_question_service_1.PendingAskUserQuestionService])
|
|
82
165
|
], HooksService);
|
|
83
166
|
//# 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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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import type { NormalizedAskUserQuestion } from '../../events/catalog/claude.hooks.ask_user_question.pending';
|
|
2
|
+
export declare const PENDING_ASK_QUESTION_TTL_MS: number;
|
|
3
|
+
export interface PendingAskUserQuestionEntry {
|
|
4
|
+
projectId: string;
|
|
5
|
+
agentId: string | null;
|
|
6
|
+
sessionId: string;
|
|
7
|
+
claudeSessionId: string;
|
|
8
|
+
toolUseId: string;
|
|
9
|
+
questions: NormalizedAskUserQuestion[];
|
|
10
|
+
createdAt: number;
|
|
11
|
+
expiresAt: number;
|
|
12
|
+
status: 'pending';
|
|
13
|
+
}
|
|
14
|
+
export interface SetPendingAskUserQuestionInput {
|
|
15
|
+
projectId: string;
|
|
16
|
+
agentId: string | null;
|
|
17
|
+
sessionId: string;
|
|
18
|
+
claudeSessionId: string;
|
|
19
|
+
toolUseId: string;
|
|
20
|
+
questions: NormalizedAskUserQuestion[];
|
|
21
|
+
now?: number;
|
|
22
|
+
}
|
|
23
|
+
export declare class PendingAskUserQuestionService {
|
|
24
|
+
private readonly entries;
|
|
25
|
+
private key;
|
|
26
|
+
set(input: SetPendingAskUserQuestionInput): PendingAskUserQuestionEntry;
|
|
27
|
+
getBySession(sessionId: string, now?: number): PendingAskUserQuestionEntry[];
|
|
28
|
+
clearByToolUseId(sessionId: string, toolUseId: string): boolean;
|
|
29
|
+
clearBySession(sessionId: string): number;
|
|
30
|
+
size(now?: number): number;
|
|
31
|
+
private prune;
|
|
32
|
+
onSessionStopped(payload: {
|
|
33
|
+
sessionId: string;
|
|
34
|
+
}): void;
|
|
35
|
+
onSessionCrashed(payload: {
|
|
36
|
+
sessionId: string;
|
|
37
|
+
}): void;
|
|
38
|
+
}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.PendingAskUserQuestionService = exports.PENDING_ASK_QUESTION_TTL_MS = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const event_emitter_1 = require("@nestjs/event-emitter");
|
|
15
|
+
const logger_1 = require("../../../common/logging/logger");
|
|
16
|
+
const logger = (0, logger_1.createLogger)('PendingAskUserQuestionService');
|
|
17
|
+
exports.PENDING_ASK_QUESTION_TTL_MS = 30 * 60 * 1000;
|
|
18
|
+
let PendingAskUserQuestionService = class PendingAskUserQuestionService {
|
|
19
|
+
constructor() {
|
|
20
|
+
this.entries = new Map();
|
|
21
|
+
}
|
|
22
|
+
key(sessionId, toolUseId) {
|
|
23
|
+
return `${sessionId}::${toolUseId}`;
|
|
24
|
+
}
|
|
25
|
+
set(input) {
|
|
26
|
+
const now = input.now ?? Date.now();
|
|
27
|
+
this.prune(now);
|
|
28
|
+
const entry = {
|
|
29
|
+
projectId: input.projectId,
|
|
30
|
+
agentId: input.agentId,
|
|
31
|
+
sessionId: input.sessionId,
|
|
32
|
+
claudeSessionId: input.claudeSessionId,
|
|
33
|
+
toolUseId: input.toolUseId,
|
|
34
|
+
questions: input.questions,
|
|
35
|
+
createdAt: now,
|
|
36
|
+
expiresAt: now + exports.PENDING_ASK_QUESTION_TTL_MS,
|
|
37
|
+
status: 'pending',
|
|
38
|
+
};
|
|
39
|
+
this.entries.set(this.key(input.sessionId, input.toolUseId), entry);
|
|
40
|
+
return entry;
|
|
41
|
+
}
|
|
42
|
+
getBySession(sessionId, now = Date.now()) {
|
|
43
|
+
this.prune(now);
|
|
44
|
+
const result = [];
|
|
45
|
+
for (const entry of this.entries.values()) {
|
|
46
|
+
if (entry.sessionId === sessionId) {
|
|
47
|
+
result.push(entry);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return result;
|
|
51
|
+
}
|
|
52
|
+
clearByToolUseId(sessionId, toolUseId) {
|
|
53
|
+
return this.entries.delete(this.key(sessionId, toolUseId));
|
|
54
|
+
}
|
|
55
|
+
clearBySession(sessionId) {
|
|
56
|
+
let cleared = 0;
|
|
57
|
+
for (const [key, entry] of this.entries) {
|
|
58
|
+
if (entry.sessionId === sessionId) {
|
|
59
|
+
this.entries.delete(key);
|
|
60
|
+
cleared += 1;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return cleared;
|
|
64
|
+
}
|
|
65
|
+
size(now = Date.now()) {
|
|
66
|
+
this.prune(now);
|
|
67
|
+
return this.entries.size;
|
|
68
|
+
}
|
|
69
|
+
prune(now) {
|
|
70
|
+
for (const [key, entry] of this.entries) {
|
|
71
|
+
if (entry.expiresAt <= now) {
|
|
72
|
+
this.entries.delete(key);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
onSessionStopped(payload) {
|
|
77
|
+
const cleared = this.clearBySession(payload.sessionId);
|
|
78
|
+
if (cleared > 0) {
|
|
79
|
+
logger.info({ sessionId: payload.sessionId, cleared }, 'Cleared pending AskUserQuestion entries on session stop');
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
onSessionCrashed(payload) {
|
|
83
|
+
const cleared = this.clearBySession(payload.sessionId);
|
|
84
|
+
if (cleared > 0) {
|
|
85
|
+
logger.info({ sessionId: payload.sessionId, cleared }, 'Cleared pending AskUserQuestion entries on session crash');
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
exports.PendingAskUserQuestionService = PendingAskUserQuestionService;
|
|
90
|
+
__decorate([
|
|
91
|
+
(0, event_emitter_1.OnEvent)('session.stopped', { async: true }),
|
|
92
|
+
__metadata("design:type", Function),
|
|
93
|
+
__metadata("design:paramtypes", [Object]),
|
|
94
|
+
__metadata("design:returntype", void 0)
|
|
95
|
+
], PendingAskUserQuestionService.prototype, "onSessionStopped", null);
|
|
96
|
+
__decorate([
|
|
97
|
+
(0, event_emitter_1.OnEvent)('session.crashed', { async: true }),
|
|
98
|
+
__metadata("design:type", Function),
|
|
99
|
+
__metadata("design:paramtypes", [Object]),
|
|
100
|
+
__metadata("design:returntype", void 0)
|
|
101
|
+
], PendingAskUserQuestionService.prototype, "onSessionCrashed", null);
|
|
102
|
+
exports.PendingAskUserQuestionService = PendingAskUserQuestionService = __decorate([
|
|
103
|
+
(0, common_1.Injectable)()
|
|
104
|
+
], PendingAskUserQuestionService);
|
|
105
|
+
//# sourceMappingURL=pending-ask-user-question.service.js.map
|