@theia/core 1.43.1 → 1.45.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 -6
- package/i18n/nls.cs.json +10 -3
- package/i18n/nls.de.json +10 -3
- package/i18n/nls.es.json +10 -3
- package/i18n/nls.fr.json +10 -3
- package/i18n/nls.hu.json +10 -3
- package/i18n/nls.it.json +10 -3
- package/i18n/nls.ja.json +10 -3
- package/i18n/nls.json +10 -3
- package/i18n/nls.pl.json +10 -3
- package/i18n/nls.pt-br.json +10 -3
- package/i18n/nls.pt-pt.json +10 -3
- package/i18n/nls.ru.json +10 -3
- package/i18n/nls.zh-cn.json +10 -3
- package/lib/browser/common-frontend-contribution.d.ts +10 -0
- package/lib/browser/common-frontend-contribution.d.ts.map +1 -1
- package/lib/browser/common-frontend-contribution.js +68 -10
- package/lib/browser/common-frontend-contribution.js.map +1 -1
- package/lib/browser/connection-status-service.d.ts +2 -2
- package/lib/browser/connection-status-service.d.ts.map +1 -1
- package/lib/browser/connection-status-service.js +3 -3
- package/lib/browser/connection-status-service.js.map +1 -1
- package/lib/browser/connection-status-service.spec.js +6 -6
- package/lib/browser/connection-status-service.spec.js.map +1 -1
- package/lib/browser/core-preferences.d.ts.map +1 -1
- package/lib/browser/core-preferences.js +16 -0
- package/lib/browser/core-preferences.js.map +1 -1
- package/lib/browser/dialogs.d.ts +0 -1
- package/lib/browser/dialogs.d.ts.map +1 -1
- package/lib/browser/dialogs.js +1 -34
- package/lib/browser/dialogs.js.map +1 -1
- package/lib/browser/frontend-application-module.d.ts.map +1 -1
- package/lib/browser/frontend-application-module.js +4 -0
- package/lib/browser/frontend-application-module.js.map +1 -1
- package/lib/browser/icon-theme-contribution.d.ts +1 -0
- package/lib/browser/icon-theme-contribution.d.ts.map +1 -1
- package/lib/browser/icon-theme-contribution.js +1 -0
- package/lib/browser/icon-theme-contribution.js.map +1 -1
- package/lib/browser/icon-theme-service.d.ts +1 -0
- package/lib/browser/icon-theme-service.d.ts.map +1 -1
- package/lib/browser/icon-theme-service.js.map +1 -1
- package/lib/browser/language-icon-provider.d.ts +15 -0
- package/lib/browser/language-icon-provider.d.ts.map +1 -0
- package/lib/browser/language-icon-provider.js +74 -0
- package/lib/browser/language-icon-provider.js.map +1 -0
- package/lib/browser/language-service.d.ts +22 -0
- package/lib/browser/language-service.d.ts.map +1 -1
- package/lib/browser/language-service.js +28 -0
- package/lib/browser/language-service.js.map +1 -1
- package/lib/browser/messaging/connection-source.d.ts +9 -0
- package/lib/browser/messaging/connection-source.d.ts.map +1 -0
- package/lib/browser/messaging/connection-source.js +20 -0
- package/lib/browser/messaging/connection-source.js.map +1 -0
- package/lib/browser/messaging/frontend-id-provider.d.ts +13 -0
- package/lib/browser/messaging/frontend-id-provider.d.ts.map +1 -0
- package/lib/browser/messaging/frontend-id-provider.js +40 -0
- package/lib/browser/messaging/frontend-id-provider.js.map +1 -0
- package/lib/browser/messaging/messaging-frontend-module.d.ts.map +1 -1
- package/lib/browser/messaging/messaging-frontend-module.js +18 -1
- package/lib/browser/messaging/messaging-frontend-module.js.map +1 -1
- package/lib/browser/messaging/service-connection-provider.d.ts +48 -0
- package/lib/browser/messaging/service-connection-provider.d.ts.map +1 -0
- package/lib/browser/messaging/service-connection-provider.js +115 -0
- package/lib/browser/messaging/service-connection-provider.js.map +1 -0
- package/lib/browser/messaging/ws-connection-provider.d.ts +7 -38
- package/lib/browser/messaging/ws-connection-provider.d.ts.map +1 -1
- package/lib/browser/messaging/ws-connection-provider.js +17 -121
- package/lib/browser/messaging/ws-connection-provider.js.map +1 -1
- package/lib/browser/messaging/ws-connection-source.d.ts +41 -0
- package/lib/browser/messaging/ws-connection-source.d.ts.map +1 -0
- package/lib/browser/messaging/ws-connection-source.js +210 -0
- package/lib/browser/messaging/ws-connection-source.js.map +1 -0
- package/lib/browser/preload/i18n-preload-contribution.js +1 -1
- package/lib/browser/preload/i18n-preload-contribution.js.map +1 -1
- package/lib/browser/shell/application-shell.js +1 -1
- package/lib/browser/shell/application-shell.js.map +1 -1
- package/lib/browser/tree/tree-compression/compressed-tree-widget.d.ts +1 -0
- package/lib/browser/tree/tree-compression/compressed-tree-widget.d.ts.map +1 -1
- package/lib/browser/tree/tree-compression/compressed-tree-widget.js +5 -0
- package/lib/browser/tree/tree-compression/compressed-tree-widget.js.map +1 -1
- package/lib/browser/tree/tree-widget.d.ts +6 -0
- package/lib/browser/tree/tree-widget.d.ts.map +1 -1
- package/lib/browser/tree/tree-widget.js +21 -11
- package/lib/browser/tree/tree-widget.js.map +1 -1
- package/lib/browser/user-working-directory-provider.d.ts +8 -1
- package/lib/browser/user-working-directory-provider.d.ts.map +1 -1
- package/lib/browser/user-working-directory-provider.js +22 -1
- package/lib/browser/user-working-directory-provider.js.map +1 -1
- package/lib/browser/window/default-secondary-window-service.d.ts +3 -0
- package/lib/browser/window/default-secondary-window-service.d.ts.map +1 -1
- package/lib/browser/window/default-secondary-window-service.js +55 -1
- package/lib/browser/window/default-secondary-window-service.js.map +1 -1
- package/lib/common/contribution-filter/contribution-filter.d.ts +9 -0
- package/lib/common/contribution-filter/contribution-filter.d.ts.map +1 -1
- package/lib/common/event.js +1 -1
- package/lib/common/event.js.map +1 -1
- package/lib/common/message-rpc/channel.d.ts.map +1 -1
- package/lib/common/message-rpc/channel.js +7 -1
- package/lib/common/message-rpc/channel.js.map +1 -1
- package/lib/common/message-rpc/message-buffer.d.ts +2 -0
- package/lib/common/message-rpc/message-buffer.d.ts.map +1 -1
- package/lib/common/message-rpc/message-buffer.js +4 -0
- package/lib/common/message-rpc/message-buffer.js.map +1 -1
- package/lib/common/message-rpc/uint8-array-message-buffer.d.ts +1 -0
- package/lib/common/message-rpc/uint8-array-message-buffer.d.ts.map +1 -1
- package/lib/common/message-rpc/uint8-array-message-buffer.js +6 -0
- package/lib/common/message-rpc/uint8-array-message-buffer.js.map +1 -1
- package/lib/common/messaging/connection-management.d.ts +25 -0
- package/lib/common/messaging/connection-management.d.ts.map +1 -0
- package/lib/common/messaging/connection-management.js +38 -0
- package/lib/common/messaging/connection-management.js.map +1 -0
- package/lib/common/messaging/handler.d.ts +1 -0
- package/lib/common/messaging/handler.d.ts.map +1 -1
- package/lib/common/messaging/handler.js +2 -1
- package/lib/common/messaging/handler.js.map +1 -1
- package/lib/common/messaging/socket-write-buffer.d.ts +11 -0
- package/lib/common/messaging/socket-write-buffer.d.ts.map +1 -0
- package/lib/common/messaging/socket-write-buffer.js +50 -0
- package/lib/common/messaging/socket-write-buffer.js.map +1 -0
- package/lib/common/messaging/web-socket-channel.d.ts +7 -35
- package/lib/common/messaging/web-socket-channel.d.ts.map +1 -1
- package/lib/common/messaging/web-socket-channel.js +20 -9
- package/lib/common/messaging/web-socket-channel.js.map +1 -1
- package/lib/common/nls.js +12 -1
- package/lib/common/nls.js.map +1 -1
- package/lib/electron-browser/messaging/electron-frontend-id-provider.d.ts +5 -0
- package/lib/electron-browser/messaging/electron-frontend-id-provider.d.ts.map +1 -0
- package/lib/{electron-node/token/electron-token-messaging-contribution.js → electron-browser/messaging/electron-frontend-id-provider.js} +9 -28
- package/lib/electron-browser/messaging/electron-frontend-id-provider.js.map +1 -0
- package/lib/electron-browser/messaging/electron-ipc-connection-source.d.ts +24 -0
- package/lib/electron-browser/messaging/electron-ipc-connection-source.d.ts.map +1 -0
- package/lib/electron-browser/messaging/{electron-ipc-connection-provider.js → electron-ipc-connection-source.js} +19 -19
- package/lib/electron-browser/messaging/electron-ipc-connection-source.js.map +1 -0
- package/lib/electron-browser/messaging/electron-local-ws-connection-source.d.ts +7 -0
- package/lib/electron-browser/messaging/electron-local-ws-connection-source.d.ts.map +1 -0
- package/lib/electron-browser/messaging/{electron-local-ws-connection-provider.js → electron-local-ws-connection-source.js} +7 -7
- package/lib/electron-browser/messaging/electron-local-ws-connection-source.js.map +1 -0
- package/lib/electron-browser/messaging/electron-messaging-frontend-module.d.ts.map +1 -1
- package/lib/electron-browser/messaging/electron-messaging-frontend-module.js +45 -13
- package/lib/electron-browser/messaging/electron-messaging-frontend-module.js.map +1 -1
- package/lib/electron-browser/messaging/electron-ws-connection-source.d.ts +12 -0
- package/lib/electron-browser/messaging/electron-ws-connection-source.d.ts.map +1 -0
- package/lib/electron-browser/messaging/{electron-ws-connection-provider.js → electron-ws-connection-source.js} +14 -21
- package/lib/electron-browser/messaging/electron-ws-connection-source.js.map +1 -0
- package/lib/electron-browser/preload.d.ts.map +1 -1
- package/lib/electron-browser/preload.js +11 -0
- package/lib/electron-browser/preload.js.map +1 -1
- package/lib/electron-browser/window/electron-secondary-window-service.d.ts +1 -1
- package/lib/electron-browser/window/electron-secondary-window-service.d.ts.map +1 -1
- package/lib/electron-browser/window/electron-window-module.js +2 -2
- package/lib/electron-browser/window/electron-window-module.js.map +1 -1
- package/lib/electron-browser/window/electron-window-preferences.js +1 -1
- package/lib/electron-browser/window/electron-window-preferences.js.map +1 -1
- package/lib/electron-browser/window/electron-window-service.d.ts +4 -0
- package/lib/electron-browser/window/electron-window-service.d.ts.map +1 -1
- package/lib/electron-browser/window/electron-window-service.js +13 -0
- package/lib/electron-browser/window/electron-window-service.js.map +1 -1
- package/lib/electron-common/electron-api.d.ts +7 -0
- package/lib/electron-common/electron-api.d.ts.map +1 -1
- package/lib/electron-common/electron-api.js +3 -1
- package/lib/electron-common/electron-api.js.map +1 -1
- package/lib/electron-main/electron-api-main.d.ts +1 -0
- package/lib/electron-main/electron-api-main.d.ts.map +1 -1
- package/lib/electron-main/electron-api-main.js +15 -0
- package/lib/electron-main/electron-api-main.js.map +1 -1
- package/lib/electron-main/electron-main-application-module.js +5 -5
- package/lib/electron-main/electron-main-application-module.js.map +1 -1
- package/lib/electron-main/electron-main-application.d.ts +9 -13
- package/lib/electron-main/electron-main-application.d.ts.map +1 -1
- package/lib/electron-main/electron-main-application.js +60 -28
- package/lib/electron-main/electron-main-application.js.map +1 -1
- package/lib/electron-main/messaging/electron-connection-handler.d.ts.map +1 -0
- package/lib/electron-main/messaging/electron-connection-handler.js.map +1 -0
- package/lib/electron-main/messaging/electron-messaging-contribution.d.ts +13 -22
- package/lib/electron-main/messaging/electron-messaging-contribution.d.ts.map +1 -1
- package/lib/electron-main/messaging/electron-messaging-contribution.js +39 -39
- package/lib/electron-main/messaging/electron-messaging-contribution.js.map +1 -1
- package/lib/electron-main/messaging/electron-messaging-service.d.ts.map +1 -1
- package/lib/electron-main/messaging/electron-messaging-service.js.map +1 -1
- package/lib/electron-main/theia-electron-window.d.ts +2 -2
- package/lib/electron-main/theia-electron-window.d.ts.map +1 -1
- package/lib/electron-main/theia-electron-window.js +3 -2
- package/lib/electron-main/theia-electron-window.js.map +1 -1
- package/lib/node/backend-application.d.ts +2 -0
- package/lib/node/backend-application.d.ts.map +1 -1
- package/lib/node/backend-application.js +11 -9
- package/lib/node/backend-application.js.map +1 -1
- package/lib/node/cli.d.ts +1 -1
- package/lib/node/cli.d.ts.map +1 -1
- package/lib/node/cli.js +9 -5
- package/lib/node/cli.js.map +1 -1
- package/lib/node/cli.spec.js +3 -3
- package/lib/node/cli.spec.js.map +1 -1
- package/lib/node/env-variables/env-variables-server.d.ts +3 -0
- package/lib/node/env-variables/env-variables-server.d.ts.map +1 -1
- package/lib/node/env-variables/env-variables-server.js +25 -1
- package/lib/node/env-variables/env-variables-server.js.map +1 -1
- package/lib/node/i18n/localization-server.d.ts +1 -1
- package/lib/node/i18n/localization-server.d.ts.map +1 -1
- package/lib/node/messaging/default-messaging-service.d.ts +29 -0
- package/lib/node/messaging/default-messaging-service.d.ts.map +1 -0
- package/lib/node/messaging/default-messaging-service.js +140 -0
- package/lib/node/messaging/default-messaging-service.js.map +1 -0
- package/lib/node/messaging/frontend-connection-service.d.ts +7 -0
- package/lib/node/messaging/frontend-connection-service.d.ts.map +1 -0
- package/lib/node/messaging/frontend-connection-service.js +19 -0
- package/lib/node/messaging/frontend-connection-service.js.map +1 -0
- package/lib/node/messaging/ipc-protocol.js +1 -1
- package/lib/node/messaging/ipc-protocol.js.map +1 -1
- package/lib/node/messaging/messaging-backend-module.d.ts.map +1 -1
- package/lib/node/messaging/messaging-backend-module.js +23 -9
- package/lib/node/messaging/messaging-backend-module.js.map +1 -1
- package/lib/node/messaging/messaging-service.d.ts +2 -3
- package/lib/node/messaging/messaging-service.d.ts.map +1 -1
- package/lib/node/messaging/test/test-web-socket-channel.d.ts +3 -3
- package/lib/node/messaging/test/test-web-socket-channel.d.ts.map +1 -1
- package/lib/node/messaging/test/test-web-socket-channel.js +38 -24
- package/lib/node/messaging/test/test-web-socket-channel.js.map +1 -1
- package/lib/node/messaging/websocket-endpoint.d.ts +21 -0
- package/lib/node/messaging/websocket-endpoint.d.ts.map +1 -0
- package/lib/node/messaging/websocket-endpoint.js +89 -0
- package/lib/node/messaging/websocket-endpoint.js.map +1 -0
- package/lib/node/messaging/websocket-frontend-connection-service.d.ts +30 -0
- package/lib/node/messaging/websocket-frontend-connection-service.d.ts.map +1 -0
- package/lib/node/messaging/websocket-frontend-connection-service.js +173 -0
- package/lib/node/messaging/websocket-frontend-connection-service.js.map +1 -0
- package/package.json +6 -6
- package/src/browser/common-frontend-contribution.ts +70 -9
- package/src/browser/connection-status-service.spec.ts +6 -6
- package/src/browser/connection-status-service.ts +2 -2
- package/src/browser/core-preferences.ts +16 -0
- package/src/browser/dialogs.ts +0 -34
- package/src/browser/frontend-application-module.ts +4 -0
- package/src/browser/icon-theme-contribution.ts +1 -0
- package/src/browser/icon-theme-service.ts +1 -0
- package/src/browser/language-icon-provider.ts +55 -0
- package/src/browser/language-service.ts +34 -0
- package/src/browser/messaging/connection-source.ts +26 -0
- package/src/browser/messaging/frontend-id-provider.ts +37 -0
- package/src/browser/messaging/messaging-frontend-module.ts +20 -2
- package/src/browser/messaging/service-connection-provider.ts +126 -0
- package/src/browser/messaging/ws-connection-provider.ts +16 -141
- package/src/browser/messaging/ws-connection-source.ts +210 -0
- package/src/browser/preload/i18n-preload-contribution.ts +1 -1
- package/src/browser/shell/application-shell.ts +1 -1
- package/src/browser/style/index.css +1 -0
- package/src/browser/style/os.css +87 -0
- package/src/browser/tree/tree-compression/compressed-tree-widget.tsx +27 -7
- package/src/browser/tree/tree-widget.tsx +21 -10
- package/src/browser/user-working-directory-provider.ts +32 -3
- package/src/browser/window/default-secondary-window-service.ts +54 -1
- package/src/common/contribution-filter/contribution-filter.ts +9 -0
- package/src/common/event.ts +1 -1
- package/src/common/i18n/nls.metadata.json +7695 -7220
- package/src/common/message-rpc/channel.ts +5 -1
- package/src/common/message-rpc/message-buffer.ts +6 -0
- package/src/common/message-rpc/uint8-array-message-buffer.ts +7 -0
- package/src/common/messaging/connection-management.ts +43 -0
- package/src/common/messaging/handler.ts +2 -0
- package/src/common/messaging/socket-write-buffer.ts +52 -0
- package/src/common/messaging/web-socket-channel.ts +28 -45
- package/src/common/nls.ts +12 -1
- package/src/electron-browser/messaging/electron-frontend-id-provider.ts +25 -0
- package/src/electron-browser/messaging/{electron-ipc-connection-provider.ts → electron-ipc-connection-source.ts} +17 -13
- package/src/electron-browser/messaging/{electron-local-ws-connection-provider.ts → electron-local-ws-connection-source.ts} +2 -2
- package/src/electron-browser/messaging/electron-messaging-frontend-module.ts +49 -12
- package/src/electron-browser/messaging/{electron-ws-connection-provider.ts → electron-ws-connection-source.ts} +6 -17
- package/src/electron-browser/preload.ts +16 -1
- package/src/electron-browser/window/electron-secondary-window-service.ts +1 -1
- package/src/electron-browser/window/electron-window-module.ts +1 -1
- package/src/electron-browser/window/electron-window-preferences.ts +1 -1
- package/src/electron-browser/window/electron-window-service.ts +11 -0
- package/src/electron-common/electron-api.ts +8 -0
- package/src/electron-main/electron-api-main.ts +20 -1
- package/src/electron-main/electron-main-application-module.ts +5 -5
- package/src/electron-main/electron-main-application.ts +72 -44
- package/src/electron-main/messaging/electron-messaging-contribution.ts +45 -43
- package/src/electron-main/messaging/electron-messaging-service.ts +1 -0
- package/src/electron-main/theia-electron-window.ts +4 -3
- package/src/node/backend-application.ts +14 -11
- package/src/node/cli.spec.ts +3 -3
- package/src/node/cli.ts +9 -5
- package/src/node/env-variables/env-variables-server.ts +21 -1
- package/src/node/i18n/localization-server.ts +1 -1
- package/src/node/messaging/default-messaging-service.ts +129 -0
- package/src/node/messaging/frontend-connection-service.ts +24 -0
- package/src/node/messaging/ipc-protocol.ts +1 -1
- package/src/node/messaging/messaging-backend-module.ts +25 -10
- package/src/node/messaging/messaging-service.ts +3 -3
- package/src/node/messaging/test/test-web-socket-channel.ts +32 -27
- package/src/node/messaging/websocket-endpoint.ts +79 -0
- package/src/node/messaging/websocket-frontend-connection-service.ts +171 -0
- package/lib/common/messaging/abstract-connection-provider.d.ts +0 -45
- package/lib/common/messaging/abstract-connection-provider.d.ts.map +0 -1
- package/lib/common/messaging/abstract-connection-provider.js +0 -93
- package/lib/common/messaging/abstract-connection-provider.js.map +0 -1
- package/lib/electron-browser/messaging/electron-ipc-connection-provider.d.ts +0 -19
- package/lib/electron-browser/messaging/electron-ipc-connection-provider.d.ts.map +0 -1
- package/lib/electron-browser/messaging/electron-ipc-connection-provider.js.map +0 -1
- package/lib/electron-browser/messaging/electron-local-ws-connection-provider.d.ts +0 -7
- package/lib/electron-browser/messaging/electron-local-ws-connection-provider.d.ts.map +0 -1
- package/lib/electron-browser/messaging/electron-local-ws-connection-provider.js.map +0 -1
- package/lib/electron-browser/messaging/electron-ws-connection-provider.d.ts +0 -17
- package/lib/electron-browser/messaging/electron-ws-connection-provider.d.ts.map +0 -1
- package/lib/electron-browser/messaging/electron-ws-connection-provider.js.map +0 -1
- package/lib/electron-common/messaging/electron-connection-handler.d.ts.map +0 -1
- package/lib/electron-common/messaging/electron-connection-handler.js.map +0 -1
- package/lib/electron-node/token/electron-token-messaging-contribution.d.ts +0 -16
- package/lib/electron-node/token/electron-token-messaging-contribution.d.ts.map +0 -1
- package/lib/electron-node/token/electron-token-messaging-contribution.js.map +0 -1
- package/lib/node/messaging/messaging-contribution.d.ts +0 -44
- package/lib/node/messaging/messaging-contribution.d.ts.map +0 -1
- package/lib/node/messaging/messaging-contribution.js +0 -210
- package/lib/node/messaging/messaging-contribution.js.map +0 -1
- package/src/common/messaging/abstract-connection-provider.ts +0 -115
- package/src/electron-node/token/electron-token-messaging-contribution.ts +0 -41
- package/src/node/messaging/messaging-contribution.ts +0 -197
- /package/lib/{electron-common → electron-main}/messaging/electron-connection-handler.d.ts +0 -0
- /package/lib/{electron-common → electron-main}/messaging/electron-connection-handler.js +0 -0
- /package/src/{electron-common → electron-main}/messaging/electron-connection-handler.ts +0 -0
|
@@ -1,10 +1,13 @@
|
|
|
1
|
+
import { Disposable, Emitter, Event } from '../common';
|
|
1
2
|
export interface Language {
|
|
2
3
|
readonly id: string;
|
|
3
4
|
readonly name: string;
|
|
4
5
|
readonly extensions: Set<string>;
|
|
5
6
|
readonly filenames: Set<string>;
|
|
7
|
+
readonly iconClass?: string;
|
|
6
8
|
}
|
|
7
9
|
export declare class LanguageService {
|
|
10
|
+
protected readonly onDidChangeIconEmitter: Emitter<DidChangeIconEvent>;
|
|
8
11
|
/**
|
|
9
12
|
* It should be implemented by an extension, e.g. by the monaco extension.
|
|
10
13
|
*/
|
|
@@ -13,5 +16,24 @@ export declare class LanguageService {
|
|
|
13
16
|
* It should be implemented by an extension, e.g. by the monaco extension.
|
|
14
17
|
*/
|
|
15
18
|
getLanguage(languageId: string): Language | undefined;
|
|
19
|
+
/**
|
|
20
|
+
* It should be implemented by an extension, e.g. by the monaco extension.
|
|
21
|
+
*/
|
|
22
|
+
detectLanguage(obj: unknown): Language | undefined;
|
|
23
|
+
/**
|
|
24
|
+
* It should be implemented by an extension, e.g. by the monaco extension.
|
|
25
|
+
*/
|
|
26
|
+
registerIcon(languageId: string, iconClass: string): Disposable;
|
|
27
|
+
/**
|
|
28
|
+
* It should be implemented by an extension, e.g. by the monaco extension.
|
|
29
|
+
*/
|
|
30
|
+
getIcon(obj: unknown): string | undefined;
|
|
31
|
+
/**
|
|
32
|
+
* Emit when the icon of a particular language was changed.
|
|
33
|
+
*/
|
|
34
|
+
get onDidChangeIcon(): Event<DidChangeIconEvent>;
|
|
35
|
+
}
|
|
36
|
+
export interface DidChangeIconEvent {
|
|
37
|
+
languageId: string;
|
|
16
38
|
}
|
|
17
39
|
//# sourceMappingURL=language-service.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"language-service.d.ts","sourceRoot":"","sources":["../../src/browser/language-service.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"language-service.d.ts","sourceRoot":"","sources":["../../src/browser/language-service.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,WAAW,CAAC;AAEvD,MAAM,WAAW,QAAQ;IACrB,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,UAAU,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IACjC,QAAQ,CAAC,SAAS,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IAChC,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;CAC/B;AAED,qBACa,eAAe;IACxB,SAAS,CAAC,QAAQ,CAAC,sBAAsB,8BAAqC;IAE9E;;OAEG;IACH,IAAI,SAAS,IAAI,QAAQ,EAAE,CAE1B;IAED;;OAEG;IACH,WAAW,CAAC,UAAU,EAAE,MAAM,GAAG,QAAQ,GAAG,SAAS;IAIrD;;OAEG;IACH,cAAc,CAAC,GAAG,EAAE,OAAO,GAAG,QAAQ,GAAG,SAAS;IAIlD;;OAEG;IACH,YAAY,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,UAAU;IAI/D;;OAEG;IACH,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,MAAM,GAAG,SAAS;IAIzC;;OAEG;IACH,IAAI,eAAe,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAE/C;CACJ;AAED,MAAM,WAAW,kBAAkB;IAC/B,UAAU,EAAE,MAAM,CAAC;CACtB"}
|
|
@@ -23,7 +23,11 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
23
23
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
24
24
|
exports.LanguageService = void 0;
|
|
25
25
|
const inversify_1 = require("inversify");
|
|
26
|
+
const common_1 = require("../common");
|
|
26
27
|
let LanguageService = class LanguageService {
|
|
28
|
+
constructor() {
|
|
29
|
+
this.onDidChangeIconEmitter = new common_1.Emitter();
|
|
30
|
+
}
|
|
27
31
|
/**
|
|
28
32
|
* It should be implemented by an extension, e.g. by the monaco extension.
|
|
29
33
|
*/
|
|
@@ -36,6 +40,30 @@ let LanguageService = class LanguageService {
|
|
|
36
40
|
getLanguage(languageId) {
|
|
37
41
|
return undefined;
|
|
38
42
|
}
|
|
43
|
+
/**
|
|
44
|
+
* It should be implemented by an extension, e.g. by the monaco extension.
|
|
45
|
+
*/
|
|
46
|
+
detectLanguage(obj) {
|
|
47
|
+
return undefined;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* It should be implemented by an extension, e.g. by the monaco extension.
|
|
51
|
+
*/
|
|
52
|
+
registerIcon(languageId, iconClass) {
|
|
53
|
+
return common_1.Disposable.NULL;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* It should be implemented by an extension, e.g. by the monaco extension.
|
|
57
|
+
*/
|
|
58
|
+
getIcon(obj) {
|
|
59
|
+
return undefined;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Emit when the icon of a particular language was changed.
|
|
63
|
+
*/
|
|
64
|
+
get onDidChangeIcon() {
|
|
65
|
+
return this.onDidChangeIconEmitter.event;
|
|
66
|
+
}
|
|
39
67
|
};
|
|
40
68
|
LanguageService = __decorate([
|
|
41
69
|
(0, inversify_1.injectable)()
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"language-service.js","sourceRoot":"","sources":["../../src/browser/language-service.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,yCAAyC;AACzC,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;;;;;;;AAEhF,yCAAuC;
|
|
1
|
+
{"version":3,"file":"language-service.js","sourceRoot":"","sources":["../../src/browser/language-service.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,yCAAyC;AACzC,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;;;;;;;AAEhF,yCAAuC;AACvC,sCAAuD;AAWvD,IAAa,eAAe,GAA5B,MAAa,eAAe;IAA5B;QACuB,2BAAsB,GAAG,IAAI,gBAAO,EAAsB,CAAC;IA2ClF,CAAC;IAzCG;;OAEG;IACH,IAAI,SAAS;QACT,OAAO,EAAE,CAAC;IACd,CAAC;IAED;;OAEG;IACH,WAAW,CAAC,UAAkB;QAC1B,OAAO,SAAS,CAAC;IACrB,CAAC;IAED;;OAEG;IACH,cAAc,CAAC,GAAY;QACvB,OAAO,SAAS,CAAC;IACrB,CAAC;IAED;;OAEG;IACH,YAAY,CAAC,UAAkB,EAAE,SAAiB;QAC9C,OAAO,mBAAU,CAAC,IAAI,CAAC;IAC3B,CAAC;IAED;;OAEG;IACH,OAAO,CAAC,GAAY;QAChB,OAAO,SAAS,CAAC;IACrB,CAAC;IAED;;OAEG;IACH,IAAI,eAAe;QACf,OAAO,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC;IAC7C,CAAC;CACJ,CAAA;AA5CY,eAAe;IAD3B,IAAA,sBAAU,GAAE;GACA,eAAe,CA4C3B;AA5CY,0CAAe"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Channel, Event } from '../../common';
|
|
2
|
+
export declare const ConnectionSource: unique symbol;
|
|
3
|
+
/**
|
|
4
|
+
* A ConnectionSource creates a Channel. The channel is valid until it sends a close event.
|
|
5
|
+
*/
|
|
6
|
+
export interface ConnectionSource {
|
|
7
|
+
onConnectionDidOpen: Event<Channel>;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=connection-source.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connection-source.d.ts","sourceRoot":"","sources":["../../../src/browser/messaging/connection-source.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AAE9C,eAAO,MAAM,gBAAgB,eAA6B,CAAC;AAE3D;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC7B,mBAAmB,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;CACvC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2023 STMicroelectronics and others.
|
|
4
|
+
//
|
|
5
|
+
// This program and the accompanying materials are made available under the
|
|
6
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
7
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
8
|
+
//
|
|
9
|
+
// This Source Code may also be made available under the following Secondary
|
|
10
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
11
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
12
|
+
// with the GNU Classpath Exception which is available at
|
|
13
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
14
|
+
//
|
|
15
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
16
|
+
// *****************************************************************************
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.ConnectionSource = void 0;
|
|
19
|
+
exports.ConnectionSource = Symbol('ConnectionSource');
|
|
20
|
+
//# sourceMappingURL=connection-source.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connection-source.js","sourceRoot":"","sources":["../../../src/browser/messaging/connection-source.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,oDAAoD;AACpD,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;AAInE,QAAA,gBAAgB,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export declare const FrontendIdProvider: unique symbol;
|
|
2
|
+
/**
|
|
3
|
+
* A FrontendIdProvider computes an id for an instance of the front end that may be reconnected to a back end
|
|
4
|
+
* connection context.
|
|
5
|
+
*/
|
|
6
|
+
export interface FrontendIdProvider {
|
|
7
|
+
getId(): string;
|
|
8
|
+
}
|
|
9
|
+
export declare class BrowserFrontendIdProvider implements FrontendIdProvider {
|
|
10
|
+
protected readonly id: string;
|
|
11
|
+
getId(): string;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=frontend-id-provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"frontend-id-provider.d.ts","sourceRoot":"","sources":["../../../src/browser/messaging/frontend-id-provider.ts"],"names":[],"mappings":"AAmBA,eAAO,MAAM,kBAAkB,eAA+B,CAAC;AAE/D;;;GAGG;AACH,MAAM,WAAW,kBAAkB;IAC/B,KAAK,IAAI,MAAM,CAAC;CACnB;AAED,qBACa,yBAA0B,YAAW,kBAAkB;IAChE,SAAS,CAAC,QAAQ,CAAC,EAAE,SAAkB;IAEvC,KAAK,IAAI,MAAM;CAGlB"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2023 STMicroelectronics and others.
|
|
4
|
+
//
|
|
5
|
+
// This program and the accompanying materials are made available under the
|
|
6
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
7
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
8
|
+
//
|
|
9
|
+
// This Source Code may also be made available under the following Secondary
|
|
10
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
11
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
12
|
+
// with the GNU Classpath Exception which is available at
|
|
13
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
14
|
+
//
|
|
15
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
16
|
+
// *****************************************************************************
|
|
17
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
18
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
19
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
20
|
+
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;
|
|
21
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
22
|
+
};
|
|
23
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
24
|
+
exports.BrowserFrontendIdProvider = exports.FrontendIdProvider = void 0;
|
|
25
|
+
const inversify_1 = require("inversify");
|
|
26
|
+
const uuid_1 = require("../../common/uuid");
|
|
27
|
+
exports.FrontendIdProvider = Symbol('FrontendIdProvider');
|
|
28
|
+
let BrowserFrontendIdProvider = class BrowserFrontendIdProvider {
|
|
29
|
+
constructor() {
|
|
30
|
+
this.id = (0, uuid_1.generateUuid)(); // generate a new id each time we load the application
|
|
31
|
+
}
|
|
32
|
+
getId() {
|
|
33
|
+
return this.id;
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
BrowserFrontendIdProvider = __decorate([
|
|
37
|
+
(0, inversify_1.injectable)()
|
|
38
|
+
], BrowserFrontendIdProvider);
|
|
39
|
+
exports.BrowserFrontendIdProvider = BrowserFrontendIdProvider;
|
|
40
|
+
//# sourceMappingURL=frontend-id-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"frontend-id-provider.js","sourceRoot":"","sources":["../../../src/browser/messaging/frontend-id-provider.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,oDAAoD;AACpD,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;;;;;;;AAEhF,yCAAuC;AACvC,4CAAiD;AAEpC,QAAA,kBAAkB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;AAW/D,IAAa,yBAAyB,GAAtC,MAAa,yBAAyB;IAAtC;QACuB,OAAE,GAAG,IAAA,mBAAY,GAAE,CAAC,CAAC,sDAAsD;IAKlG,CAAC;IAHG,KAAK;QACD,OAAO,IAAI,CAAC,EAAE,CAAC;IACnB,CAAC;CACJ,CAAA;AANY,yBAAyB;IADrC,IAAA,sBAAU,GAAE;GACA,yBAAyB,CAMrC;AANY,8DAAyB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"messaging-frontend-module.d.ts","sourceRoot":"","sources":["../../../src/browser/messaging/messaging-frontend-module.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"messaging-frontend-module.d.ts","sourceRoot":"","sources":["../../../src/browser/messaging/messaging-frontend-module.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAU5C,eAAO,MAAM,uBAAuB,iBAclC,CAAC"}
|
|
@@ -17,9 +17,26 @@
|
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
18
|
exports.messagingFrontendModule = void 0;
|
|
19
19
|
const inversify_1 = require("inversify");
|
|
20
|
+
const frontend_id_provider_1 = require("./frontend-id-provider");
|
|
21
|
+
const ws_connection_source_1 = require("./ws-connection-source");
|
|
22
|
+
const service_connection_provider_1 = require("./service-connection-provider");
|
|
23
|
+
const connection_source_1 = require("./connection-source");
|
|
24
|
+
const connection_management_1 = require("../../common/messaging/connection-management");
|
|
20
25
|
const ws_connection_provider_1 = require("./ws-connection-provider");
|
|
26
|
+
const backendServiceProvider = Symbol('backendServiceProvider');
|
|
21
27
|
exports.messagingFrontendModule = new inversify_1.ContainerModule(bind => {
|
|
28
|
+
bind(connection_management_1.ConnectionCloseService).toDynamicValue(ctx => ws_connection_provider_1.WebSocketConnectionProvider.createProxy(ctx.container, connection_management_1.connectionCloseServicePath)).inSingletonScope();
|
|
29
|
+
bind(frontend_id_provider_1.BrowserFrontendIdProvider).toSelf().inSingletonScope();
|
|
30
|
+
bind(frontend_id_provider_1.FrontendIdProvider).toService(frontend_id_provider_1.BrowserFrontendIdProvider);
|
|
31
|
+
bind(ws_connection_source_1.WebSocketConnectionSource).toSelf().inSingletonScope();
|
|
32
|
+
bind(backendServiceProvider).toDynamicValue(ctx => {
|
|
33
|
+
bind(service_connection_provider_1.ServiceConnectionProvider).toSelf().inSingletonScope();
|
|
34
|
+
const container = ctx.container.createChild();
|
|
35
|
+
container.bind(connection_source_1.ConnectionSource).toService(ws_connection_source_1.WebSocketConnectionSource);
|
|
36
|
+
return container.get(service_connection_provider_1.ServiceConnectionProvider);
|
|
37
|
+
}).inSingletonScope();
|
|
38
|
+
bind(service_connection_provider_1.LocalConnectionProvider).toService(backendServiceProvider);
|
|
39
|
+
bind(service_connection_provider_1.RemoteConnectionProvider).toService(backendServiceProvider);
|
|
22
40
|
bind(ws_connection_provider_1.WebSocketConnectionProvider).toSelf().inSingletonScope();
|
|
23
|
-
bind(ws_connection_provider_1.LocalWebSocketConnectionProvider).toService(ws_connection_provider_1.WebSocketConnectionProvider);
|
|
24
41
|
});
|
|
25
42
|
//# sourceMappingURL=messaging-frontend-module.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"messaging-frontend-module.js","sourceRoot":"","sources":["../../../src/browser/messaging/messaging-frontend-module.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,yCAAyC;AACzC,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;AAEhF,yCAA4C;AAC5C,
|
|
1
|
+
{"version":3,"file":"messaging-frontend-module.js","sourceRoot":"","sources":["../../../src/browser/messaging/messaging-frontend-module.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,yCAAyC;AACzC,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;AAEhF,yCAA4C;AAC5C,iEAAuF;AACvF,iEAAmE;AACnE,+EAA6H;AAC7H,2DAAuD;AACvD,wFAAkH;AAClH,qEAAuE;AAEvE,MAAM,sBAAsB,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;AAEnD,QAAA,uBAAuB,GAAG,IAAI,2BAAe,CAAC,IAAI,CAAC,EAAE;IAC9D,IAAI,CAAC,8CAAsB,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,oDAA2B,CAAC,WAAW,CAAC,GAAG,CAAC,SAAS,EAAE,kDAA0B,CAAC,CAAC,CAAC,gBAAgB,EAAE,CAAC;IAC1J,IAAI,CAAC,gDAAyB,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IAC5D,IAAI,CAAC,yCAAkB,CAAC,CAAC,SAAS,CAAC,gDAAyB,CAAC,CAAC;IAC9D,IAAI,CAAC,gDAAyB,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IAC5D,IAAI,CAAC,sBAAsB,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;QAC9C,IAAI,CAAC,uDAAyB,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;QAC5D,MAAM,SAAS,GAAG,GAAG,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;QAC9C,SAAS,CAAC,IAAI,CAAC,oCAAgB,CAAC,CAAC,SAAS,CAAC,gDAAyB,CAAC,CAAC;QACtE,OAAO,SAAS,CAAC,GAAG,CAAC,uDAAyB,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC,gBAAgB,EAAE,CAAC;IACtB,IAAI,CAAC,qDAAuB,CAAC,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC;IAChE,IAAI,CAAC,sDAAwB,CAAC,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC;IACjE,IAAI,CAAC,oDAA2B,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;AAClE,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { interfaces } from 'inversify';
|
|
2
|
+
import { Channel, RpcProxy, RpcProxyFactory } from '../../common';
|
|
3
|
+
import { ChannelMultiplexer } from '../../common/message-rpc/channel';
|
|
4
|
+
import { ConnectionSource } from './connection-source';
|
|
5
|
+
export declare const LocalConnectionProvider: unique symbol;
|
|
6
|
+
export declare const RemoteConnectionProvider: unique symbol;
|
|
7
|
+
export declare namespace ServiceConnectionProvider {
|
|
8
|
+
type ConnectionHandler = (path: String, channel: Channel) => void;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* This class manages the channels for remote services in the back end
|
|
12
|
+
*/
|
|
13
|
+
export declare class ServiceConnectionProvider {
|
|
14
|
+
static createProxy<T extends object>(container: interfaces.Container, path: string, arg?: object): RpcProxy<T>;
|
|
15
|
+
static createLocalProxy<T extends object>(container: interfaces.Container, path: string, arg?: object): RpcProxy<T>;
|
|
16
|
+
static createHandler(container: interfaces.Container, path: string, arg?: object): void;
|
|
17
|
+
protected readonly channelHandlers: Map<string, ServiceConnectionProvider.ConnectionHandler>;
|
|
18
|
+
/**
|
|
19
|
+
* Create a proxy object to remote interface of T type
|
|
20
|
+
* over a web socket connection for the given path and proxy factory.
|
|
21
|
+
*/
|
|
22
|
+
createProxy<T extends object>(path: string, factory: RpcProxyFactory<T>): RpcProxy<T>;
|
|
23
|
+
/**
|
|
24
|
+
* Create a proxy object to remote interface of T type
|
|
25
|
+
* over a web socket connection for the given path.
|
|
26
|
+
*
|
|
27
|
+
* An optional target can be provided to handle
|
|
28
|
+
* notifications and requests from a remote side.
|
|
29
|
+
*/
|
|
30
|
+
createProxy<T extends object>(path: string, target?: object): RpcProxy<T>;
|
|
31
|
+
protected channelMultiplexer: ChannelMultiplexer;
|
|
32
|
+
private channelReadyDeferred;
|
|
33
|
+
protected get channelReady(): Promise<void>;
|
|
34
|
+
init(): void;
|
|
35
|
+
protected connectionSource: ConnectionSource;
|
|
36
|
+
/**
|
|
37
|
+
* This method must be invoked by subclasses when they have created the main channel.
|
|
38
|
+
* @param mainChannel
|
|
39
|
+
*/
|
|
40
|
+
protected handleChannelCreated(channel: Channel): void;
|
|
41
|
+
handleChannelClosed(channel: Channel): void;
|
|
42
|
+
/**
|
|
43
|
+
* Install a connection handler for the given path.
|
|
44
|
+
*/
|
|
45
|
+
listen(path: string, handler: ServiceConnectionProvider.ConnectionHandler, reconnect: boolean): void;
|
|
46
|
+
private openChannel;
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=service-connection-provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-connection-provider.d.ts","sourceRoot":"","sources":["../../../src/browser/messaging/service-connection-provider.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAsB,UAAU,EAAiB,MAAM,WAAW,CAAC;AAC1E,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAClE,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AAEtE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAEvD,eAAO,MAAM,uBAAuB,eAAoC,CAAC;AACzE,eAAO,MAAM,wBAAwB,eAAqC,CAAC;AAE3E,yBAAiB,yBAAyB,CAAC;IACvC,KAAY,iBAAiB,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;CAC5E;AAED;;GAEG;AACH,qBACa,yBAAyB;IAElC,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,MAAM,EAAE,SAAS,EAAE,UAAU,CAAC,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC;IAI9G,MAAM,CAAC,gBAAgB,CAAC,CAAC,SAAS,MAAM,EAAE,SAAS,EAAE,UAAU,CAAC,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC;IAInH,MAAM,CAAC,aAAa,CAAC,SAAS,EAAE,UAAU,CAAC,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI;IASvF,SAAS,CAAC,QAAQ,CAAC,eAAe,2DAAkE;IAEpG;;;OAGG;IACH,WAAW,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,eAAe,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;IACrF;;;;;;OAMG;IACH,WAAW,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC;IAOzE,SAAS,CAAC,kBAAkB,EAAE,kBAAkB,CAAC;IAEjD,OAAO,CAAC,oBAAoB,CAAwB;IACpD,SAAS,KAAK,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC,CAE1C;IAGD,IAAI,IAAI,IAAI;IAKZ,SAAS,CAAC,gBAAgB,EAAE,gBAAgB,CAAC;IAE7C;;;OAGG;IACH,SAAS,CAAC,oBAAoB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAYtD,mBAAmB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAI3C;;OAEG;IACH,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,yBAAyB,CAAC,iBAAiB,EAAE,SAAS,EAAE,OAAO,GAAG,IAAI;YAStF,WAAW;CAK5B"}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2020 Ericsson and others.
|
|
4
|
+
//
|
|
5
|
+
// This program and the accompanying materials are made available under the
|
|
6
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
7
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
8
|
+
//
|
|
9
|
+
// This Source Code may also be made available under the following Secondary
|
|
10
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
11
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
12
|
+
// with the GNU Classpath Exception which is available at
|
|
13
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
14
|
+
//
|
|
15
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
16
|
+
// *****************************************************************************
|
|
17
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
18
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
19
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
20
|
+
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;
|
|
21
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
22
|
+
};
|
|
23
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
24
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
25
|
+
};
|
|
26
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
27
|
+
exports.ServiceConnectionProvider = exports.RemoteConnectionProvider = exports.LocalConnectionProvider = void 0;
|
|
28
|
+
const inversify_1 = require("inversify");
|
|
29
|
+
const common_1 = require("../../common");
|
|
30
|
+
const channel_1 = require("../../common/message-rpc/channel");
|
|
31
|
+
const promise_util_1 = require("../../common/promise-util");
|
|
32
|
+
const connection_source_1 = require("./connection-source");
|
|
33
|
+
exports.LocalConnectionProvider = Symbol('LocalConnectionProvider');
|
|
34
|
+
exports.RemoteConnectionProvider = Symbol('RemoteConnectionProvider');
|
|
35
|
+
/**
|
|
36
|
+
* This class manages the channels for remote services in the back end
|
|
37
|
+
*/
|
|
38
|
+
let ServiceConnectionProvider = class ServiceConnectionProvider {
|
|
39
|
+
constructor() {
|
|
40
|
+
this.channelHandlers = new Map();
|
|
41
|
+
this.channelReadyDeferred = new promise_util_1.Deferred();
|
|
42
|
+
}
|
|
43
|
+
static createProxy(container, path, arg) {
|
|
44
|
+
return container.get(exports.RemoteConnectionProvider).createProxy(path, arg);
|
|
45
|
+
}
|
|
46
|
+
static createLocalProxy(container, path, arg) {
|
|
47
|
+
return container.get(exports.LocalConnectionProvider).createProxy(path, arg);
|
|
48
|
+
}
|
|
49
|
+
static createHandler(container, path, arg) {
|
|
50
|
+
const remote = container.get(exports.RemoteConnectionProvider);
|
|
51
|
+
const local = container.get(exports.LocalConnectionProvider);
|
|
52
|
+
remote.createProxy(path, arg);
|
|
53
|
+
if (remote !== local) {
|
|
54
|
+
local.createProxy(path, arg);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
createProxy(path, arg) {
|
|
58
|
+
const factory = arg instanceof common_1.RpcProxyFactory ? arg : new common_1.RpcProxyFactory(arg);
|
|
59
|
+
this.listen(path, (_, c) => factory.listen(c), true);
|
|
60
|
+
return factory.createProxy();
|
|
61
|
+
}
|
|
62
|
+
get channelReady() {
|
|
63
|
+
return this.channelReadyDeferred.promise;
|
|
64
|
+
}
|
|
65
|
+
init() {
|
|
66
|
+
this.connectionSource.onConnectionDidOpen(channel => this.handleChannelCreated(channel));
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* This method must be invoked by subclasses when they have created the main channel.
|
|
70
|
+
* @param mainChannel
|
|
71
|
+
*/
|
|
72
|
+
handleChannelCreated(channel) {
|
|
73
|
+
channel.onClose(() => {
|
|
74
|
+
this.handleChannelClosed(channel);
|
|
75
|
+
});
|
|
76
|
+
this.channelMultiplexer = new channel_1.ChannelMultiplexer(channel);
|
|
77
|
+
this.channelReadyDeferred.resolve();
|
|
78
|
+
for (const entry of this.channelHandlers.entries()) {
|
|
79
|
+
this.openChannel(entry[0], entry[1]);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
handleChannelClosed(channel) {
|
|
83
|
+
this.channelReadyDeferred = new promise_util_1.Deferred();
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Install a connection handler for the given path.
|
|
87
|
+
*/
|
|
88
|
+
listen(path, handler, reconnect) {
|
|
89
|
+
this.openChannel(path, handler).then(() => {
|
|
90
|
+
if (reconnect) {
|
|
91
|
+
this.channelHandlers.set(path, handler);
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
async openChannel(path, handler) {
|
|
96
|
+
await this.channelReady;
|
|
97
|
+
const newChannel = await this.channelMultiplexer.open(path);
|
|
98
|
+
handler(path, newChannel);
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
__decorate([
|
|
102
|
+
(0, inversify_1.postConstruct)(),
|
|
103
|
+
__metadata("design:type", Function),
|
|
104
|
+
__metadata("design:paramtypes", []),
|
|
105
|
+
__metadata("design:returntype", void 0)
|
|
106
|
+
], ServiceConnectionProvider.prototype, "init", null);
|
|
107
|
+
__decorate([
|
|
108
|
+
(0, inversify_1.inject)(connection_source_1.ConnectionSource),
|
|
109
|
+
__metadata("design:type", Object)
|
|
110
|
+
], ServiceConnectionProvider.prototype, "connectionSource", void 0);
|
|
111
|
+
ServiceConnectionProvider = __decorate([
|
|
112
|
+
(0, inversify_1.injectable)()
|
|
113
|
+
], ServiceConnectionProvider);
|
|
114
|
+
exports.ServiceConnectionProvider = ServiceConnectionProvider;
|
|
115
|
+
//# sourceMappingURL=service-connection-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-connection-provider.js","sourceRoot":"","sources":["../../../src/browser/messaging/service-connection-provider.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,44 +1,13 @@
|
|
|
1
1
|
import { interfaces } from 'inversify';
|
|
2
|
-
import { RpcProxy
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
export interface WebSocketOptions {
|
|
9
|
-
/**
|
|
10
|
-
* True by default.
|
|
11
|
-
*/
|
|
12
|
-
reconnecting?: boolean;
|
|
13
|
-
}
|
|
14
|
-
export declare class WebSocketConnectionProvider extends AbstractConnectionProvider<WebSocketOptions> {
|
|
15
|
-
protected readonly onSocketDidOpenEmitter: Emitter<void>;
|
|
16
|
-
get onSocketDidOpen(): Event<void>;
|
|
17
|
-
protected readonly onSocketDidCloseEmitter: Emitter<void>;
|
|
18
|
-
get onSocketDidClose(): Event<void>;
|
|
2
|
+
import { RpcProxy } from '../../common';
|
|
3
|
+
/**
|
|
4
|
+
* @deprecated This class serves to keep API compatibility for a while. Use {@linkcode ServiceConnectionProvider} instead.
|
|
5
|
+
*/
|
|
6
|
+
export declare class WebSocketConnectionProvider {
|
|
7
|
+
private readonly remoteConnectionProvider;
|
|
19
8
|
static createProxy<T extends object>(container: interfaces.Container, path: string, arg?: object): RpcProxy<T>;
|
|
20
9
|
static createLocalProxy<T extends object>(container: interfaces.Container, path: string, arg?: object): RpcProxy<T>;
|
|
21
10
|
static createHandler(container: interfaces.Container, path: string, arg?: object): void;
|
|
22
|
-
|
|
23
|
-
constructor();
|
|
24
|
-
protected createMainChannel(): Channel;
|
|
25
|
-
protected toIWebSocket(socket: Socket): IWebSocket;
|
|
26
|
-
openChannel(path: string, handler: (channel: Channel) => void, options?: WebSocketOptions): Promise<void>;
|
|
27
|
-
/**
|
|
28
|
-
* @param path The handler to reach in the backend.
|
|
29
|
-
*/
|
|
30
|
-
protected createWebSocketUrl(path: string): string;
|
|
31
|
-
protected createHttpWebSocketUrl(path: string): string;
|
|
32
|
-
protected createEndpoint(path: string): Endpoint;
|
|
33
|
-
/**
|
|
34
|
-
* Creates a web socket for the given url
|
|
35
|
-
*/
|
|
36
|
-
protected createWebSocket(url: string): Socket;
|
|
37
|
-
/**
|
|
38
|
-
* Path for Socket.io to make its requests to.
|
|
39
|
-
*/
|
|
40
|
-
protected createSocketIoPath(url: string): string | undefined;
|
|
41
|
-
protected fireSocketDidOpen(): void;
|
|
42
|
-
protected fireSocketDidClose(): void;
|
|
11
|
+
createProxy<T extends object>(path: string, target?: object): RpcProxy<T>;
|
|
43
12
|
}
|
|
44
13
|
//# sourceMappingURL=ws-connection-provider.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ws-connection-provider.d.ts","sourceRoot":"","sources":["../../../src/browser/messaging/ws-connection-provider.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAc,UAAU,
|
|
1
|
+
{"version":3,"file":"ws-connection-provider.d.ts","sourceRoot":"","sources":["../../../src/browser/messaging/ws-connection-provider.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAc,UAAU,EAA+B,MAAM,WAAW,CAAC;AAChF,OAAO,EAAmB,QAAQ,EAAE,MAAM,cAAc,CAAC;AAMzD;;GAEG;AACH,qBACa,2BAA2B;IAEpC,OAAO,CAAC,QAAQ,CAAC,wBAAwB,CAA4B;IAErE,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,MAAM,EAAE,SAAS,EAAE,UAAU,CAAC,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC;IAI9G,MAAM,CAAC,gBAAgB,CAAC,CAAC,SAAS,MAAM,EAAE,SAAS,EAAE,UAAU,CAAC,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC;IAInH,MAAM,CAAC,aAAa,CAAC,SAAS,EAAE,UAAU,CAAC,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI;IAIvF,WAAW,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC;CAI5E"}
|
|
@@ -23,140 +23,36 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
23
23
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
24
24
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
25
25
|
};
|
|
26
|
-
var WebSocketConnectionProvider_1;
|
|
27
26
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
28
|
-
exports.WebSocketConnectionProvider =
|
|
27
|
+
exports.WebSocketConnectionProvider = void 0;
|
|
29
28
|
const inversify_1 = require("inversify");
|
|
30
29
|
const common_1 = require("../../common");
|
|
31
|
-
const
|
|
32
|
-
const abstract_connection_provider_1 = require("../../common/messaging/abstract-connection-provider");
|
|
33
|
-
const socket_io_client_1 = require("socket.io-client");
|
|
34
|
-
const web_socket_channel_1 = require("../../common/messaging/web-socket-channel");
|
|
30
|
+
const service_connection_provider_1 = require("./service-connection-provider");
|
|
35
31
|
(0, inversify_1.decorate)((0, inversify_1.injectable)(), common_1.RpcProxyFactory);
|
|
36
32
|
(0, inversify_1.decorate)((0, inversify_1.unmanaged)(), common_1.RpcProxyFactory, 0);
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
this.onSocketDidOpenEmitter = new common_1.Emitter();
|
|
42
|
-
this.onSocketDidCloseEmitter = new common_1.Emitter();
|
|
43
|
-
const url = this.createWebSocketUrl(web_socket_channel_1.WebSocketChannel.wsPath);
|
|
44
|
-
this.socket = this.createWebSocket(url);
|
|
45
|
-
this.socket.on('connect', () => {
|
|
46
|
-
this.initializeMultiplexer();
|
|
47
|
-
if (this.reconnectChannelOpeners.length > 0) {
|
|
48
|
-
this.reconnectChannelOpeners.forEach(opener => opener());
|
|
49
|
-
this.reconnectChannelOpeners = [];
|
|
50
|
-
}
|
|
51
|
-
this.socket.on('disconnect', () => this.fireSocketDidClose());
|
|
52
|
-
this.socket.on('message', () => this.onIncomingMessageActivityEmitter.fire(undefined));
|
|
53
|
-
this.fireSocketDidOpen();
|
|
54
|
-
});
|
|
55
|
-
this.socket.connect();
|
|
56
|
-
}
|
|
57
|
-
get onSocketDidOpen() {
|
|
58
|
-
return this.onSocketDidOpenEmitter.event;
|
|
59
|
-
}
|
|
60
|
-
get onSocketDidClose() {
|
|
61
|
-
return this.onSocketDidCloseEmitter.event;
|
|
62
|
-
}
|
|
33
|
+
/**
|
|
34
|
+
* @deprecated This class serves to keep API compatibility for a while. Use {@linkcode ServiceConnectionProvider} instead.
|
|
35
|
+
*/
|
|
36
|
+
let WebSocketConnectionProvider = class WebSocketConnectionProvider {
|
|
63
37
|
static createProxy(container, path, arg) {
|
|
64
|
-
return
|
|
38
|
+
return service_connection_provider_1.ServiceConnectionProvider.createProxy(container, path, arg);
|
|
65
39
|
}
|
|
66
40
|
static createLocalProxy(container, path, arg) {
|
|
67
|
-
return
|
|
41
|
+
return service_connection_provider_1.ServiceConnectionProvider.createLocalProxy(container, path, arg);
|
|
68
42
|
}
|
|
69
43
|
static createHandler(container, path, arg) {
|
|
70
|
-
|
|
71
|
-
const local = container.get(exports.LocalWebSocketConnectionProvider);
|
|
72
|
-
remote.createProxy(path, arg);
|
|
73
|
-
if (remote !== local) {
|
|
74
|
-
local.createProxy(path, arg);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
createMainChannel() {
|
|
78
|
-
return new web_socket_channel_1.WebSocketChannel(this.toIWebSocket(this.socket));
|
|
79
|
-
}
|
|
80
|
-
toIWebSocket(socket) {
|
|
81
|
-
return {
|
|
82
|
-
close: () => {
|
|
83
|
-
socket.removeAllListeners('disconnect');
|
|
84
|
-
socket.removeAllListeners('error');
|
|
85
|
-
socket.removeAllListeners('message');
|
|
86
|
-
},
|
|
87
|
-
isConnected: () => socket.connected,
|
|
88
|
-
onClose: cb => socket.on('disconnect', reason => cb(reason)),
|
|
89
|
-
onError: cb => socket.on('error', reason => cb(reason)),
|
|
90
|
-
onMessage: cb => socket.on('message', data => cb(data)),
|
|
91
|
-
send: message => socket.emit('message', message)
|
|
92
|
-
};
|
|
93
|
-
}
|
|
94
|
-
async openChannel(path, handler, options) {
|
|
95
|
-
if (this.socket.connected) {
|
|
96
|
-
return super.openChannel(path, handler, options);
|
|
97
|
-
}
|
|
98
|
-
else {
|
|
99
|
-
const openChannel = () => {
|
|
100
|
-
this.socket.off('connect', openChannel);
|
|
101
|
-
this.openChannel(path, handler, options);
|
|
102
|
-
};
|
|
103
|
-
this.socket.on('connect', openChannel);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
/**
|
|
107
|
-
* @param path The handler to reach in the backend.
|
|
108
|
-
*/
|
|
109
|
-
createWebSocketUrl(path) {
|
|
110
|
-
// Since we are using Socket.io, the path should look like the following:
|
|
111
|
-
// proto://domain.com/{path}
|
|
112
|
-
return this.createEndpoint(path).getWebSocketUrl().withPath(path).toString();
|
|
113
|
-
}
|
|
114
|
-
createHttpWebSocketUrl(path) {
|
|
115
|
-
return this.createEndpoint(path).getRestUrl().toString();
|
|
116
|
-
}
|
|
117
|
-
createEndpoint(path) {
|
|
118
|
-
return new endpoint_1.Endpoint({ path });
|
|
119
|
-
}
|
|
120
|
-
/**
|
|
121
|
-
* Creates a web socket for the given url
|
|
122
|
-
*/
|
|
123
|
-
createWebSocket(url) {
|
|
124
|
-
return (0, socket_io_client_1.io)(url, {
|
|
125
|
-
path: this.createSocketIoPath(url),
|
|
126
|
-
reconnection: true,
|
|
127
|
-
reconnectionDelay: 1000,
|
|
128
|
-
reconnectionDelayMax: 10000,
|
|
129
|
-
reconnectionAttempts: Infinity,
|
|
130
|
-
extraHeaders: {
|
|
131
|
-
// Socket.io strips the `origin` header
|
|
132
|
-
// We need to provide our own for validation
|
|
133
|
-
'fix-origin': window.location.origin
|
|
134
|
-
}
|
|
135
|
-
});
|
|
136
|
-
}
|
|
137
|
-
/**
|
|
138
|
-
* Path for Socket.io to make its requests to.
|
|
139
|
-
*/
|
|
140
|
-
createSocketIoPath(url) {
|
|
141
|
-
if (location.protocol === endpoint_1.Endpoint.PROTO_FILE) {
|
|
142
|
-
return '/socket.io';
|
|
143
|
-
}
|
|
144
|
-
let { pathname } = location;
|
|
145
|
-
if (!pathname.endsWith('/')) {
|
|
146
|
-
pathname += '/';
|
|
147
|
-
}
|
|
148
|
-
return pathname + 'socket.io';
|
|
149
|
-
}
|
|
150
|
-
fireSocketDidOpen() {
|
|
151
|
-
this.onSocketDidOpenEmitter.fire(undefined);
|
|
44
|
+
return service_connection_provider_1.ServiceConnectionProvider.createHandler(container, path, arg);
|
|
152
45
|
}
|
|
153
|
-
|
|
154
|
-
this.
|
|
46
|
+
createProxy(path, factory) {
|
|
47
|
+
return this.remoteConnectionProvider.createProxy(path, factory);
|
|
155
48
|
}
|
|
156
49
|
};
|
|
157
|
-
|
|
158
|
-
(0, inversify_1.
|
|
159
|
-
__metadata("design:
|
|
50
|
+
__decorate([
|
|
51
|
+
(0, inversify_1.inject)(service_connection_provider_1.RemoteConnectionProvider),
|
|
52
|
+
__metadata("design:type", service_connection_provider_1.ServiceConnectionProvider)
|
|
53
|
+
], WebSocketConnectionProvider.prototype, "remoteConnectionProvider", void 0);
|
|
54
|
+
WebSocketConnectionProvider = __decorate([
|
|
55
|
+
(0, inversify_1.injectable)()
|
|
160
56
|
], WebSocketConnectionProvider);
|
|
161
57
|
exports.WebSocketConnectionProvider = WebSocketConnectionProvider;
|
|
162
58
|
//# sourceMappingURL=ws-connection-provider.js.map
|