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
|
@@ -8,18 +8,73 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
9
|
exports.CloudTunnelModule = void 0;
|
|
10
10
|
const common_1 = require("@nestjs/common");
|
|
11
|
+
const core_1 = require("@nestjs/core");
|
|
11
12
|
const cloud_module_1 = require("../cloud/cloud.module");
|
|
12
13
|
const storage_module_1 = require("../storage/storage.module");
|
|
14
|
+
const sessions_read_module_1 = require("../sessions/sessions-read.module");
|
|
15
|
+
const sessions_lifecycle_module_1 = require("../sessions/sessions-lifecycle.module");
|
|
16
|
+
const session_reader_module_1 = require("../session-reader/session-reader.module");
|
|
17
|
+
const agent_message_delivery_module_1 = require("../agent-message-delivery/agent-message-delivery.module");
|
|
18
|
+
const teams_module_1 = require("../teams/teams.module");
|
|
19
|
+
const epics_module_1 = require("../epics/epics.module");
|
|
20
|
+
const hooks_module_1 = require("../hooks/hooks.module");
|
|
21
|
+
const terminal_viewport_module_1 = require("../terminal/terminal-viewport.module");
|
|
22
|
+
const e2ee_module_1 = require("../e2ee/e2ee.module");
|
|
13
23
|
const tunnel_keypair_service_1 = require("./services/tunnel-keypair.service");
|
|
14
24
|
const tunnel_handler_service_1 = require("./services/tunnel-handler.service");
|
|
25
|
+
const tunnel_rpc_crypto_service_1 = require("./services/tunnel-rpc-crypto.service");
|
|
26
|
+
const tunnel_push_crypto_service_1 = require("./services/tunnel-push-crypto.service");
|
|
27
|
+
const tunnel_viewport_crypto_service_1 = require("./services/tunnel-viewport-crypto.service");
|
|
15
28
|
const tunnel_client_service_1 = require("./services/tunnel-client.service");
|
|
29
|
+
const tunnel_event_forwarder_service_1 = require("./services/tunnel-event-forwarder.service");
|
|
30
|
+
const ask_user_question_push_gate_service_1 = require("./services/ask-user-question-push-gate.service");
|
|
31
|
+
const mobile_chat_rpc_service_1 = require("./services/mobile-chat-rpc.service");
|
|
32
|
+
const mobile_board_rpc_service_1 = require("./services/mobile-board-rpc.service");
|
|
33
|
+
const lifecycle_operation_tracker_1 = require("./services/lifecycle-operation-tracker");
|
|
34
|
+
const viewport_streamer_service_1 = require("./services/viewport-streamer.service");
|
|
35
|
+
const viewport_frame_sink_1 = require("./services/viewport-frame-sink");
|
|
16
36
|
let CloudTunnelModule = class CloudTunnelModule {
|
|
17
37
|
};
|
|
18
38
|
exports.CloudTunnelModule = CloudTunnelModule;
|
|
19
39
|
exports.CloudTunnelModule = CloudTunnelModule = __decorate([
|
|
20
40
|
(0, common_1.Module)({
|
|
21
|
-
imports: [
|
|
22
|
-
|
|
41
|
+
imports: [
|
|
42
|
+
cloud_module_1.CloudModule,
|
|
43
|
+
storage_module_1.StorageModule,
|
|
44
|
+
sessions_read_module_1.SessionsReadModule,
|
|
45
|
+
sessions_lifecycle_module_1.SessionsLifecycleModule,
|
|
46
|
+
session_reader_module_1.SessionReaderModule,
|
|
47
|
+
agent_message_delivery_module_1.AgentMessageDeliveryModule,
|
|
48
|
+
teams_module_1.TeamsModule,
|
|
49
|
+
epics_module_1.EpicsModule,
|
|
50
|
+
hooks_module_1.HooksModule,
|
|
51
|
+
terminal_viewport_module_1.TerminalViewportModule,
|
|
52
|
+
e2ee_module_1.E2eeModule,
|
|
53
|
+
],
|
|
54
|
+
providers: [
|
|
55
|
+
tunnel_keypair_service_1.TunnelKeypairService,
|
|
56
|
+
tunnel_handler_service_1.TunnelHandlerService,
|
|
57
|
+
tunnel_rpc_crypto_service_1.TunnelRpcCryptoService,
|
|
58
|
+
tunnel_push_crypto_service_1.TunnelPushCryptoService,
|
|
59
|
+
tunnel_viewport_crypto_service_1.TunnelViewportCryptoService,
|
|
60
|
+
{ provide: tunnel_rpc_crypto_service_1.E2EE_REQUIRED_POLICY, useFactory: () => process.env.E2EE_REQUIRED === 'true' },
|
|
61
|
+
tunnel_client_service_1.TunnelClientService,
|
|
62
|
+
tunnel_event_forwarder_service_1.TunnelEventForwarderService,
|
|
63
|
+
ask_user_question_push_gate_service_1.AskUserQuestionPushGateService,
|
|
64
|
+
mobile_chat_rpc_service_1.MobileChatRpcService,
|
|
65
|
+
mobile_board_rpc_service_1.MobileBoardRpcService,
|
|
66
|
+
lifecycle_operation_tracker_1.LifecycleOperationTracker,
|
|
67
|
+
viewport_streamer_service_1.ViewportStreamerService,
|
|
68
|
+
{
|
|
69
|
+
provide: viewport_frame_sink_1.ViewportFrameSink,
|
|
70
|
+
useFactory: (moduleRef) => ({
|
|
71
|
+
sendViewport: (frame) => moduleRef.get(tunnel_client_service_1.TunnelClientService, { strict: false }).sendViewport(frame),
|
|
72
|
+
onPushReady: (listener) => moduleRef.get(tunnel_client_service_1.TunnelClientService, { strict: false }).onPushReady(listener),
|
|
73
|
+
getInstanceId: () => moduleRef.get(tunnel_client_service_1.TunnelClientService, { strict: false }).getInstanceId(),
|
|
74
|
+
}),
|
|
75
|
+
inject: [core_1.ModuleRef],
|
|
76
|
+
},
|
|
77
|
+
],
|
|
23
78
|
})
|
|
24
79
|
], CloudTunnelModule);
|
|
25
80
|
//# sourceMappingURL=cloud-tunnel.module.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cloud-tunnel.module.js","sourceRoot":"","sources":["../../../src/modules/cloud-tunnel/cloud-tunnel.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,wDAAoD;AACpD,8DAA0D;AAC1D,8EAAyE;AACzE,8EAAyE;AACzE,4EAAuE;
|
|
1
|
+
{"version":3,"file":"cloud-tunnel.module.js","sourceRoot":"","sources":["../../../src/modules/cloud-tunnel/cloud-tunnel.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,uCAAyC;AACzC,wDAAoD;AACpD,8DAA0D;AAC1D,2EAAsE;AACtE,qFAAgF;AAChF,mFAA8E;AAC9E,2GAAqG;AACrG,wDAAoD;AACpD,wDAAoD;AACpD,wDAAoD;AACpD,mFAA8E;AAC9E,qDAAiD;AACjD,8EAAyE;AACzE,8EAAyE;AACzE,oFAAoG;AACpG,sFAAgF;AAChF,8FAAwF;AACxF,4EAAuE;AACvE,8FAAwF;AACxF,wGAAgG;AAChG,gFAA0E;AAC1E,kFAA4E;AAC5E,wFAAmF;AACnF,oFAA+E;AAC/E,wEAAmE;AAgF5D,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;CAAG,CAAA;AAApB,8CAAiB;4BAAjB,iBAAiB;IA9E7B,IAAA,eAAM,EAAC;QASN,OAAO,EAAE;YACP,0BAAW;YACX,8BAAa;YACb,yCAAkB;YAClB,mDAAuB;YACvB,2CAAmB;YACnB,0DAA0B;YAC1B,0BAAW;YAIX,0BAAW;YAMX,0BAAW;YAIX,iDAAsB;YAItB,wBAAU;SACX;QACD,SAAS,EAAE;YACT,6CAAoB;YACpB,6CAAoB;YAGpB,kDAAsB;YAItB,oDAAuB;YAGvB,4DAA2B;YAI3B,EAAE,OAAO,EAAE,gDAAoB,EAAE,UAAU,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,aAAa,KAAK,MAAM,EAAE;YACzF,2CAAmB;YACnB,4DAA2B;YAC3B,oEAA8B;YAC9B,8CAAoB;YACpB,gDAAqB;YACrB,uDAAyB;YACzB,mDAAuB;YAMvB;gBACE,OAAO,EAAE,uCAAiB;gBAC1B,UAAU,EAAE,CAAC,SAAoB,EAAqB,EAAE,CAAC,CAAC;oBACxD,YAAY,EAAE,CAAC,KAAK,EAAE,EAAE,CACtB,SAAS,CAAC,GAAG,CAAC,2CAAmB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC;oBAC3E,WAAW,EAAE,CAAC,QAAQ,EAAE,EAAE,CACxB,SAAS,CAAC,GAAG,CAAC,2CAAmB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,WAAW,CAAC,QAAQ,CAAC;oBAC7E,aAAa,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,2CAAmB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,aAAa,EAAE;iBAC3F,CAAC;gBACF,MAAM,EAAE,CAAC,gBAAS,CAAC;aACpB;SACF;KACF,CAAC;GACW,iBAAiB,CAAG"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { OnModuleDestroy } from '@nestjs/common';
|
|
2
|
+
import { CloudSessionManagerService } from '../../cloud/services/cloud-session-manager.service';
|
|
3
|
+
import { EgressQueueService } from '../../cloud/services/egress-queue.service';
|
|
4
|
+
import { EventMapperService } from '../../cloud/services/event-mapper.service';
|
|
5
|
+
import { ProjectEgressConfigService } from '../../cloud/services/project-egress-config.service';
|
|
6
|
+
import type { ClaudeHooksAskUserQuestionPendingEventPayload } from '../../events/catalog/claude.hooks.ask_user_question.pending';
|
|
7
|
+
import { TunnelClientService } from './tunnel-client.service';
|
|
8
|
+
export declare const AUQ_NATIVE_PUSH_GRACE_MS = 12000;
|
|
9
|
+
export declare class AskUserQuestionPushGateService implements OnModuleDestroy {
|
|
10
|
+
private readonly cloudSession;
|
|
11
|
+
private readonly egressQueue;
|
|
12
|
+
private readonly eventMapper;
|
|
13
|
+
private readonly projectConfig;
|
|
14
|
+
private readonly tunnelClient;
|
|
15
|
+
private readonly pendingTimers;
|
|
16
|
+
constructor(cloudSession: CloudSessionManagerService, egressQueue: EgressQueueService, eventMapper: EventMapperService, projectConfig: ProjectEgressConfigService, tunnelClient: TunnelClientService);
|
|
17
|
+
onPending(payload: ClaudeHooksAskUserQuestionPendingEventPayload): Promise<void>;
|
|
18
|
+
private decide;
|
|
19
|
+
onModuleDestroy(): void;
|
|
20
|
+
}
|
|
@@ -0,0 +1,84 @@
|
|
|
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.AskUserQuestionPushGateService = exports.AUQ_NATIVE_PUSH_GRACE_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 cloud_session_manager_service_1 = require("../../cloud/services/cloud-session-manager.service");
|
|
17
|
+
const egress_queue_service_1 = require("../../cloud/services/egress-queue.service");
|
|
18
|
+
const event_mapper_service_1 = require("../../cloud/services/event-mapper.service");
|
|
19
|
+
const project_egress_config_service_1 = require("../../cloud/services/project-egress-config.service");
|
|
20
|
+
const tunnel_client_service_1 = require("./tunnel-client.service");
|
|
21
|
+
const logger = (0, logger_1.createLogger)('AskUserQuestionPushGate');
|
|
22
|
+
exports.AUQ_NATIVE_PUSH_GRACE_MS = 12_000;
|
|
23
|
+
let AskUserQuestionPushGateService = class AskUserQuestionPushGateService {
|
|
24
|
+
constructor(cloudSession, egressQueue, eventMapper, projectConfig, tunnelClient) {
|
|
25
|
+
this.cloudSession = cloudSession;
|
|
26
|
+
this.egressQueue = egressQueue;
|
|
27
|
+
this.eventMapper = eventMapper;
|
|
28
|
+
this.projectConfig = projectConfig;
|
|
29
|
+
this.tunnelClient = tunnelClient;
|
|
30
|
+
this.pendingTimers = new Set();
|
|
31
|
+
}
|
|
32
|
+
async onPending(payload) {
|
|
33
|
+
const status = this.cloudSession.getStatus();
|
|
34
|
+
if (!status.connected || !status.userId)
|
|
35
|
+
return;
|
|
36
|
+
if (!this.projectConfig.isEnabled(payload.projectId))
|
|
37
|
+
return;
|
|
38
|
+
const sourceEventId = `auq.pending:${payload.toolUseId}`;
|
|
39
|
+
const ingestPayload = this.eventMapper.mapToIngestPayload({ name: 'claude.hooks.ask_user_question.pending', payload }, sourceEventId, status.userId, { instanceId: this.tunnelClient.getInstanceId() });
|
|
40
|
+
const timer = setTimeout(() => {
|
|
41
|
+
this.pendingTimers.delete(timer);
|
|
42
|
+
void this.decide(ingestPayload, payload.toolUseId);
|
|
43
|
+
}, exports.AUQ_NATIVE_PUSH_GRACE_MS);
|
|
44
|
+
if (typeof timer.unref === 'function')
|
|
45
|
+
timer.unref();
|
|
46
|
+
this.pendingTimers.add(timer);
|
|
47
|
+
}
|
|
48
|
+
async decide(ingestPayload, toolUseId) {
|
|
49
|
+
let live = false;
|
|
50
|
+
try {
|
|
51
|
+
({ live } = await this.tunnelClient.querySseLiveness());
|
|
52
|
+
}
|
|
53
|
+
catch {
|
|
54
|
+
live = false;
|
|
55
|
+
}
|
|
56
|
+
if (live) {
|
|
57
|
+
logger.debug({ toolUseId }, 'SSE live — suppressing AskUserQuestion native push');
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
this.egressQueue.enqueue(ingestPayload);
|
|
61
|
+
logger.debug({ toolUseId }, 'SSE down — enqueued AskUserQuestion native push');
|
|
62
|
+
}
|
|
63
|
+
onModuleDestroy() {
|
|
64
|
+
for (const timer of this.pendingTimers)
|
|
65
|
+
clearTimeout(timer);
|
|
66
|
+
this.pendingTimers.clear();
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
exports.AskUserQuestionPushGateService = AskUserQuestionPushGateService;
|
|
70
|
+
__decorate([
|
|
71
|
+
(0, event_emitter_1.OnEvent)('claude.hooks.ask_user_question.pending', { async: true }),
|
|
72
|
+
__metadata("design:type", Function),
|
|
73
|
+
__metadata("design:paramtypes", [Object]),
|
|
74
|
+
__metadata("design:returntype", Promise)
|
|
75
|
+
], AskUserQuestionPushGateService.prototype, "onPending", null);
|
|
76
|
+
exports.AskUserQuestionPushGateService = AskUserQuestionPushGateService = __decorate([
|
|
77
|
+
(0, common_1.Injectable)(),
|
|
78
|
+
__metadata("design:paramtypes", [cloud_session_manager_service_1.CloudSessionManagerService,
|
|
79
|
+
egress_queue_service_1.EgressQueueService,
|
|
80
|
+
event_mapper_service_1.EventMapperService,
|
|
81
|
+
project_egress_config_service_1.ProjectEgressConfigService,
|
|
82
|
+
tunnel_client_service_1.TunnelClientService])
|
|
83
|
+
], AskUserQuestionPushGateService);
|
|
84
|
+
//# sourceMappingURL=ask-user-question-push-gate.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ask-user-question-push-gate.service.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/ask-user-question-push-gate.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA6D;AAC7D,yDAAgD;AAChD,2DAA8D;AAC9D,sGAAgG;AAChG,oFAA+E;AAC/E,oFAAmG;AACnG,sGAAgG;AAEhG,mEAA8D;AAE9D,MAAM,MAAM,GAAG,IAAA,qBAAY,EAAC,yBAAyB,CAAC,CAAC;AAS1C,QAAA,wBAAwB,GAAG,MAAM,CAAC;AAmBxC,IAAM,8BAA8B,GAApC,MAAM,8BAA8B;IAGzC,YACmB,YAAwC,EACxC,WAA+B,EAC/B,WAA+B,EAC/B,aAAyC,EACzC,YAAiC;QAJjC,iBAAY,GAAZ,YAAY,CAA4B;QACxC,gBAAW,GAAX,WAAW,CAAoB;QAC/B,gBAAW,GAAX,WAAW,CAAoB;QAC/B,kBAAa,GAAb,aAAa,CAA4B;QACzC,iBAAY,GAAZ,YAAY,CAAqB;QAPnC,kBAAa,GAAG,IAAI,GAAG,EAAiC,CAAC;IAQvE,CAAC;IAGE,AAAN,KAAK,CAAC,SAAS,CAAC,OAAsD;QACpE,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;QAC7C,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,CAAC,MAAM,CAAC,MAAM;YAAE,OAAO;QAGhD,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC;YAAE,OAAO;QAK7D,MAAM,aAAa,GAAG,eAAe,OAAO,CAAC,SAAS,EAAE,CAAC;QACzD,MAAM,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC,kBAAkB,CACvD,EAAE,IAAI,EAAE,wCAAwC,EAAE,OAAO,EAAE,EAC3D,aAAa,EACb,MAAM,CAAC,MAAM,EACb,EAAE,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,EAAE,CAClD,CAAC;QAEF,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;YAC5B,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACjC,KAAK,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;QACrD,CAAC,EAAE,gCAAwB,CAAC,CAAC;QAC7B,IAAI,OAAO,KAAK,CAAC,KAAK,KAAK,UAAU;YAAE,KAAK,CAAC,KAAK,EAAE,CAAC;QACrD,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAEO,KAAK,CAAC,MAAM,CAAC,aAA4B,EAAE,SAAiB;QAClE,IAAI,IAAI,GAAG,KAAK,CAAC;QACjB,IAAI,CAAC;YACH,CAAC,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,gBAAgB,EAAE,CAAC,CAAC;QAC1D,CAAC;QAAC,MAAM,CAAC;YACP,IAAI,GAAG,KAAK,CAAC;QACf,CAAC;QAED,IAAI,IAAI,EAAE,CAAC;YACT,MAAM,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,EAAE,oDAAoD,CAAC,CAAC;YAClF,OAAO;QACT,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QACxC,MAAM,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,EAAE,iDAAiD,CAAC,CAAC;IACjF,CAAC;IAED,eAAe;QACb,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,aAAa;YAAE,YAAY,CAAC,KAAK,CAAC,CAAC;QAC5D,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC7B,CAAC;CACF,CAAA;AA3DY,wEAA8B;AAYnC;IADL,IAAA,uBAAO,EAAC,wCAAwC,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;;;;+DAyBlE;yCApCU,8BAA8B;IAD1C,IAAA,mBAAU,GAAE;qCAKsB,0DAA0B;QAC3B,yCAAkB;QAClB,yCAAkB;QAChB,0DAA0B;QAC3B,2CAAmB;GARzC,8BAA8B,CA2D1C"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export declare function toStatusDto(status: Record<string, unknown>): Record<string, unknown>;
|
|
2
|
+
export declare function toStatusMap(statuses: Array<Record<string, unknown>>): Map<string, Record<string, unknown>>;
|
|
3
|
+
export declare function toEpicDto(epic: Record<string, unknown>, statusMap?: Map<string, Record<string, unknown>>, agentNameById?: Map<string, string>): Record<string, unknown>;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.toStatusDto = toStatusDto;
|
|
4
|
+
exports.toStatusMap = toStatusMap;
|
|
5
|
+
exports.toEpicDto = toEpicDto;
|
|
6
|
+
function toStatusDto(status) {
|
|
7
|
+
return {
|
|
8
|
+
id: status.id,
|
|
9
|
+
name: status.name ?? status.label,
|
|
10
|
+
color: status.color,
|
|
11
|
+
position: status.position,
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
function toStatusMap(statuses) {
|
|
15
|
+
return new Map(statuses
|
|
16
|
+
.filter((status) => typeof status.id === 'string')
|
|
17
|
+
.map((status) => [status.id, toStatusDto(status)]));
|
|
18
|
+
}
|
|
19
|
+
function toEpicDto(epic, statusMap, agentNameById) {
|
|
20
|
+
const statusId = epic.statusId;
|
|
21
|
+
const status = statusId ? statusMap?.get(statusId) : undefined;
|
|
22
|
+
const agentId = epic.agentId ?? null;
|
|
23
|
+
const resolvedAgentName = (agentId ? agentNameById?.get(agentId) : undefined) ?? epic.agentName;
|
|
24
|
+
return {
|
|
25
|
+
id: epic.id,
|
|
26
|
+
projectId: epic.projectId,
|
|
27
|
+
title: epic.title,
|
|
28
|
+
statusId,
|
|
29
|
+
statusName: status?.name,
|
|
30
|
+
statusColor: status?.color,
|
|
31
|
+
statusPosition: status?.position,
|
|
32
|
+
status,
|
|
33
|
+
agentId,
|
|
34
|
+
agentName: resolvedAgentName,
|
|
35
|
+
parentId: epic.parentId,
|
|
36
|
+
version: epic.version,
|
|
37
|
+
updatedAt: epic.updatedAt,
|
|
38
|
+
description: epic.description,
|
|
39
|
+
createdAt: epic.createdAt,
|
|
40
|
+
tags: epic.tags,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=epic-dto.util.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"epic-dto.util.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/epic-dto.util.ts"],"names":[],"mappings":";;AAmBA,kCAOC;AAGD,kCAQC;AAED,8BA6BC;AAjDD,SAAgB,WAAW,CAAC,MAA+B;IACzD,OAAO;QACL,EAAE,EAAE,MAAM,CAAC,EAAE;QACb,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,KAAK;QACjC,KAAK,EAAE,MAAM,CAAC,KAAK;QACnB,QAAQ,EAAE,MAAM,CAAC,QAAQ;KAC1B,CAAC;AACJ,CAAC;AAGD,SAAgB,WAAW,CACzB,QAAwC;IAExC,OAAO,IAAI,GAAG,CACZ,QAAQ;SACL,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO,MAAM,CAAC,EAAE,KAAK,QAAQ,CAAC;SACjD,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,EAAY,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAC/D,CAAC;AACJ,CAAC;AAED,SAAgB,SAAS,CACvB,IAA6B,EAC7B,SAAgD,EAChD,aAAmC;IAEnC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAA8B,CAAC;IACrD,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/D,MAAM,OAAO,GAAI,IAAI,CAAC,OAAqC,IAAI,IAAI,CAAC;IACpE,MAAM,iBAAiB,GACrB,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,IAAK,IAAI,CAAC,SAAgC,CAAC;IAEhG,OAAO;QACL,EAAE,EAAE,IAAI,CAAC,EAAE;QACX,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,KAAK,EAAE,IAAI,CAAC,KAAK;QACjB,QAAQ;QACR,UAAU,EAAE,MAAM,EAAE,IAAI;QACxB,WAAW,EAAE,MAAM,EAAE,KAAK;QAC1B,cAAc,EAAE,MAAM,EAAE,QAAQ;QAChC,MAAM;QACN,OAAO;QACP,SAAS,EAAE,iBAAiB;QAC5B,QAAQ,EAAE,IAAI,CAAC,QAAQ;QACvB,OAAO,EAAE,IAAI,CAAC,OAAO;QACrB,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,WAAW,EAAE,IAAI,CAAC,WAAW;QAC7B,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,IAAI,EAAE,IAAI,CAAC,IAAI;KAChB,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export interface JsonRpcError {
|
|
2
|
+
code: number;
|
|
3
|
+
message: string;
|
|
4
|
+
data?: {
|
|
5
|
+
code: string;
|
|
6
|
+
details?: unknown;
|
|
7
|
+
};
|
|
8
|
+
}
|
|
9
|
+
export declare const JSON_RPC_INVALID_PARAMS = -32602;
|
|
10
|
+
export declare const JSON_RPC_INTERNAL_ERROR = -32603;
|
|
11
|
+
export declare function toJsonRpcError(err: unknown): JsonRpcError;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.JSON_RPC_INTERNAL_ERROR = exports.JSON_RPC_INVALID_PARAMS = void 0;
|
|
4
|
+
exports.toJsonRpcError = toJsonRpcError;
|
|
5
|
+
const zod_1 = require("zod");
|
|
6
|
+
const error_types_1 = require("../../../common/errors/error-types");
|
|
7
|
+
exports.JSON_RPC_INVALID_PARAMS = -32602;
|
|
8
|
+
exports.JSON_RPC_INTERNAL_ERROR = -32603;
|
|
9
|
+
function appErrorToRpcCode(err) {
|
|
10
|
+
return err.statusCode === 400 ? exports.JSON_RPC_INVALID_PARAMS : exports.JSON_RPC_INTERNAL_ERROR;
|
|
11
|
+
}
|
|
12
|
+
function toJsonRpcError(err) {
|
|
13
|
+
if (err instanceof zod_1.ZodError) {
|
|
14
|
+
return {
|
|
15
|
+
code: exports.JSON_RPC_INVALID_PARAMS,
|
|
16
|
+
message: 'Invalid params',
|
|
17
|
+
data: { code: 'validation_error', details: err.format() },
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
if (err instanceof error_types_1.AppError) {
|
|
21
|
+
const data = { code: err.code };
|
|
22
|
+
if (err.details !== undefined) {
|
|
23
|
+
data.details = err.details;
|
|
24
|
+
}
|
|
25
|
+
return { code: appErrorToRpcCode(err), message: err.message, data };
|
|
26
|
+
}
|
|
27
|
+
return {
|
|
28
|
+
code: exports.JSON_RPC_INTERNAL_ERROR,
|
|
29
|
+
message: err instanceof Error ? err.message : 'Internal error',
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=jsonrpc-error.util.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonrpc-error.util.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/jsonrpc-error.util.ts"],"names":[],"mappings":";;;AAsCA,wCAqBC;AA3DD,6BAA+B;AAC/B,oEAA8D;AAkBjD,QAAA,uBAAuB,GAAG,CAAC,KAAK,CAAC;AACjC,QAAA,uBAAuB,GAAG,CAAC,KAAK,CAAC;AAO9C,SAAS,iBAAiB,CAAC,GAAa;IACtC,OAAO,GAAG,CAAC,UAAU,KAAK,GAAG,CAAC,CAAC,CAAC,+BAAuB,CAAC,CAAC,CAAC,+BAAuB,CAAC;AACpF,CAAC;AASD,SAAgB,cAAc,CAAC,GAAY;IACzC,IAAI,GAAG,YAAY,cAAQ,EAAE,CAAC;QAC5B,OAAO;YACL,IAAI,EAAE,+BAAuB;YAC7B,OAAO,EAAE,gBAAgB;YACzB,IAAI,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,EAAE;SAC1D,CAAC;IACJ,CAAC;IAED,IAAI,GAAG,YAAY,sBAAQ,EAAE,CAAC;QAC5B,MAAM,IAAI,GAAyB,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,EAAE,CAAC;QACtD,IAAI,GAAG,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;YAC9B,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC;QAC7B,CAAC;QACD,OAAO,EAAE,IAAI,EAAE,iBAAiB,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC;IACtE,CAAC;IAED,OAAO;QACL,IAAI,EAAE,+BAAuB;QAC7B,OAAO,EAAE,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,gBAAgB;KAC/D,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export type LifecycleOperationType = 'launch' | 'restart' | 'restore';
|
|
2
|
+
export type LifecycleOperationStatus = 'pending' | 'running' | 'succeeded' | 'failed';
|
|
3
|
+
export interface LifecycleOperation {
|
|
4
|
+
operationId: string;
|
|
5
|
+
type: LifecycleOperationType;
|
|
6
|
+
agentId: string | null;
|
|
7
|
+
sessionId: string | null;
|
|
8
|
+
projectId: string;
|
|
9
|
+
status: LifecycleOperationStatus;
|
|
10
|
+
errorCode?: string;
|
|
11
|
+
errorMessage?: string;
|
|
12
|
+
createdAt: string;
|
|
13
|
+
updatedAt: string;
|
|
14
|
+
}
|
|
15
|
+
export declare class LifecycleOperationTracker {
|
|
16
|
+
private readonly operations;
|
|
17
|
+
create(input: {
|
|
18
|
+
type: LifecycleOperationType;
|
|
19
|
+
projectId: string;
|
|
20
|
+
agentId?: string | null;
|
|
21
|
+
sessionId?: string | null;
|
|
22
|
+
}): LifecycleOperation;
|
|
23
|
+
markRunning(operationId: string): void;
|
|
24
|
+
succeed(operationId: string, sessionId?: string | null): void;
|
|
25
|
+
fail(operationId: string, errorCode: string, errorMessage: string): void;
|
|
26
|
+
get(operationId: string): LifecycleOperation | undefined;
|
|
27
|
+
latestForAgent(agentId: string): LifecycleOperation | undefined;
|
|
28
|
+
private patch;
|
|
29
|
+
private evictIfNeeded;
|
|
30
|
+
}
|
|
@@ -0,0 +1,80 @@
|
|
|
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.LifecycleOperationTracker = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const node_crypto_1 = require("node:crypto");
|
|
12
|
+
const MAX_OPERATIONS = 500;
|
|
13
|
+
let LifecycleOperationTracker = class LifecycleOperationTracker {
|
|
14
|
+
constructor() {
|
|
15
|
+
this.operations = new Map();
|
|
16
|
+
}
|
|
17
|
+
create(input) {
|
|
18
|
+
const now = new Date().toISOString();
|
|
19
|
+
const op = {
|
|
20
|
+
operationId: (0, node_crypto_1.randomUUID)(),
|
|
21
|
+
type: input.type,
|
|
22
|
+
agentId: input.agentId ?? null,
|
|
23
|
+
sessionId: input.sessionId ?? null,
|
|
24
|
+
projectId: input.projectId,
|
|
25
|
+
status: 'pending',
|
|
26
|
+
createdAt: now,
|
|
27
|
+
updatedAt: now,
|
|
28
|
+
};
|
|
29
|
+
this.operations.set(op.operationId, op);
|
|
30
|
+
this.evictIfNeeded();
|
|
31
|
+
return op;
|
|
32
|
+
}
|
|
33
|
+
markRunning(operationId) {
|
|
34
|
+
this.patch(operationId, { status: 'running' });
|
|
35
|
+
}
|
|
36
|
+
succeed(operationId, sessionId) {
|
|
37
|
+
this.patch(operationId, {
|
|
38
|
+
status: 'succeeded',
|
|
39
|
+
...(sessionId ? { sessionId } : {}),
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
fail(operationId, errorCode, errorMessage) {
|
|
43
|
+
this.patch(operationId, { status: 'failed', errorCode, errorMessage });
|
|
44
|
+
}
|
|
45
|
+
get(operationId) {
|
|
46
|
+
return this.operations.get(operationId);
|
|
47
|
+
}
|
|
48
|
+
latestForAgent(agentId) {
|
|
49
|
+
let latest;
|
|
50
|
+
for (const op of this.operations.values()) {
|
|
51
|
+
if (op.agentId === agentId && (!latest || op.createdAt >= latest.createdAt)) {
|
|
52
|
+
latest = op;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
return latest;
|
|
56
|
+
}
|
|
57
|
+
patch(operationId, fields) {
|
|
58
|
+
const existing = this.operations.get(operationId);
|
|
59
|
+
if (!existing)
|
|
60
|
+
return;
|
|
61
|
+
this.operations.set(operationId, {
|
|
62
|
+
...existing,
|
|
63
|
+
...fields,
|
|
64
|
+
updatedAt: new Date().toISOString(),
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
evictIfNeeded() {
|
|
68
|
+
while (this.operations.size > MAX_OPERATIONS) {
|
|
69
|
+
const oldest = this.operations.keys().next().value;
|
|
70
|
+
if (oldest === undefined)
|
|
71
|
+
break;
|
|
72
|
+
this.operations.delete(oldest);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
exports.LifecycleOperationTracker = LifecycleOperationTracker;
|
|
77
|
+
exports.LifecycleOperationTracker = LifecycleOperationTracker = __decorate([
|
|
78
|
+
(0, common_1.Injectable)()
|
|
79
|
+
], LifecycleOperationTracker);
|
|
80
|
+
//# sourceMappingURL=lifecycle-operation-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lifecycle-operation-tracker.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/lifecycle-operation-tracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { type StorageService } from '../../storage/interfaces/storage.interface';
|
|
2
|
+
import { EpicsService } from '../../epics/services/epics.service';
|
|
3
|
+
import type { EpicComment } from '../../storage/models/domain.models';
|
|
4
|
+
import type { ListResult } from '../../storage/interfaces/storage.interface';
|
|
5
|
+
export declare class MobileBoardRpcService {
|
|
6
|
+
private readonly storage;
|
|
7
|
+
private readonly epicsService;
|
|
8
|
+
constructor(storage: StorageService, epicsService: EpicsService);
|
|
9
|
+
updateEpicAssignment(params: Record<string, unknown>): Promise<Record<string, unknown>>;
|
|
10
|
+
listEpicComments(params: Record<string, unknown>): Promise<ListResult<EpicComment>>;
|
|
11
|
+
addEpicComment(params: Record<string, unknown>): Promise<EpicComment>;
|
|
12
|
+
deleteEpicComment(params: Record<string, unknown>): Promise<{
|
|
13
|
+
deleted: true;
|
|
14
|
+
}>;
|
|
15
|
+
private assertEpicInProject;
|
|
16
|
+
}
|
|
@@ -0,0 +1,78 @@
|
|
|
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
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.MobileBoardRpcService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const storage_interface_1 = require("../../storage/interfaces/storage.interface");
|
|
18
|
+
const epics_service_1 = require("../../epics/services/epics.service");
|
|
19
|
+
const error_types_1 = require("../../../common/errors/error-types");
|
|
20
|
+
const epic_dto_util_1 = require("./epic-dto.util");
|
|
21
|
+
let MobileBoardRpcService = class MobileBoardRpcService {
|
|
22
|
+
constructor(storage, epicsService) {
|
|
23
|
+
this.storage = storage;
|
|
24
|
+
this.epicsService = epicsService;
|
|
25
|
+
}
|
|
26
|
+
async updateEpicAssignment(params) {
|
|
27
|
+
const projectId = params['projectId'];
|
|
28
|
+
const epicId = params['epicId'];
|
|
29
|
+
const agentId = params['agentId'];
|
|
30
|
+
const version = params['version'];
|
|
31
|
+
await this.assertEpicInProject(epicId, projectId);
|
|
32
|
+
const updated = await this.epicsService.updateEpic(epicId, { agentId }, version);
|
|
33
|
+
const [statusesResult, assignee] = await Promise.all([
|
|
34
|
+
this.storage.listStatuses(projectId, { limit: 1000, offset: 0 }),
|
|
35
|
+
updated.agentId ? this.storage.getAgent(updated.agentId) : Promise.resolve(null),
|
|
36
|
+
]);
|
|
37
|
+
const statusMap = (0, epic_dto_util_1.toStatusMap)(statusesResult.items);
|
|
38
|
+
const agentNameById = assignee ? new Map([[assignee.id, assignee.name]]) : undefined;
|
|
39
|
+
return (0, epic_dto_util_1.toEpicDto)(updated, statusMap, agentNameById);
|
|
40
|
+
}
|
|
41
|
+
async listEpicComments(params) {
|
|
42
|
+
const projectId = params['projectId'];
|
|
43
|
+
const epicId = params['epicId'];
|
|
44
|
+
const limit = params['limit'];
|
|
45
|
+
const offset = params['offset'];
|
|
46
|
+
await this.assertEpicInProject(epicId, projectId);
|
|
47
|
+
return this.storage.listEpicComments(epicId, { limit, offset });
|
|
48
|
+
}
|
|
49
|
+
async addEpicComment(params) {
|
|
50
|
+
const projectId = params['projectId'];
|
|
51
|
+
const epicId = params['epicId'];
|
|
52
|
+
const authorName = params['authorName'];
|
|
53
|
+
const content = params['content'];
|
|
54
|
+
await this.assertEpicInProject(epicId, projectId);
|
|
55
|
+
return this.epicsService.addEpicCommentFromRest(epicId, authorName, content);
|
|
56
|
+
}
|
|
57
|
+
async deleteEpicComment(params) {
|
|
58
|
+
const projectId = params['projectId'];
|
|
59
|
+
const epicId = params['epicId'];
|
|
60
|
+
const commentId = params['commentId'];
|
|
61
|
+
await this.epicsService.deleteEpicComment(projectId, epicId, commentId);
|
|
62
|
+
return { deleted: true };
|
|
63
|
+
}
|
|
64
|
+
async assertEpicInProject(epicId, projectId) {
|
|
65
|
+
const epic = await this.storage.getEpic(epicId);
|
|
66
|
+
if (epic.projectId !== projectId) {
|
|
67
|
+
throw new error_types_1.NotFoundError('Epic', epicId);
|
|
68
|
+
}
|
|
69
|
+
return epic;
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
exports.MobileBoardRpcService = MobileBoardRpcService;
|
|
73
|
+
exports.MobileBoardRpcService = MobileBoardRpcService = __decorate([
|
|
74
|
+
(0, common_1.Injectable)(),
|
|
75
|
+
__param(0, (0, common_1.Inject)(storage_interface_1.STORAGE_SERVICE)),
|
|
76
|
+
__metadata("design:paramtypes", [Object, epics_service_1.EpicsService])
|
|
77
|
+
], MobileBoardRpcService);
|
|
78
|
+
//# sourceMappingURL=mobile-board-rpc.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mobile-board-rpc.service.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/mobile-board-rpc.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import { StorageService } from '../../storage/interfaces/storage.interface';
|
|
2
|
+
import { ActiveSessionLookup } from '../../sessions/services/active-session-lookup.service';
|
|
3
|
+
import { SessionLifecycleFacade } from '../../sessions/services/session-lifecycle-facade.service';
|
|
4
|
+
import type { SessionDto, SessionHistoryResponseDto } from '../../sessions/dtos/sessions.dto';
|
|
5
|
+
import { SessionReaderService, type TranscriptSummaryWithCursor, type UnifiedChunkedResponse, type TranscriptTailResponse } from '../../session-reader/services/session-reader.service';
|
|
6
|
+
import { TranscriptWatcherService } from '../../session-reader/services/transcript-watcher.service';
|
|
7
|
+
import { AgentMessageDeliveryService } from '../../agent-message-delivery/agent-message-delivery.service';
|
|
8
|
+
import { TeamsService } from '../../teams/services/teams.service';
|
|
9
|
+
import { PendingAskUserQuestionService } from '../../hooks/services/pending-ask-user-question.service';
|
|
10
|
+
import type { NormalizedAskUserQuestion } from '../../events/catalog/claude.hooks.ask_user_question.pending';
|
|
11
|
+
import { LifecycleOperationTracker, type LifecycleOperation } from './lifecycle-operation-tracker';
|
|
12
|
+
export interface MobileChatAgent {
|
|
13
|
+
id: string;
|
|
14
|
+
name: string;
|
|
15
|
+
type: 'agent';
|
|
16
|
+
profileName?: string;
|
|
17
|
+
providerName?: string;
|
|
18
|
+
providerConfigName?: string;
|
|
19
|
+
online: boolean;
|
|
20
|
+
sessionId?: string;
|
|
21
|
+
activityState?: 'idle' | 'busy' | null;
|
|
22
|
+
latestMessageCount?: number;
|
|
23
|
+
}
|
|
24
|
+
export interface MobileChatTeam {
|
|
25
|
+
id: string;
|
|
26
|
+
name: string;
|
|
27
|
+
teamLeadAgentId: string | null;
|
|
28
|
+
memberAgentIds: string[];
|
|
29
|
+
memberCount?: number;
|
|
30
|
+
}
|
|
31
|
+
export interface MobileChatProfile {
|
|
32
|
+
id: string;
|
|
33
|
+
name: string;
|
|
34
|
+
familySlug?: string | null;
|
|
35
|
+
}
|
|
36
|
+
export interface MobileChatProviderConfig {
|
|
37
|
+
id: string;
|
|
38
|
+
profileId: string;
|
|
39
|
+
providerId: string;
|
|
40
|
+
providerName?: string;
|
|
41
|
+
name: string;
|
|
42
|
+
position: number;
|
|
43
|
+
}
|
|
44
|
+
export interface MobileChatCreatedAgent {
|
|
45
|
+
id: string;
|
|
46
|
+
name: string;
|
|
47
|
+
profileId: string;
|
|
48
|
+
providerConfigId: string;
|
|
49
|
+
description: string | null;
|
|
50
|
+
teamId: string | null;
|
|
51
|
+
}
|
|
52
|
+
export interface SendMessageResult {
|
|
53
|
+
status: 'queued' | 'delivered';
|
|
54
|
+
}
|
|
55
|
+
export interface LifecycleStartResult {
|
|
56
|
+
operationId: string;
|
|
57
|
+
status: 'launching' | 'restarting' | 'restoring';
|
|
58
|
+
}
|
|
59
|
+
export interface TerminateResult {
|
|
60
|
+
status: 'terminated';
|
|
61
|
+
}
|
|
62
|
+
export interface PendingAskUserQuestionItem {
|
|
63
|
+
toolUseId: string;
|
|
64
|
+
questions: NormalizedAskUserQuestion[];
|
|
65
|
+
createdAt: number;
|
|
66
|
+
expiresAt: number;
|
|
67
|
+
}
|
|
68
|
+
export declare class MobileChatRpcService {
|
|
69
|
+
private readonly storage;
|
|
70
|
+
private readonly activeSessions;
|
|
71
|
+
private readonly sessionReader;
|
|
72
|
+
private readonly transcriptWatcher;
|
|
73
|
+
private readonly agentMessageDelivery;
|
|
74
|
+
private readonly sessionLifecycle;
|
|
75
|
+
private readonly operationTracker;
|
|
76
|
+
private readonly teamsService;
|
|
77
|
+
private readonly pendingAskUserQuestion;
|
|
78
|
+
constructor(storage: StorageService, activeSessions: ActiveSessionLookup, sessionReader: SessionReaderService, transcriptWatcher: TranscriptWatcherService, agentMessageDelivery: AgentMessageDeliveryService, sessionLifecycle: SessionLifecycleFacade, operationTracker: LifecycleOperationTracker, teamsService: TeamsService, pendingAskUserQuestion: PendingAskUserQuestionService);
|
|
79
|
+
listAgents(params: Record<string, unknown>): Promise<MobileChatAgent[]>;
|
|
80
|
+
listTeams(params: Record<string, unknown>): Promise<MobileChatTeam[]>;
|
|
81
|
+
listProfiles(params: Record<string, unknown>): Promise<MobileChatProfile[]>;
|
|
82
|
+
listProfileConfigs(params: Record<string, unknown>): Promise<MobileChatProviderConfig[]>;
|
|
83
|
+
createTeamAgent(params: Record<string, unknown>): Promise<MobileChatCreatedAgent>;
|
|
84
|
+
createIndependentAgent(params: Record<string, unknown>): Promise<MobileChatCreatedAgent>;
|
|
85
|
+
deleteAgent(params: Record<string, unknown>): Promise<{
|
|
86
|
+
deleted: true;
|
|
87
|
+
}>;
|
|
88
|
+
private toCreatedAgent;
|
|
89
|
+
getTranscriptSummary(params: Record<string, unknown>): Promise<TranscriptSummaryWithCursor>;
|
|
90
|
+
getTranscriptChunks(params: Record<string, unknown>): Promise<UnifiedChunkedResponse>;
|
|
91
|
+
getTranscriptTail(params: Record<string, unknown>): Promise<TranscriptTailResponse | null>;
|
|
92
|
+
sendMessage(params: Record<string, unknown>): Promise<SendMessageResult>;
|
|
93
|
+
launchAgent(params: Record<string, unknown>): Promise<LifecycleStartResult>;
|
|
94
|
+
restartAgent(params: Record<string, unknown>): Promise<LifecycleStartResult>;
|
|
95
|
+
restoreSession(params: Record<string, unknown>): Promise<LifecycleStartResult>;
|
|
96
|
+
terminateSession(params: Record<string, unknown>): Promise<TerminateResult>;
|
|
97
|
+
getOperationStatus(params: Record<string, unknown>): Promise<LifecycleOperation>;
|
|
98
|
+
getAgentStatus(params: Record<string, unknown>): Promise<LifecycleOperation | null>;
|
|
99
|
+
listPendingAskQuestions(params: Record<string, unknown>): Promise<PendingAskUserQuestionItem[]>;
|
|
100
|
+
listSessions(params: Record<string, unknown>): Promise<SessionHistoryResponseDto>;
|
|
101
|
+
deleteSessionRecord(params: Record<string, unknown>): Promise<{
|
|
102
|
+
deleted: boolean;
|
|
103
|
+
}>;
|
|
104
|
+
renameSession(params: Record<string, unknown>): Promise<SessionDto>;
|
|
105
|
+
private assertAgentInProject;
|
|
106
|
+
private assertProfileInProject;
|
|
107
|
+
private runOperation;
|
|
108
|
+
private assertSessionInProject;
|
|
109
|
+
private resolveProviderConfigInfo;
|
|
110
|
+
private resolveProfileNames;
|
|
111
|
+
private distinct;
|
|
112
|
+
}
|