devchain-cli 0.14.1 → 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/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/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 +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 +33 -28
- package/dist/server/templates/teams-dev.json +42 -70
- package/dist/server/tsconfig.tsbuildinfo +1 -1
- package/dist/server/ui/assets/{ReviewDetailPage-CobRKQBn.js → ReviewDetailPage-BpPjTAgL.js} +1 -1
- package/dist/server/ui/assets/{ReviewsPage-Bb6ZmriH.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-DzaIaXy7.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 +42 -70
- package/package.json +23 -8
- 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,116 @@
|
|
|
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.TunnelRpcCryptoService = exports.RPC_BOOTSTRAP_METHODS = exports.E2EE_REQUIRED_POLICY = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const crypto_1 = require("crypto");
|
|
18
|
+
const shared_1 = require("@devchain/shared");
|
|
19
|
+
const logger_1 = require("../../../common/logging/logger");
|
|
20
|
+
const e2ee_keypair_service_1 = require("../../e2ee/services/e2ee-keypair.service");
|
|
21
|
+
const e2ee_device_store_service_1 = require("../../e2ee/services/e2ee-device-store.service");
|
|
22
|
+
const logger = (0, logger_1.createLogger)('TunnelRpcCrypto');
|
|
23
|
+
exports.E2EE_REQUIRED_POLICY = 'E2EE_REQUIRED_POLICY';
|
|
24
|
+
exports.RPC_BOOTSTRAP_METHODS = new Set(['e2ee.adoptDeviceKey']);
|
|
25
|
+
let TunnelRpcCryptoService = class TunnelRpcCryptoService {
|
|
26
|
+
constructor(keypair, deviceStore, e2eeRequired = false) {
|
|
27
|
+
this.keypair = keypair;
|
|
28
|
+
this.deviceStore = deviceStore;
|
|
29
|
+
this.e2eeRequired = e2eeRequired;
|
|
30
|
+
this.randomBytes = (n) => new Uint8Array((0, crypto_1.randomBytes)(n));
|
|
31
|
+
}
|
|
32
|
+
async handle(req, instanceId, dispatch) {
|
|
33
|
+
const params = req.params;
|
|
34
|
+
if (!(0, shared_1.isE2eeEnvelope)(params)) {
|
|
35
|
+
if (this.e2eeRequired && !exports.RPC_BOOTSTRAP_METHODS.has(req.method)) {
|
|
36
|
+
logger.warn({ id: req.id, method: req.method }, 'Plaintext RPC rejected — E2EE is required on this instance');
|
|
37
|
+
return {
|
|
38
|
+
jsonrpc: '2.0',
|
|
39
|
+
id: req.id,
|
|
40
|
+
error: { code: -32603, message: 'E2EE required' },
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
return dispatch(req);
|
|
44
|
+
}
|
|
45
|
+
if (!instanceId) {
|
|
46
|
+
logger.warn({ id: req.id, method: req.method }, 'Encrypted RPC arrived before tunnel ready — cannot bind AAD');
|
|
47
|
+
return { jsonrpc: '2.0', id: req.id, error: { code: -32603, message: 'E2EE unavailable' } };
|
|
48
|
+
}
|
|
49
|
+
const service = await this.buildEnvelopeService(params.kid);
|
|
50
|
+
if (!service) {
|
|
51
|
+
logger.warn({ id: req.id, method: req.method, kid: params.kid }, 'No paired device for RPC envelope kid — rejecting');
|
|
52
|
+
return {
|
|
53
|
+
jsonrpc: '2.0',
|
|
54
|
+
id: req.id,
|
|
55
|
+
error: { code: -32602, message: 'E2EE decrypt failed' },
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
let plainParams;
|
|
59
|
+
try {
|
|
60
|
+
plainParams = await service.open(params, this.ctx('mobile-to-pc', instanceId, req.method));
|
|
61
|
+
}
|
|
62
|
+
catch (err) {
|
|
63
|
+
logger.warn({ err: err?.name, id: req.id, method: req.method }, 'RPC params decryption failed — rejecting');
|
|
64
|
+
return {
|
|
65
|
+
jsonrpc: '2.0',
|
|
66
|
+
id: req.id,
|
|
67
|
+
error: { code: -32602, message: 'E2EE decrypt failed' },
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
const plainReq = {
|
|
71
|
+
...req,
|
|
72
|
+
params: plainParams && typeof plainParams === 'object' && !Array.isArray(plainParams)
|
|
73
|
+
? plainParams
|
|
74
|
+
: {},
|
|
75
|
+
};
|
|
76
|
+
const resp = await dispatch(plainReq);
|
|
77
|
+
const payload = resp.error
|
|
78
|
+
? { ok: false, error: resp.error }
|
|
79
|
+
: { ok: true, data: resp.result };
|
|
80
|
+
const sealed = await service.seal(payload, this.ctx('pc-to-mobile', instanceId, req.method));
|
|
81
|
+
return { jsonrpc: '2.0', id: req.id, result: sealed };
|
|
82
|
+
}
|
|
83
|
+
async buildEnvelopeService(peerKid) {
|
|
84
|
+
const device = this.deviceStore.get(peerKid);
|
|
85
|
+
if (!device)
|
|
86
|
+
return null;
|
|
87
|
+
let devicePub;
|
|
88
|
+
try {
|
|
89
|
+
devicePub = (0, shared_1.base64ToBytes)(device.publicKeyB64);
|
|
90
|
+
}
|
|
91
|
+
catch {
|
|
92
|
+
return null;
|
|
93
|
+
}
|
|
94
|
+
if (devicePub.length !== shared_1.X25519_PUBLIC_KEY_BYTES)
|
|
95
|
+
return null;
|
|
96
|
+
const pc = await this.keypair.getOrCreate();
|
|
97
|
+
const sharedKey = (0, shared_1.deriveSharedKey)(pc.privateKey, devicePub);
|
|
98
|
+
const provider = {
|
|
99
|
+
resolveSealKey: () => ({ kid: pc.kid, key: sharedKey }),
|
|
100
|
+
getKeyById: (kid) => (kid === device.kid || kid === pc.kid ? sharedKey : undefined),
|
|
101
|
+
};
|
|
102
|
+
return new shared_1.CryptoEnvelopeService(provider, this.randomBytes);
|
|
103
|
+
}
|
|
104
|
+
ctx(direction, instanceId, method) {
|
|
105
|
+
return { lane: 'rpc', direction, instanceId, routeKey: method };
|
|
106
|
+
}
|
|
107
|
+
};
|
|
108
|
+
exports.TunnelRpcCryptoService = TunnelRpcCryptoService;
|
|
109
|
+
exports.TunnelRpcCryptoService = TunnelRpcCryptoService = __decorate([
|
|
110
|
+
(0, common_1.Injectable)(),
|
|
111
|
+
__param(2, (0, common_1.Optional)()),
|
|
112
|
+
__param(2, (0, common_1.Inject)(exports.E2EE_REQUIRED_POLICY)),
|
|
113
|
+
__metadata("design:paramtypes", [e2ee_keypair_service_1.E2eeKeypairService,
|
|
114
|
+
e2ee_device_store_service_1.E2eeDeviceStoreService, Boolean])
|
|
115
|
+
], TunnelRpcCryptoService);
|
|
116
|
+
//# sourceMappingURL=tunnel-rpc-crypto.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tunnel-rpc-crypto.service.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/tunnel-rpc-crypto.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { type E2eeEnvelope, type E2eeNegotiationReason, type ViewportScreen } from '@devchain/shared';
|
|
2
|
+
import { E2eeKeypairService } from '../../e2ee/services/e2ee-keypair.service';
|
|
3
|
+
import { E2eeDeviceStoreService } from '../../e2ee/services/e2ee-device-store.service';
|
|
4
|
+
export type ViewportChannelMode = 'encrypted' | 'plaintext' | 'blocked';
|
|
5
|
+
export interface ViewportChannel {
|
|
6
|
+
mode: ViewportChannelMode;
|
|
7
|
+
reason: E2eeNegotiationReason;
|
|
8
|
+
sealScreen?: (sessionId: string, seq: number, screen: ViewportScreen) => Promise<E2eeEnvelope>;
|
|
9
|
+
}
|
|
10
|
+
export declare class TunnelViewportCryptoService {
|
|
11
|
+
private readonly keypair;
|
|
12
|
+
private readonly deviceStore;
|
|
13
|
+
private readonly e2eeRequired;
|
|
14
|
+
constructor(keypair: E2eeKeypairService, deviceStore: E2eeDeviceStoreService, e2eeRequired?: boolean);
|
|
15
|
+
private readonly randomBytes;
|
|
16
|
+
resolveViewportChannel(instanceId: string | null): Promise<ViewportChannel>;
|
|
17
|
+
private ctx;
|
|
18
|
+
private selectPeerDevice;
|
|
19
|
+
private isUsable;
|
|
20
|
+
}
|
|
@@ -0,0 +1,114 @@
|
|
|
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.TunnelViewportCryptoService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const crypto_1 = require("crypto");
|
|
18
|
+
const shared_1 = require("@devchain/shared");
|
|
19
|
+
const logger_1 = require("../../../common/logging/logger");
|
|
20
|
+
const e2ee_keypair_service_1 = require("../../e2ee/services/e2ee-keypair.service");
|
|
21
|
+
const e2ee_device_store_service_1 = require("../../e2ee/services/e2ee-device-store.service");
|
|
22
|
+
const tunnel_rpc_crypto_service_1 = require("./tunnel-rpc-crypto.service");
|
|
23
|
+
const logger = (0, logger_1.createLogger)('TunnelViewportCrypto');
|
|
24
|
+
let TunnelViewportCryptoService = class TunnelViewportCryptoService {
|
|
25
|
+
constructor(keypair, deviceStore, e2eeRequired = false) {
|
|
26
|
+
this.keypair = keypair;
|
|
27
|
+
this.deviceStore = deviceStore;
|
|
28
|
+
this.e2eeRequired = e2eeRequired;
|
|
29
|
+
this.randomBytes = (n) => new Uint8Array((0, crypto_1.randomBytes)(n));
|
|
30
|
+
}
|
|
31
|
+
async resolveViewportChannel(instanceId) {
|
|
32
|
+
if (!instanceId) {
|
|
33
|
+
return { mode: 'plaintext', reason: 'plaintext-mixed' };
|
|
34
|
+
}
|
|
35
|
+
let pcKid;
|
|
36
|
+
let pcPrivateKey;
|
|
37
|
+
let selfCap;
|
|
38
|
+
try {
|
|
39
|
+
const kp = await this.keypair.getOrCreate();
|
|
40
|
+
pcKid = kp.kid;
|
|
41
|
+
pcPrivateKey = kp.privateKey;
|
|
42
|
+
selfCap = (0, shared_1.buildE2eeCapability)({
|
|
43
|
+
e2eeRequired: this.e2eeRequired,
|
|
44
|
+
key: { kid: kp.kid, publicKeyB64: Buffer.from(kp.publicKey).toString('base64') },
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
catch (err) {
|
|
48
|
+
if (this.e2eeRequired) {
|
|
49
|
+
logger.warn({ err }, 'E2EE keypair unavailable — viewport BLOCKED (E2EE required)');
|
|
50
|
+
return { mode: 'blocked', reason: 'peer-incapable-required' };
|
|
51
|
+
}
|
|
52
|
+
logger.warn({ err }, 'E2EE keypair unavailable — viewport falls back to plaintext');
|
|
53
|
+
return { mode: 'plaintext', reason: 'plaintext-mixed' };
|
|
54
|
+
}
|
|
55
|
+
const device = this.selectPeerDevice();
|
|
56
|
+
const peerCap = device
|
|
57
|
+
? { v: 1, envelopeVersion: 1, e2eeSupported: true, e2eeRequired: false }
|
|
58
|
+
: null;
|
|
59
|
+
const neg = (0, shared_1.negotiateE2ee)(selfCap, peerCap, { hasExistingKey: !!device });
|
|
60
|
+
if (neg.mode !== 'encrypted' || !device) {
|
|
61
|
+
return { mode: neg.mode, reason: neg.reason };
|
|
62
|
+
}
|
|
63
|
+
const devicePub = (0, shared_1.base64ToBytes)(device.publicKeyB64);
|
|
64
|
+
const sharedKey = (0, shared_1.deriveSharedKey)(pcPrivateKey, devicePub);
|
|
65
|
+
const provider = {
|
|
66
|
+
resolveSealKey: () => ({ kid: pcKid, key: sharedKey }),
|
|
67
|
+
getKeyById: (kid) => (kid === pcKid || kid === device.kid ? sharedKey : undefined),
|
|
68
|
+
};
|
|
69
|
+
const service = new shared_1.CryptoEnvelopeService(provider, this.randomBytes);
|
|
70
|
+
return {
|
|
71
|
+
mode: 'encrypted',
|
|
72
|
+
reason: neg.reason,
|
|
73
|
+
sealScreen: (sessionId, seq, screen) => service.seal(screen, this.ctx(instanceId, sessionId, seq)),
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
ctx(instanceId, sessionId, seq) {
|
|
77
|
+
return {
|
|
78
|
+
lane: 'viewport',
|
|
79
|
+
direction: 'pc-to-mobile',
|
|
80
|
+
instanceId,
|
|
81
|
+
routeKey: sessionId,
|
|
82
|
+
seq,
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
selectPeerDevice() {
|
|
86
|
+
const usable = this.deviceStore.list().filter((d) => this.isUsable(d));
|
|
87
|
+
if (usable.length === 0)
|
|
88
|
+
return null;
|
|
89
|
+
if (usable.length === 1)
|
|
90
|
+
return usable[0];
|
|
91
|
+
const [latest] = [...usable].sort((a, b) => (a.addedAt < b.addedAt ? 1 : -1));
|
|
92
|
+
logger.debug({ count: usable.length, kid: latest.kid }, 'Multiple paired devices — sealing viewport for the most recently added (v1 single-recipient)');
|
|
93
|
+
return latest;
|
|
94
|
+
}
|
|
95
|
+
isUsable(device) {
|
|
96
|
+
if (device.trust === 'revoked')
|
|
97
|
+
return false;
|
|
98
|
+
try {
|
|
99
|
+
return (0, shared_1.base64ToBytes)(device.publicKeyB64).length === shared_1.X25519_PUBLIC_KEY_BYTES;
|
|
100
|
+
}
|
|
101
|
+
catch {
|
|
102
|
+
return false;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
exports.TunnelViewportCryptoService = TunnelViewportCryptoService;
|
|
107
|
+
exports.TunnelViewportCryptoService = TunnelViewportCryptoService = __decorate([
|
|
108
|
+
(0, common_1.Injectable)(),
|
|
109
|
+
__param(2, (0, common_1.Optional)()),
|
|
110
|
+
__param(2, (0, common_1.Inject)(tunnel_rpc_crypto_service_1.E2EE_REQUIRED_POLICY)),
|
|
111
|
+
__metadata("design:paramtypes", [e2ee_keypair_service_1.E2eeKeypairService,
|
|
112
|
+
e2ee_device_store_service_1.E2eeDeviceStoreService, Boolean])
|
|
113
|
+
], TunnelViewportCryptoService);
|
|
114
|
+
//# sourceMappingURL=tunnel-viewport-crypto.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tunnel-viewport-crypto.service.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/tunnel-viewport-crypto.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { TunnelViewportFrame } from '@devchain/shared';
|
|
2
|
+
export declare abstract class ViewportFrameSink {
|
|
3
|
+
abstract sendViewport(frame: TunnelViewportFrame): boolean;
|
|
4
|
+
abstract onPushReady(listener: () => void): () => void;
|
|
5
|
+
abstract getInstanceId(): string | null;
|
|
6
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"viewport-frame-sink.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/viewport-frame-sink.ts"],"names":[],"mappings":";;;AAWA,MAAsB,iBAAiB;CAWtC;AAXD,8CAWC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { OnModuleDestroy, OnModuleInit } from '@nestjs/common';
|
|
2
|
+
import { ActiveSessionLookup } from '../../sessions/services/active-session-lookup.service';
|
|
3
|
+
import { TerminalViewportFacade } from '../../terminal/services/terminal-viewport/terminal-viewport.facade';
|
|
4
|
+
import { ViewportFrameSink } from './viewport-frame-sink';
|
|
5
|
+
import { TunnelViewportCryptoService } from './tunnel-viewport-crypto.service';
|
|
6
|
+
export declare class ViewportStreamerService implements OnModuleInit, OnModuleDestroy {
|
|
7
|
+
private readonly activeSessions;
|
|
8
|
+
private readonly terminalViewport;
|
|
9
|
+
private readonly sink;
|
|
10
|
+
private readonly viewportCrypto;
|
|
11
|
+
private readonly subscriptions;
|
|
12
|
+
private subscriptionSeq;
|
|
13
|
+
private detachReadyListener;
|
|
14
|
+
constructor(activeSessions: ActiveSessionLookup, terminalViewport: TerminalViewportFacade, sink: ViewportFrameSink, viewportCrypto: TunnelViewportCryptoService);
|
|
15
|
+
onModuleInit(): void;
|
|
16
|
+
subscribe(params: Record<string, unknown>): Promise<{
|
|
17
|
+
subscriptionId: string;
|
|
18
|
+
}>;
|
|
19
|
+
unsubscribe(params: Record<string, unknown>): {
|
|
20
|
+
ok: boolean;
|
|
21
|
+
};
|
|
22
|
+
onModuleDestroy(): void;
|
|
23
|
+
private markDirty;
|
|
24
|
+
private scheduleCapture;
|
|
25
|
+
private runScheduledCapture;
|
|
26
|
+
private captureAndSend;
|
|
27
|
+
private reanchorAll;
|
|
28
|
+
private teardown;
|
|
29
|
+
private assertSessionInProject;
|
|
30
|
+
}
|
|
@@ -0,0 +1,228 @@
|
|
|
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.ViewportStreamerService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const shared_1 = require("@devchain/shared");
|
|
18
|
+
const active_session_lookup_service_1 = require("../../sessions/services/active-session-lookup.service");
|
|
19
|
+
const terminal_viewport_facade_1 = require("../../terminal/services/terminal-viewport/terminal-viewport.facade");
|
|
20
|
+
const error_types_1 = require("../../../common/errors/error-types");
|
|
21
|
+
const logger_1 = require("../../../common/logging/logger");
|
|
22
|
+
const viewport_frame_sink_1 = require("./viewport-frame-sink");
|
|
23
|
+
const tunnel_viewport_crypto_service_1 = require("./tunnel-viewport-crypto.service");
|
|
24
|
+
const logger = (0, logger_1.createLogger)('ViewportStreamer');
|
|
25
|
+
const MIN_CAPTURE_INTERVAL_MS = 350;
|
|
26
|
+
let ViewportStreamerService = class ViewportStreamerService {
|
|
27
|
+
constructor(activeSessions, terminalViewport, sink, viewportCrypto) {
|
|
28
|
+
this.activeSessions = activeSessions;
|
|
29
|
+
this.terminalViewport = terminalViewport;
|
|
30
|
+
this.sink = sink;
|
|
31
|
+
this.viewportCrypto = viewportCrypto;
|
|
32
|
+
this.subscriptions = new Map();
|
|
33
|
+
this.subscriptionSeq = 0;
|
|
34
|
+
this.detachReadyListener = null;
|
|
35
|
+
}
|
|
36
|
+
onModuleInit() {
|
|
37
|
+
this.detachReadyListener = this.sink.onPushReady(() => this.reanchorAll());
|
|
38
|
+
}
|
|
39
|
+
async subscribe(params) {
|
|
40
|
+
const sessionId = params['sessionId'];
|
|
41
|
+
const projectId = params['projectId'];
|
|
42
|
+
await this.assertSessionInProject(sessionId, projectId);
|
|
43
|
+
if (!this.terminalViewport.hasSession(sessionId)) {
|
|
44
|
+
throw new error_types_1.AppError('No running terminal session for this session id. Launch/restore it first.', 'SESSION_NOT_RUNNING', 409, { sessionId, projectId });
|
|
45
|
+
}
|
|
46
|
+
const subscriptionId = `vp-${++this.subscriptionSeq}`;
|
|
47
|
+
const sub = {
|
|
48
|
+
subscriptionId,
|
|
49
|
+
sessionId,
|
|
50
|
+
seq: 0,
|
|
51
|
+
lastScreen: null,
|
|
52
|
+
detachData: () => { },
|
|
53
|
+
disposed: false,
|
|
54
|
+
dirty: false,
|
|
55
|
+
capturing: false,
|
|
56
|
+
lastCaptureAt: 0,
|
|
57
|
+
timer: null,
|
|
58
|
+
};
|
|
59
|
+
this.subscriptions.set(subscriptionId, sub);
|
|
60
|
+
sub.detachData = this.terminalViewport.onData(sessionId, () => this.markDirty(sub));
|
|
61
|
+
await this.captureAndSend(sub);
|
|
62
|
+
return { subscriptionId };
|
|
63
|
+
}
|
|
64
|
+
unsubscribe(params) {
|
|
65
|
+
const subscriptionId = params['subscriptionId'];
|
|
66
|
+
const sub = this.subscriptions.get(subscriptionId);
|
|
67
|
+
if (!sub)
|
|
68
|
+
return { ok: false };
|
|
69
|
+
this.teardown(sub);
|
|
70
|
+
return { ok: true };
|
|
71
|
+
}
|
|
72
|
+
onModuleDestroy() {
|
|
73
|
+
this.detachReadyListener?.();
|
|
74
|
+
this.detachReadyListener = null;
|
|
75
|
+
for (const sub of [...this.subscriptions.values()]) {
|
|
76
|
+
this.teardown(sub);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
markDirty(sub) {
|
|
80
|
+
if (sub.disposed)
|
|
81
|
+
return;
|
|
82
|
+
sub.dirty = true;
|
|
83
|
+
this.scheduleCapture(sub);
|
|
84
|
+
}
|
|
85
|
+
scheduleCapture(sub) {
|
|
86
|
+
if (sub.disposed || sub.timer || sub.capturing)
|
|
87
|
+
return;
|
|
88
|
+
const elapsed = Date.now() - sub.lastCaptureAt;
|
|
89
|
+
const delay = Math.max(0, MIN_CAPTURE_INTERVAL_MS - elapsed);
|
|
90
|
+
sub.timer = setTimeout(() => {
|
|
91
|
+
sub.timer = null;
|
|
92
|
+
void this.runScheduledCapture(sub);
|
|
93
|
+
}, delay);
|
|
94
|
+
if (typeof sub.timer.unref === 'function')
|
|
95
|
+
sub.timer.unref();
|
|
96
|
+
}
|
|
97
|
+
async runScheduledCapture(sub) {
|
|
98
|
+
if (sub.disposed)
|
|
99
|
+
return;
|
|
100
|
+
sub.capturing = true;
|
|
101
|
+
sub.dirty = false;
|
|
102
|
+
try {
|
|
103
|
+
await this.captureAndSend(sub);
|
|
104
|
+
}
|
|
105
|
+
finally {
|
|
106
|
+
sub.capturing = false;
|
|
107
|
+
}
|
|
108
|
+
if (!sub.disposed && sub.dirty)
|
|
109
|
+
this.scheduleCapture(sub);
|
|
110
|
+
}
|
|
111
|
+
async captureAndSend(sub) {
|
|
112
|
+
if (sub.disposed)
|
|
113
|
+
return;
|
|
114
|
+
sub.lastCaptureAt = Date.now();
|
|
115
|
+
const capture = await this.terminalViewport.capture(sub.sessionId);
|
|
116
|
+
if (sub.disposed)
|
|
117
|
+
return;
|
|
118
|
+
if (!capture) {
|
|
119
|
+
if (!this.terminalViewport.hasSession(sub.sessionId)) {
|
|
120
|
+
logger.debug({ sessionId: sub.sessionId }, 'Viewport session ended; tearing down');
|
|
121
|
+
this.teardown(sub);
|
|
122
|
+
}
|
|
123
|
+
return;
|
|
124
|
+
}
|
|
125
|
+
const screen = {
|
|
126
|
+
lines: capture.lines,
|
|
127
|
+
cursor: capture.cursor,
|
|
128
|
+
cols: capture.cols,
|
|
129
|
+
rows: capture.rows,
|
|
130
|
+
};
|
|
131
|
+
const channel = await this.viewportCrypto.resolveViewportChannel(this.sink.getInstanceId());
|
|
132
|
+
if (sub.disposed)
|
|
133
|
+
return;
|
|
134
|
+
let body;
|
|
135
|
+
if (channel.mode === 'blocked') {
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
else if (channel.mode === 'encrypted') {
|
|
139
|
+
if (sub.lastScreen && diffScreens(sub.lastScreen, screen) === null)
|
|
140
|
+
return;
|
|
141
|
+
const enc = await channel.sealScreen(sub.sessionId, sub.seq, screen);
|
|
142
|
+
if (sub.disposed)
|
|
143
|
+
return;
|
|
144
|
+
body = { kind: 'enc-full', enc };
|
|
145
|
+
}
|
|
146
|
+
else {
|
|
147
|
+
body = sub.lastScreen ? diffScreens(sub.lastScreen, screen) : fullBody(screen);
|
|
148
|
+
}
|
|
149
|
+
if (!body)
|
|
150
|
+
return;
|
|
151
|
+
const frame = {
|
|
152
|
+
type: shared_1.TUNNEL_VIEWPORT_FRAME_TYPE,
|
|
153
|
+
v: shared_1.TUNNEL_VIEWPORT_FRAME_VERSION,
|
|
154
|
+
subscriptionId: sub.subscriptionId,
|
|
155
|
+
sessionId: sub.sessionId,
|
|
156
|
+
seq: sub.seq,
|
|
157
|
+
body,
|
|
158
|
+
};
|
|
159
|
+
if (this.sink.sendViewport(frame)) {
|
|
160
|
+
sub.seq += 1;
|
|
161
|
+
sub.lastScreen = screen;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
reanchorAll() {
|
|
165
|
+
for (const sub of this.subscriptions.values()) {
|
|
166
|
+
if (sub.disposed)
|
|
167
|
+
continue;
|
|
168
|
+
sub.lastScreen = null;
|
|
169
|
+
this.scheduleCapture(sub);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
teardown(sub) {
|
|
173
|
+
if (sub.disposed)
|
|
174
|
+
return;
|
|
175
|
+
sub.disposed = true;
|
|
176
|
+
if (sub.timer) {
|
|
177
|
+
clearTimeout(sub.timer);
|
|
178
|
+
sub.timer = null;
|
|
179
|
+
}
|
|
180
|
+
sub.detachData();
|
|
181
|
+
this.subscriptions.delete(sub.subscriptionId);
|
|
182
|
+
}
|
|
183
|
+
async assertSessionInProject(sessionId, projectId) {
|
|
184
|
+
const scope = await this.activeSessions.getSessionProjectScope(sessionId);
|
|
185
|
+
if (!scope) {
|
|
186
|
+
throw new error_types_1.NotFoundError('Session', sessionId);
|
|
187
|
+
}
|
|
188
|
+
if (scope.projectId !== projectId) {
|
|
189
|
+
throw new error_types_1.ForbiddenError('Session does not belong to the requested project', {
|
|
190
|
+
code: 'SESSION_PROJECT_MISMATCH',
|
|
191
|
+
sessionId,
|
|
192
|
+
projectId,
|
|
193
|
+
});
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
};
|
|
197
|
+
exports.ViewportStreamerService = ViewportStreamerService;
|
|
198
|
+
exports.ViewportStreamerService = ViewportStreamerService = __decorate([
|
|
199
|
+
(0, common_1.Injectable)(),
|
|
200
|
+
__param(2, (0, common_1.Inject)(viewport_frame_sink_1.ViewportFrameSink)),
|
|
201
|
+
__metadata("design:paramtypes", [active_session_lookup_service_1.ActiveSessionLookup,
|
|
202
|
+
terminal_viewport_facade_1.TerminalViewportFacade,
|
|
203
|
+
viewport_frame_sink_1.ViewportFrameSink,
|
|
204
|
+
tunnel_viewport_crypto_service_1.TunnelViewportCryptoService])
|
|
205
|
+
], ViewportStreamerService);
|
|
206
|
+
function fullBody(screen) {
|
|
207
|
+
return { kind: 'full', screen };
|
|
208
|
+
}
|
|
209
|
+
function diffScreens(last, next) {
|
|
210
|
+
if (last.cols !== next.cols ||
|
|
211
|
+
last.rows !== next.rows ||
|
|
212
|
+
last.lines.length !== next.lines.length) {
|
|
213
|
+
return fullBody(next);
|
|
214
|
+
}
|
|
215
|
+
const changedLines = [];
|
|
216
|
+
for (let row = 0; row < next.lines.length; row++) {
|
|
217
|
+
if (next.lines[row] !== last.lines[row]) {
|
|
218
|
+
changedLines.push({ row, text: next.lines[row] });
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
const cursorMoved = last.cursor.x !== next.cursor.x || last.cursor.y !== next.cursor.y;
|
|
222
|
+
if (changedLines.length === 0 && !cursorMoved)
|
|
223
|
+
return null;
|
|
224
|
+
return cursorMoved
|
|
225
|
+
? { kind: 'diff', changedLines, cursor: next.cursor }
|
|
226
|
+
: { kind: 'diff', changedLines };
|
|
227
|
+
}
|
|
228
|
+
//# sourceMappingURL=viewport-streamer.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"viewport-streamer.service.js","sourceRoot":"","sources":["../../../../src/modules/cloud-tunnel/services/viewport-streamer.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { E2eePairingService, type BeginQrPairingResult, type CompleteQrPairingResult } from '../services/e2ee-pairing.service';
|
|
2
|
+
interface BeginBody {
|
|
3
|
+
channelId?: string;
|
|
4
|
+
}
|
|
5
|
+
interface CompleteBody {
|
|
6
|
+
channelId?: string;
|
|
7
|
+
deviceEncPubKey?: string;
|
|
8
|
+
deviceEncKid?: string;
|
|
9
|
+
pairingMac?: string;
|
|
10
|
+
label?: string;
|
|
11
|
+
}
|
|
12
|
+
export declare class E2eePairingController {
|
|
13
|
+
private readonly pairing;
|
|
14
|
+
constructor(pairing: E2eePairingService);
|
|
15
|
+
begin(body: BeginBody): Promise<BeginQrPairingResult>;
|
|
16
|
+
complete(body: CompleteBody): Promise<CompleteQrPairingResult>;
|
|
17
|
+
}
|
|
18
|
+
export {};
|
|
@@ -0,0 +1,62 @@
|
|
|
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.E2eePairingController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const error_types_1 = require("../../../common/errors/error-types");
|
|
18
|
+
const e2ee_pairing_service_1 = require("../services/e2ee-pairing.service");
|
|
19
|
+
let E2eePairingController = class E2eePairingController {
|
|
20
|
+
constructor(pairing) {
|
|
21
|
+
this.pairing = pairing;
|
|
22
|
+
}
|
|
23
|
+
async begin(body) {
|
|
24
|
+
if (!body?.channelId)
|
|
25
|
+
throw new error_types_1.ValidationError('channelId is required');
|
|
26
|
+
return this.pairing.beginQrPairing(body.channelId);
|
|
27
|
+
}
|
|
28
|
+
async complete(body) {
|
|
29
|
+
if (!body?.channelId)
|
|
30
|
+
throw new error_types_1.ValidationError('channelId is required');
|
|
31
|
+
if (!body.deviceEncPubKey || !body.deviceEncKid || !body.pairingMac) {
|
|
32
|
+
throw new error_types_1.ValidationError('deviceEncPubKey, deviceEncKid and pairingMac are required');
|
|
33
|
+
}
|
|
34
|
+
return this.pairing.completeQrPairing({
|
|
35
|
+
channelId: body.channelId,
|
|
36
|
+
deviceEncPubKey: body.deviceEncPubKey,
|
|
37
|
+
deviceEncKid: body.deviceEncKid,
|
|
38
|
+
pairingMac: body.pairingMac,
|
|
39
|
+
...(body.label !== undefined ? { label: body.label } : {}),
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
exports.E2eePairingController = E2eePairingController;
|
|
44
|
+
__decorate([
|
|
45
|
+
(0, common_1.Post)('begin'),
|
|
46
|
+
__param(0, (0, common_1.Body)()),
|
|
47
|
+
__metadata("design:type", Function),
|
|
48
|
+
__metadata("design:paramtypes", [Object]),
|
|
49
|
+
__metadata("design:returntype", Promise)
|
|
50
|
+
], E2eePairingController.prototype, "begin", null);
|
|
51
|
+
__decorate([
|
|
52
|
+
(0, common_1.Post)('complete'),
|
|
53
|
+
__param(0, (0, common_1.Body)()),
|
|
54
|
+
__metadata("design:type", Function),
|
|
55
|
+
__metadata("design:paramtypes", [Object]),
|
|
56
|
+
__metadata("design:returntype", Promise)
|
|
57
|
+
], E2eePairingController.prototype, "complete", null);
|
|
58
|
+
exports.E2eePairingController = E2eePairingController = __decorate([
|
|
59
|
+
(0, common_1.Controller)('api/e2ee/pairing'),
|
|
60
|
+
__metadata("design:paramtypes", [e2ee_pairing_service_1.E2eePairingService])
|
|
61
|
+
], E2eePairingController);
|
|
62
|
+
//# sourceMappingURL=e2ee-pairing.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"e2ee-pairing.controller.js","sourceRoot":"","sources":["../../../../src/modules/e2ee/controllers/e2ee-pairing.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAwD;AACxD,oEAAqE;AACrE,2EAI0C;AAsBnC,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;IAChC,YAA6B,OAA2B;QAA3B,YAAO,GAAP,OAAO,CAAoB;IAAG,CAAC;IAGtD,AAAN,KAAK,CAAC,KAAK,CAAS,IAAe;QACjC,IAAI,CAAC,IAAI,EAAE,SAAS;YAAE,MAAM,IAAI,6BAAe,CAAC,uBAAuB,CAAC,CAAC;QACzE,OAAO,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACrD,CAAC;IAGK,AAAN,KAAK,CAAC,QAAQ,CAAS,IAAkB;QACvC,IAAI,CAAC,IAAI,EAAE,SAAS;YAAE,MAAM,IAAI,6BAAe,CAAC,uBAAuB,CAAC,CAAC;QACzE,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACpE,MAAM,IAAI,6BAAe,CAAC,2DAA2D,CAAC,CAAC;QACzF,CAAC;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC;YACpC,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,GAAG,CAAC,IAAI,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAC3D,CAAC,CAAC;IACL,CAAC;CACF,CAAA;AAvBY,sDAAqB;AAI1B;IADL,IAAA,aAAI,EAAC,OAAO,CAAC;IACD,WAAA,IAAA,aAAI,GAAE,CAAA;;;;kDAGlB;AAGK;IADL,IAAA,aAAI,EAAC,UAAU,CAAC;IACD,WAAA,IAAA,aAAI,GAAE,CAAA;;;;qDAYrB;gCAtBU,qBAAqB;IADjC,IAAA,mBAAU,EAAC,kBAAkB,CAAC;qCAES,yCAAkB;GAD7C,qBAAqB,CAuBjC"}
|