From 953ddd82e48dd206cef5ac94456549aed13b3ad5 Mon Sep 17 00:00:00 2001 From: RaindropsSys Date: Fri, 17 Nov 2023 23:25:29 +0100 Subject: Updated 30 files and deleted 2976 files (automated) --- .../matrix/node_modules/matrix-widget-api/LICENSE | 201 - .../node_modules/matrix-widget-api/README.md | 91 - .../node_modules/matrix-widget-api/dist/api.js | 5105 -------------------- .../node_modules/matrix-widget-api/dist/api.min.js | 1 - .../matrix-widget-api/lib/ClientWidgetApi.d.ts | 114 - .../matrix-widget-api/lib/ClientWidgetApi.js | 1343 ----- .../matrix-widget-api/lib/Symbols.d.ts | 3 - .../node_modules/matrix-widget-api/lib/Symbols.js | 28 - .../matrix-widget-api/lib/WidgetApi.d.ts | 265 - .../matrix-widget-api/lib/WidgetApi.js | 922 ---- .../matrix-widget-api/lib/driver/WidgetDriver.d.ts | 170 - .../matrix-widget-api/lib/driver/WidgetDriver.js | 229 - .../node_modules/matrix-widget-api/lib/index.d.ts | 46 - .../node_modules/matrix-widget-api/lib/index.js | 603 --- .../lib/interfaces/ApiVersion.d.ts | 17 - .../matrix-widget-api/lib/interfaces/ApiVersion.js | 48 - .../lib/interfaces/Capabilities.d.ts | 42 - .../lib/interfaces/Capabilities.js | 74 - .../lib/interfaces/CapabilitiesAction.d.ts | 34 - .../lib/interfaces/CapabilitiesAction.js | 5 - .../lib/interfaces/ContentLoadedAction.d.ts | 10 - .../lib/interfaces/ContentLoadedAction.js | 5 - .../lib/interfaces/GetOpenIDAction.d.ts | 26 - .../lib/interfaces/GetOpenIDAction.js | 30 - .../lib/interfaces/ICustomWidgetData.d.ts | 10 - .../lib/interfaces/ICustomWidgetData.js | 5 - .../lib/interfaces/IJitsiWidgetData.d.ts | 19 - .../lib/interfaces/IJitsiWidgetData.js | 5 - .../lib/interfaces/IRoomEvent.d.ts | 10 - .../matrix-widget-api/lib/interfaces/IRoomEvent.js | 5 - .../lib/interfaces/IStickerpickerWidgetData.d.ts | 3 - .../lib/interfaces/IStickerpickerWidgetData.js | 5 - .../matrix-widget-api/lib/interfaces/IWidget.d.ts | 50 - .../matrix-widget-api/lib/interfaces/IWidget.js | 5 - .../lib/interfaces/IWidgetApiErrorResponse.d.ts | 10 - .../lib/interfaces/IWidgetApiErrorResponse.js | 30 - .../lib/interfaces/IWidgetApiRequest.d.ts | 15 - .../lib/interfaces/IWidgetApiRequest.js | 5 - .../lib/interfaces/IWidgetApiResponse.d.ts | 9 - .../lib/interfaces/IWidgetApiResponse.js | 5 - .../lib/interfaces/ModalButtonKind.d.ts | 7 - .../lib/interfaces/ModalButtonKind.js | 32 - .../lib/interfaces/ModalWidgetActions.d.ts | 55 - .../lib/interfaces/ModalWidgetActions.js | 28 - .../lib/interfaces/NavigateAction.d.ts | 13 - .../lib/interfaces/NavigateAction.js | 5 - .../lib/interfaces/OpenIDCredentialsAction.d.ts | 17 - .../lib/interfaces/OpenIDCredentialsAction.js | 5 - .../lib/interfaces/ReadEventAction.d.ts | 22 - .../lib/interfaces/ReadEventAction.js | 5 - .../lib/interfaces/ReadRelationsAction.d.ts | 26 - .../lib/interfaces/ReadRelationsAction.js | 5 - .../lib/interfaces/ScreenshotAction.d.ts | 13 - .../lib/interfaces/ScreenshotAction.js | 5 - .../lib/interfaces/SendEventAction.d.ts | 32 - .../lib/interfaces/SendEventAction.js | 5 - .../lib/interfaces/SendToDeviceAction.d.ts | 34 - .../lib/interfaces/SendToDeviceAction.js | 5 - .../interfaces/SetModalButtonEnabledAction.d.ts | 15 - .../lib/interfaces/SetModalButtonEnabledAction.js | 5 - .../lib/interfaces/StickerAction.d.ts | 29 - .../lib/interfaces/StickerAction.js | 5 - .../lib/interfaces/StickyAction.d.ts | 16 - .../lib/interfaces/StickyAction.js | 5 - .../lib/interfaces/SupportedVersionsAction.d.ts | 14 - .../lib/interfaces/SupportedVersionsAction.js | 5 - .../lib/interfaces/TurnServerActions.d.ts | 31 - .../lib/interfaces/TurnServerActions.js | 5 - .../lib/interfaces/UserDirectorySearchAction.d.ts | 22 - .../lib/interfaces/UserDirectorySearchAction.js | 5 - .../lib/interfaces/VisibilityAction.d.ts | 13 - .../lib/interfaces/VisibilityAction.js | 5 - .../lib/interfaces/WidgetApiAction.d.ts | 49 - .../lib/interfaces/WidgetApiAction.js | 62 - .../lib/interfaces/WidgetApiDirection.d.ts | 5 - .../lib/interfaces/WidgetApiDirection.js | 40 - .../lib/interfaces/WidgetConfigAction.d.ts | 11 - .../lib/interfaces/WidgetConfigAction.js | 5 - .../lib/interfaces/WidgetKind.d.ts | 5 - .../matrix-widget-api/lib/interfaces/WidgetKind.js | 30 - .../lib/interfaces/WidgetType.d.ts | 6 - .../matrix-widget-api/lib/interfaces/WidgetType.js | 30 - .../matrix-widget-api/lib/models/Widget.d.ts | 53 - .../matrix-widget-api/lib/models/Widget.js | 134 - .../lib/models/WidgetEventCapability.d.ts | 31 - .../lib/models/WidgetEventCapability.js | 253 - .../matrix-widget-api/lib/models/WidgetParser.d.ts | 46 - .../matrix-widget-api/lib/models/WidgetParser.js | 150 - .../lib/models/validation/url.d.ts | 1 - .../matrix-widget-api/lib/models/validation/url.js | 41 - .../lib/models/validation/utils.d.ts | 1 - .../lib/models/validation/utils.js | 27 - .../lib/templating/url-template.d.ts | 12 - .../lib/templating/url-template.js | 60 - .../lib/transport/ITransport.d.ts | 67 - .../matrix-widget-api/lib/transport/ITransport.js | 5 - .../lib/transport/PostmessageTransport.d.ts | 32 - .../lib/transport/PostmessageTransport.js | 255 - .../lib/util/SimpleObservable.d.ts | 8 - .../matrix-widget-api/lib/util/SimpleObservable.js | 78 - .../node_modules/matrix-widget-api/package.json | 63 - .../matrix-widget-api/src/ClientWidgetApi.ts | 798 --- .../node_modules/matrix-widget-api/src/Symbols.ts | 19 - .../matrix-widget-api/src/WidgetApi.ts | 717 --- .../matrix-widget-api/src/driver/WidgetDriver.ts | 247 - .../node_modules/matrix-widget-api/src/index.ts | 73 - .../matrix-widget-api/src/interfaces/ApiVersion.ts | 50 - .../src/interfaces/Capabilities.ts | 71 - .../src/interfaces/CapabilitiesAction.ts | 60 - .../src/interfaces/ContentLoadedAction.ts | 28 - .../src/interfaces/GetOpenIDAction.ts | 49 - .../src/interfaces/ICustomWidgetData.ts | 27 - .../src/interfaces/IJitsiWidgetData.ts | 38 - .../matrix-widget-api/src/interfaces/IRoomEvent.ts | 26 - .../src/interfaces/IStickerpickerWidgetData.ts | 21 - .../matrix-widget-api/src/interfaces/IWidget.ts | 75 - .../src/interfaces/IWidgetApiErrorResponse.ts | 35 - .../src/interfaces/IWidgetApiRequest.ts | 37 - .../src/interfaces/IWidgetApiResponse.ts | 29 - .../src/interfaces/ModalButtonKind.ts | 23 - .../src/interfaces/ModalWidgetActions.ts | 89 - .../src/interfaces/NavigateAction.ts | 32 - .../src/interfaces/OpenIDCredentialsAction.ts | 38 - .../src/interfaces/ReadEventAction.ts | 42 - .../src/interfaces/ReadRelationsAction.ts | 48 - .../src/interfaces/ScreenshotAction.ts | 32 - .../src/interfaces/SendEventAction.ts | 57 - .../src/interfaces/SendToDeviceAction.ts | 56 - .../src/interfaces/SetModalButtonEnabledAction.ts | 34 - .../src/interfaces/StickerAction.ts | 48 - .../src/interfaces/StickyAction.ts | 36 - .../src/interfaces/SupportedVersionsAction.ts | 33 - .../src/interfaces/TurnServerActions.ts | 55 - .../src/interfaces/UserDirectorySearchAction.ts | 42 - .../src/interfaces/VisibilityAction.ts | 32 - .../src/interfaces/WidgetApiAction.ts | 72 - .../src/interfaces/WidgetApiDirection.ts | 30 - .../src/interfaces/WidgetConfigAction.ts | 29 - .../matrix-widget-api/src/interfaces/WidgetKind.ts | 21 - .../matrix-widget-api/src/interfaces/WidgetType.ts | 23 - .../matrix-widget-api/src/models/Widget.ts | 109 - .../src/models/WidgetEventCapability.ts | 204 - .../matrix-widget-api/src/models/WidgetParser.ts | 147 - .../matrix-widget-api/src/models/validation/url.ts | 32 - .../src/models/validation/utils.ts | 21 - .../src/templating/url-template.ts | 62 - .../matrix-widget-api/src/transport/ITransport.ts | 104 - .../src/transport/PostmessageTransport.ts | 203 - .../matrix-widget-api/src/util/SimpleObservable.ts | 39 - 149 files changed, 15845 deletions(-) delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/LICENSE delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/README.md delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/dist/api.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/dist/api.min.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/ClientWidgetApi.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/ClientWidgetApi.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/Symbols.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/Symbols.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/WidgetApi.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/WidgetApi.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/driver/WidgetDriver.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/driver/WidgetDriver.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/index.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/index.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ApiVersion.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ApiVersion.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/Capabilities.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/Capabilities.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/CapabilitiesAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/CapabilitiesAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ContentLoadedAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ContentLoadedAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/GetOpenIDAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/GetOpenIDAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ICustomWidgetData.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ICustomWidgetData.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IJitsiWidgetData.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IJitsiWidgetData.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IRoomEvent.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IRoomEvent.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IStickerpickerWidgetData.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IStickerpickerWidgetData.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidget.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidget.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiErrorResponse.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiErrorResponse.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiRequest.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiRequest.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiResponse.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiResponse.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalButtonKind.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalButtonKind.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalWidgetActions.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalWidgetActions.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/NavigateAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/NavigateAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/OpenIDCredentialsAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/OpenIDCredentialsAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadEventAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadEventAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadRelationsAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadRelationsAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ScreenshotAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ScreenshotAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendEventAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendEventAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendToDeviceAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendToDeviceAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SetModalButtonEnabledAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SetModalButtonEnabledAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickerAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickerAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickyAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickyAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SupportedVersionsAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SupportedVersionsAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/TurnServerActions.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/TurnServerActions.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/UserDirectorySearchAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/UserDirectorySearchAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/VisibilityAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/VisibilityAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiDirection.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiDirection.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetConfigAction.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetConfigAction.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetKind.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetKind.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetType.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetType.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/models/Widget.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/models/Widget.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetEventCapability.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetEventCapability.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetParser.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetParser.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/url.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/url.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/utils.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/utils.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/templating/url-template.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/templating/url-template.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/transport/ITransport.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/transport/ITransport.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/transport/PostmessageTransport.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/transport/PostmessageTransport.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/util/SimpleObservable.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/lib/util/SimpleObservable.js delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/package.json delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/ClientWidgetApi.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/Symbols.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/WidgetApi.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/driver/WidgetDriver.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/index.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ApiVersion.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/Capabilities.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/CapabilitiesAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ContentLoadedAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/GetOpenIDAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ICustomWidgetData.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IJitsiWidgetData.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IRoomEvent.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IStickerpickerWidgetData.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidget.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidgetApiErrorResponse.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidgetApiRequest.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidgetApiResponse.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ModalButtonKind.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ModalWidgetActions.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/NavigateAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/OpenIDCredentialsAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ReadEventAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ReadRelationsAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ScreenshotAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SendEventAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SendToDeviceAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SetModalButtonEnabledAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/StickerAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/StickyAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SupportedVersionsAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/TurnServerActions.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/UserDirectorySearchAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/VisibilityAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetApiAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetApiDirection.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetConfigAction.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetKind.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetType.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/models/Widget.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/models/WidgetEventCapability.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/models/WidgetParser.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/models/validation/url.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/models/validation/utils.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/templating/url-template.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/transport/ITransport.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/transport/PostmessageTransport.ts delete mode 100644 includes/external/matrix/node_modules/matrix-widget-api/src/util/SimpleObservable.ts (limited to 'includes/external/matrix/node_modules/matrix-widget-api') diff --git a/includes/external/matrix/node_modules/matrix-widget-api/LICENSE b/includes/external/matrix/node_modules/matrix-widget-api/LICENSE deleted file mode 100644 index 261eeb9..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/LICENSE +++ /dev/null @@ -1,201 +0,0 @@ - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "[]" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright [yyyy] [name of copyright owner] - - Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. diff --git a/includes/external/matrix/node_modules/matrix-widget-api/README.md b/includes/external/matrix/node_modules/matrix-widget-api/README.md deleted file mode 100644 index 56bef5f..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/README.md +++ /dev/null @@ -1,91 +0,0 @@ -# matrix-widget-api - -![npm](https://img.shields.io/npm/v/matrix-widget-api?style=for-the-badge) - -JavaScript/TypeScript SDK for widgets & clients to communicate. - -For help and support, visit [#matrix-widgets:matrix.org](https://matrix.to/#/#matrix-widgets:matrix.org) on Matrix. - -*Disclaimer: Widgets are not yet in the Matrix spec, so this library may not work with other implementations.* - -## Building - -To transpile this project to JavaScript, run: - -``` -yarn install -yarn build -``` - -## Using the API without a bundler - -If you're looking to drop the widget-api into a web browser without the use of a bundler, add a `script` -tag similar to the following: - -```html - -``` - -Note that the version number may need changing to match the current release. - -Once included, the widget-api will be available under `mxwidgets`. For example, `new mxwidgets.WidgetApi(...)` -to instantiate the `WidgetApi` class. - -## Usage for widgets - -The general usage for this would be: - -```typescript -const widgetId = null; // if you know the widget ID, supply it. -const api = new WidgetApi(widgetId); - -// Before doing anything else, request capabilities: -api.requestCapability(MatrixCapabilities.Screenshots); -api.requestCapabilities(StickerpickerCapabilities); - -// Add custom action handlers (if needed) -api.on(`action:${WidgetApiToWidgetAction.UpdateVisibility}`, (ev: CustomEvent) => { - ev.preventDefault(); // we're handling it, so stop the widget API from doing something. - console.log(ev.detail); // custom handling here - api.transport.reply(ev.detail, {}); -}); -api.on("action:com.example.my_action", (ev: CustomEvent) => { - ev.preventDefault(); // we're handling it, so stop the widget API from doing something. - console.log(ev.detail); // custom handling here - api.transport.reply(ev.detail, {custom: "reply"}); -}); - -// Start the messaging -api.start(); - -// If waitForIframeLoad is false, tell the client that we're good to go -api.sendContentLoaded(); - -// Later, do something else (if needed) -api.setAlwaysOnScreen(true); -api.transport.send("com.example.my_action", {isExample: true}); -``` - -For a more complete example, see the `examples` directory of this repo. - -## Usage for web clients - -This SDK is meant for use in browser-based applications. The concepts may be transferable to other platforms, -though currently this SDK is intended to only be used by browsers. In the future it may be possible for this -SDK to provide an interface for other platforms. - -TODO: Improve this - -```typescript -const driver = new CustomDriver(); // an implementation of WidgetDriver -const api = new ClientWidgetApi(widget, iframe, driver); - -// The API is automatically started, so we just have to wait for a ready before doing something -api.on("ready", () => { - api.updateVisibility(true).then(() => console.log("Widget knows it is visible now")); - api.transport.send("com.example.my_action", {isExample: true}); -}); - -// Eventually, stop the API handling -api.stop(); -``` diff --git a/includes/external/matrix/node_modules/matrix-widget-api/dist/api.js b/includes/external/matrix/node_modules/matrix-widget-api/dist/api.js deleted file mode 100644 index 74f35ca..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/dist/api.js +++ /dev/null @@ -1,5105 +0,0 @@ -(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.mxwidgets = f()}})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, "catch": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; } - -function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } - -function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } - -function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; } - -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } - -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } - -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } - -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); } - -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } - -function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } - -function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); } - -function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } - -function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } - -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } - -function _asyncIterator(iterable) { var method, async, sync, retry = 2; for ("undefined" != typeof Symbol && (async = Symbol.asyncIterator, sync = Symbol.iterator); retry--;) { if (async && null != (method = iterable[async])) return method.call(iterable); if (sync && null != (method = iterable[sync])) return new AsyncFromSyncIterator(method.call(iterable)); async = "@@asyncIterator", sync = "@@iterator"; } throw new TypeError("Object is not async iterable"); } - -function AsyncFromSyncIterator(s) { function AsyncFromSyncIteratorContinuation(r) { if (Object(r) !== r) return Promise.reject(new TypeError(r + " is not an object.")); var done = r.done; return Promise.resolve(r.value).then(function (value) { return { value: value, done: done }; }); } return AsyncFromSyncIterator = function AsyncFromSyncIterator(s) { this.s = s, this.n = s.next; }, AsyncFromSyncIterator.prototype = { s: null, n: null, next: function next() { return AsyncFromSyncIteratorContinuation(this.n.apply(this.s, arguments)); }, "return": function _return(value) { var ret = this.s["return"]; return void 0 === ret ? Promise.resolve({ value: value, done: !0 }) : AsyncFromSyncIteratorContinuation(ret.apply(this.s, arguments)); }, "throw": function _throw(value) { var thr = this.s["return"]; return void 0 === thr ? Promise.reject(value) : AsyncFromSyncIteratorContinuation(thr.apply(this.s, arguments)); } }, new AsyncFromSyncIterator(s); } - -/** - * API handler for the client side of widgets. This raises events - * for each action received as `action:${action}` (eg: "action:screenshot"). - * Default handling can be prevented by using preventDefault() on the - * raised event. The default handling varies for each action: ones - * which the SDK can handle safely are acknowledged appropriately and - * ones which are unhandled (custom or require the client to do something) - * are rejected with an error. - * - * Events which are preventDefault()ed must reply using the transport. - * The events raised will have a default of an IWidgetApiRequest - * interface. - * - * When the ClientWidgetApi is ready to start sending requests, it will - * raise a "ready" CustomEvent. After the ready event fires, actions can - * be sent and the transport will be ready. - * - * When the widget has indicated it has loaded, this class raises a - * "preparing" CustomEvent. The preparing event does not indicate that - * the widget is ready to receive communications - that is signified by - * the ready event exclusively. - * - * This class only handles one widget at a time. - */ -var ClientWidgetApi = /*#__PURE__*/function (_EventEmitter) { - _inherits(ClientWidgetApi, _EventEmitter); - - var _super = _createSuper(ClientWidgetApi); - - // contentLoadedActionSent is used to check that only one ContentLoaded request is send. - - /** - * Creates a new client widget API. This will instantiate the transport - * and start everything. When the iframe is loaded under the widget's - * conditions, a "ready" event will be raised. - * @param {Widget} widget The widget to communicate with. - * @param {HTMLIFrameElement} iframe The iframe the widget is in. - * @param {WidgetDriver} driver The driver for this widget/client. - */ - function ClientWidgetApi(widget, iframe, driver) { - var _this; - - _classCallCheck(this, ClientWidgetApi); - - _this = _super.call(this); - _this.widget = widget; - _this.iframe = iframe; - _this.driver = driver; - - _defineProperty(_assertThisInitialized(_this), "transport", void 0); - - _defineProperty(_assertThisInitialized(_this), "contentLoadedActionSent", false); - - _defineProperty(_assertThisInitialized(_this), "allowedCapabilities", new Set()); - - _defineProperty(_assertThisInitialized(_this), "allowedEvents", []); - - _defineProperty(_assertThisInitialized(_this), "isStopped", false); - - _defineProperty(_assertThisInitialized(_this), "turnServers", null); - - if (!(iframe !== null && iframe !== void 0 && iframe.contentWindow)) { - throw new Error("No iframe supplied"); - } - - if (!widget) { - throw new Error("Invalid widget"); - } - - if (!driver) { - throw new Error("Invalid driver"); - } - - _this.transport = new _PostmessageTransport.PostmessageTransport(_WidgetApiDirection.WidgetApiDirection.ToWidget, widget.id, iframe.contentWindow, window); - _this.transport.targetOrigin = widget.origin; - - _this.transport.on("message", _this.handleMessage.bind(_assertThisInitialized(_this))); - - iframe.addEventListener("load", _this.onIframeLoad.bind(_assertThisInitialized(_this))); - - _this.transport.start(); - - return _this; - } - - _createClass(ClientWidgetApi, [{ - key: "hasCapability", - value: function hasCapability(capability) { - return this.allowedCapabilities.has(capability); - } - }, { - key: "canUseRoomTimeline", - value: function canUseRoomTimeline(roomId) { - return this.hasCapability("org.matrix.msc2762.timeline:".concat(_Symbols.Symbols.AnyRoom)) || this.hasCapability("org.matrix.msc2762.timeline:".concat(roomId)); - } - }, { - key: "canSendRoomEvent", - value: function canSendRoomEvent(eventType) { - var msgtype = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; - return this.allowedEvents.some(function (e) { - return e.matchesAsRoomEvent(_WidgetEventCapability.EventDirection.Send, eventType, msgtype); - }); - } - }, { - key: "canSendStateEvent", - value: function canSendStateEvent(eventType, stateKey) { - return this.allowedEvents.some(function (e) { - return e.matchesAsStateEvent(_WidgetEventCapability.EventDirection.Send, eventType, stateKey); - }); - } - }, { - key: "canSendToDeviceEvent", - value: function canSendToDeviceEvent(eventType) { - return this.allowedEvents.some(function (e) { - return e.matchesAsToDeviceEvent(_WidgetEventCapability.EventDirection.Send, eventType); - }); - } - }, { - key: "canReceiveRoomEvent", - value: function canReceiveRoomEvent(eventType) { - var msgtype = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; - return this.allowedEvents.some(function (e) { - return e.matchesAsRoomEvent(_WidgetEventCapability.EventDirection.Receive, eventType, msgtype); - }); - } - }, { - key: "canReceiveStateEvent", - value: function canReceiveStateEvent(eventType, stateKey) { - return this.allowedEvents.some(function (e) { - return e.matchesAsStateEvent(_WidgetEventCapability.EventDirection.Receive, eventType, stateKey); - }); - } - }, { - key: "canReceiveToDeviceEvent", - value: function canReceiveToDeviceEvent(eventType) { - return this.allowedEvents.some(function (e) { - return e.matchesAsToDeviceEvent(_WidgetEventCapability.EventDirection.Receive, eventType); - }); - } - }, { - key: "stop", - value: function stop() { - this.isStopped = true; - this.transport.stop(); - } - }, { - key: "beginCapabilities", - value: function beginCapabilities() { - var _this2 = this; - - // widget has loaded - tell all the listeners that - this.emit("preparing"); - var requestedCaps; - this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.Capabilities, {}).then(function (caps) { - requestedCaps = caps.capabilities; - return _this2.driver.validateCapabilities(new Set(caps.capabilities)); - }).then(function (allowedCaps) { - console.log("Widget ".concat(_this2.widget.id, " is allowed capabilities:"), Array.from(allowedCaps)); - _this2.allowedCapabilities = allowedCaps; - _this2.allowedEvents = _WidgetEventCapability.WidgetEventCapability.findEventCapabilities(allowedCaps); - - _this2.notifyCapabilities(requestedCaps); - - _this2.emit("ready"); - }); - } - }, { - key: "notifyCapabilities", - value: function notifyCapabilities(requested) { - var _this3 = this; - - this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.NotifyCapabilities, { - requested: requested, - approved: Array.from(this.allowedCapabilities) - })["catch"](function (e) { - console.warn("non-fatal error notifying widget of approved capabilities:", e); - }).then(function () { - _this3.emit("capabilitiesNotified"); - }); - } - }, { - key: "onIframeLoad", - value: function onIframeLoad(ev) { - if (this.widget.waitForIframeLoad) { - // If the widget is set to waitForIframeLoad the capabilities immediatly get setup after load. - // The client does not wait for the ContentLoaded action. - this.beginCapabilities(); - } else { - // Reaching this means, that the Iframe got reloaded/loaded and - // the clientApi is awaiting the FIRST ContentLoaded action. - this.contentLoadedActionSent = false; - } - } - }, { - key: "handleContentLoadedAction", - value: function handleContentLoadedAction(action) { - if (this.contentLoadedActionSent) { - throw new Error("Improper sequence: ContentLoaded Action can only be send once after the widget loaded " + "and should only be used if waitForIframeLoad is false (default=true)"); - } - - if (this.widget.waitForIframeLoad) { - this.transport.reply(action, { - error: { - message: "Improper sequence: not expecting ContentLoaded event if " + "waitForIframLoad is true (default=true)" - } - }); - } else { - this.transport.reply(action, {}); - this.beginCapabilities(); - } - - this.contentLoadedActionSent = true; - } - }, { - key: "replyVersions", - value: function replyVersions(request) { - this.transport.reply(request, { - supported_versions: _ApiVersion.CurrentApiVersions - }); - } - }, { - key: "handleCapabilitiesRenegotiate", - value: function handleCapabilitiesRenegotiate(request) { - var _request$data, - _this4 = this; - - // acknowledge first - this.transport.reply(request, {}); - var requested = ((_request$data = request.data) === null || _request$data === void 0 ? void 0 : _request$data.capabilities) || []; - var newlyRequested = new Set(requested.filter(function (r) { - return !_this4.hasCapability(r); - })); - - if (newlyRequested.size === 0) { - // Nothing to do - notify capabilities - return this.notifyCapabilities([]); - } - - this.driver.validateCapabilities(newlyRequested).then(function (allowed) { - allowed.forEach(function (c) { - return _this4.allowedCapabilities.add(c); - }); - - var allowedEvents = _WidgetEventCapability.WidgetEventCapability.findEventCapabilities(allowed); - - allowedEvents.forEach(function (c) { - return _this4.allowedEvents.push(c); - }); - return _this4.notifyCapabilities(Array.from(newlyRequested)); - }); - } - }, { - key: "handleNavigate", - value: function handleNavigate(request) { - var _request$data2, - _request$data3, - _this5 = this; - - if (!this.hasCapability(_Capabilities.MatrixCapabilities.MSC2931Navigate)) { - return this.transport.reply(request, { - error: { - message: "Missing capability" - } - }); - } - - if (!((_request$data2 = request.data) !== null && _request$data2 !== void 0 && _request$data2.uri) || !((_request$data3 = request.data) !== null && _request$data3 !== void 0 && _request$data3.uri.toString().startsWith("https://matrix.to/#"))) { - return this.transport.reply(request, { - error: { - message: "Invalid matrix.to URI" - } - }); - } - - var onErr = function onErr(e) { - console.error("[ClientWidgetApi] Failed to handle navigation: ", e); - return _this5.transport.reply(request, { - error: { - message: "Error handling navigation" - } - }); - }; - - try { - this.driver.navigate(request.data.uri.toString())["catch"](function (e) { - return onErr(e); - }).then(function () { - return _this5.transport.reply(request, {}); - }); - } catch (e) { - return onErr(e); - } - } - }, { - key: "handleOIDC", - value: function handleOIDC(request) { - var _this6 = this; - - var phase = 1; // 1 = initial request, 2 = after user manual confirmation - - var replyState = function replyState(state, credential) { - credential = credential || {}; - - if (phase > 1) { - return _this6.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.OpenIDCredentials, _objectSpread({ - state: state, - original_request_id: request.requestId - }, credential)); - } else { - return _this6.transport.reply(request, _objectSpread({ - state: state - }, credential)); - } - }; - - var replyError = function replyError(msg) { - console.error("[ClientWidgetApi] Failed to handle OIDC: ", msg); - - if (phase > 1) { - // We don't have a way to indicate that a random error happened in this flow, so - // just block the attempt. - return replyState(_GetOpenIDAction.OpenIDRequestState.Blocked); - } else { - return _this6.transport.reply(request, { - error: { - message: msg - } - }); - } - }; - - var observer = new _SimpleObservable.SimpleObservable(function (update) { - if (update.state === _GetOpenIDAction.OpenIDRequestState.PendingUserConfirmation && phase > 1) { - observer.close(); - return replyError("client provided out-of-phase response to OIDC flow"); - } - - if (update.state === _GetOpenIDAction.OpenIDRequestState.PendingUserConfirmation) { - replyState(update.state); - phase++; - return; - } - - if (update.state === _GetOpenIDAction.OpenIDRequestState.Allowed && !update.token) { - return replyError("client provided invalid OIDC token for an allowed request"); - } - - if (update.state === _GetOpenIDAction.OpenIDRequestState.Blocked) { - update.token = undefined; // just in case the client did something weird - } - - observer.close(); - return replyState(update.state, update.token); - }); - this.driver.askOpenID(observer); - } - }, { - key: "handleReadEvents", - value: function handleReadEvents(request) { - var _this7 = this; - - if (!request.data.type) { - return this.transport.reply(request, { - error: { - message: "Invalid request - missing event type" - } - }); - } - - if (request.data.limit !== undefined && (!request.data.limit || request.data.limit < 0)) { - return this.transport.reply(request, { - error: { - message: "Invalid request - limit out of range" - } - }); - } - - var askRoomIds = null; // null denotes current room only - - if (request.data.room_ids) { - askRoomIds = request.data.room_ids; - - if (!Array.isArray(askRoomIds)) { - askRoomIds = [askRoomIds]; - } - - var _iterator2 = _createForOfIteratorHelper(askRoomIds), - _step2; - - try { - for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) { - var roomId = _step2.value; - - if (!this.canUseRoomTimeline(roomId)) { - return this.transport.reply(request, { - error: { - message: "Unable to access room timeline: ".concat(roomId) - } - }); - } - } - } catch (err) { - _iterator2.e(err); - } finally { - _iterator2.f(); - } - } - - var limit = request.data.limit || 0; - var events = Promise.resolve([]); - - if (request.data.state_key !== undefined) { - var stateKey = request.data.state_key === true ? undefined : request.data.state_key.toString(); - - if (!this.canReceiveStateEvent(request.data.type, stateKey !== null && stateKey !== void 0 ? stateKey : null)) { - return this.transport.reply(request, { - error: { - message: "Cannot read state events of this type" - } - }); - } - - events = this.driver.readStateEvents(request.data.type, stateKey, limit, askRoomIds); - } else { - if (!this.canReceiveRoomEvent(request.data.type, request.data.msgtype)) { - return this.transport.reply(request, { - error: { - message: "Cannot read room events of this type" - } - }); - } - - events = this.driver.readRoomEvents(request.data.type, request.data.msgtype, limit, askRoomIds); - } - - return events.then(function (evs) { - return _this7.transport.reply(request, { - events: evs - }); - }); - } - }, { - key: "handleSendEvent", - value: function handleSendEvent(request) { - var _this8 = this; - - if (!request.data.type) { - return this.transport.reply(request, { - error: { - message: "Invalid request - missing event type" - } - }); - } - - if (!!request.data.room_id && !this.canUseRoomTimeline(request.data.room_id)) { - return this.transport.reply(request, { - error: { - message: "Unable to access room timeline: ".concat(request.data.room_id) - } - }); - } - - var isState = request.data.state_key !== null && request.data.state_key !== undefined; - var sendEventPromise; - - if (isState) { - if (!this.canSendStateEvent(request.data.type, request.data.state_key)) { - return this.transport.reply(request, { - error: { - message: "Cannot send state events of this type" - } - }); - } - - sendEventPromise = this.driver.sendEvent(request.data.type, request.data.content || {}, request.data.state_key, request.data.room_id); - } else { - var content = request.data.content || {}; - var msgtype = content['msgtype']; - - if (!this.canSendRoomEvent(request.data.type, msgtype)) { - return this.transport.reply(request, { - error: { - message: "Cannot send room events of this type" - } - }); - } - - sendEventPromise = this.driver.sendEvent(request.data.type, content, null, // not sending a state event - request.data.room_id); - } - - sendEventPromise.then(function (sentEvent) { - return _this8.transport.reply(request, { - room_id: sentEvent.roomId, - event_id: sentEvent.eventId - }); - })["catch"](function (e) { - console.error("error sending event: ", e); - return _this8.transport.reply(request, { - error: { - message: "Error sending event" - } - }); - }); - } - }, { - key: "handleSendToDevice", - value: function () { - var _handleSendToDevice = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(request) { - return _regeneratorRuntime().wrap(function _callee$(_context) { - while (1) { - switch (_context.prev = _context.next) { - case 0: - if (request.data.type) { - _context.next = 5; - break; - } - - _context.next = 3; - return this.transport.reply(request, { - error: { - message: "Invalid request - missing event type" - } - }); - - case 3: - _context.next = 32; - break; - - case 5: - if (request.data.messages) { - _context.next = 10; - break; - } - - _context.next = 8; - return this.transport.reply(request, { - error: { - message: "Invalid request - missing event contents" - } - }); - - case 8: - _context.next = 32; - break; - - case 10: - if (!(typeof request.data.encrypted !== "boolean")) { - _context.next = 15; - break; - } - - _context.next = 13; - return this.transport.reply(request, { - error: { - message: "Invalid request - missing encryption flag" - } - }); - - case 13: - _context.next = 32; - break; - - case 15: - if (this.canSendToDeviceEvent(request.data.type)) { - _context.next = 20; - break; - } - - _context.next = 18; - return this.transport.reply(request, { - error: { - message: "Cannot send to-device events of this type" - } - }); - - case 18: - _context.next = 32; - break; - - case 20: - _context.prev = 20; - _context.next = 23; - return this.driver.sendToDevice(request.data.type, request.data.encrypted, request.data.messages); - - case 23: - _context.next = 25; - return this.transport.reply(request, {}); - - case 25: - _context.next = 32; - break; - - case 27: - _context.prev = 27; - _context.t0 = _context["catch"](20); - console.error("error sending to-device event", _context.t0); - _context.next = 32; - return this.transport.reply(request, { - error: { - message: "Error sending event" - } - }); - - case 32: - case "end": - return _context.stop(); - } - } - }, _callee, this, [[20, 27]]); - })); - - function handleSendToDevice(_x) { - return _handleSendToDevice.apply(this, arguments); - } - - return handleSendToDevice; - }() - }, { - key: "pollTurnServers", - value: function () { - var _pollTurnServers = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(turnServers, initialServer) { - var _iteratorAbruptCompletion, _didIteratorError, _iteratorError, _iterator, _step, server; - - return _regeneratorRuntime().wrap(function _callee2$(_context2) { - while (1) { - switch (_context2.prev = _context2.next) { - case 0: - _context2.prev = 0; - _context2.next = 3; - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers, initialServer // it's compatible, but missing the index signature - ); - - case 3: - // Pick the generator up where we left off - _iteratorAbruptCompletion = false; - _didIteratorError = false; - _context2.prev = 5; - _iterator = _asyncIterator(turnServers); - - case 7: - _context2.next = 9; - return _iterator.next(); - - case 9: - if (!(_iteratorAbruptCompletion = !(_step = _context2.sent).done)) { - _context2.next = 16; - break; - } - - server = _step.value; - _context2.next = 13; - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers, server // it's compatible, but missing the index signature - ); - - case 13: - _iteratorAbruptCompletion = false; - _context2.next = 7; - break; - - case 16: - _context2.next = 22; - break; - - case 18: - _context2.prev = 18; - _context2.t0 = _context2["catch"](5); - _didIteratorError = true; - _iteratorError = _context2.t0; - - case 22: - _context2.prev = 22; - _context2.prev = 23; - - if (!(_iteratorAbruptCompletion && _iterator["return"] != null)) { - _context2.next = 27; - break; - } - - _context2.next = 27; - return _iterator["return"](); - - case 27: - _context2.prev = 27; - - if (!_didIteratorError) { - _context2.next = 30; - break; - } - - throw _iteratorError; - - case 30: - return _context2.finish(27); - - case 31: - return _context2.finish(22); - - case 32: - _context2.next = 37; - break; - - case 34: - _context2.prev = 34; - _context2.t1 = _context2["catch"](0); - console.error("error polling for TURN servers", _context2.t1); - - case 37: - case "end": - return _context2.stop(); - } - } - }, _callee2, this, [[0, 34], [5, 18, 22, 32], [23,, 27, 31]]); - })); - - function pollTurnServers(_x2, _x3) { - return _pollTurnServers.apply(this, arguments); - } - - return pollTurnServers; - }() - }, { - key: "handleWatchTurnServers", - value: function () { - var _handleWatchTurnServers = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3(request) { - var turnServers, _yield$turnServers$ne, done, value; - - return _regeneratorRuntime().wrap(function _callee3$(_context3) { - while (1) { - switch (_context3.prev = _context3.next) { - case 0: - if (this.hasCapability(_Capabilities.MatrixCapabilities.MSC3846TurnServers)) { - _context3.next = 5; - break; - } - - _context3.next = 3; - return this.transport.reply(request, { - error: { - message: "Missing capability" - } - }); - - case 3: - _context3.next = 30; - break; - - case 5: - if (!this.turnServers) { - _context3.next = 10; - break; - } - - _context3.next = 8; - return this.transport.reply(request, {}); - - case 8: - _context3.next = 30; - break; - - case 10: - _context3.prev = 10; - turnServers = this.driver.getTurnServers(); // Peek at the first result, so we can at least verify that the - // client isn't banned from getting TURN servers entirely - - _context3.next = 14; - return turnServers.next(); - - case 14: - _yield$turnServers$ne = _context3.sent; - done = _yield$turnServers$ne.done; - value = _yield$turnServers$ne.value; - - if (!done) { - _context3.next = 19; - break; - } - - throw new Error("Client refuses to provide any TURN servers"); - - case 19: - _context3.next = 21; - return this.transport.reply(request, {}); - - case 21: - // Start the poll loop, sending the widget the initial result - this.pollTurnServers(turnServers, value); - this.turnServers = turnServers; - _context3.next = 30; - break; - - case 25: - _context3.prev = 25; - _context3.t0 = _context3["catch"](10); - console.error("error getting first TURN server results", _context3.t0); - _context3.next = 30; - return this.transport.reply(request, { - error: { - message: "TURN servers not available" - } - }); - - case 30: - case "end": - return _context3.stop(); - } - } - }, _callee3, this, [[10, 25]]); - })); - - function handleWatchTurnServers(_x4) { - return _handleWatchTurnServers.apply(this, arguments); - } - - return handleWatchTurnServers; - }() - }, { - key: "handleUnwatchTurnServers", - value: function () { - var _handleUnwatchTurnServers = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee4(request) { - return _regeneratorRuntime().wrap(function _callee4$(_context4) { - while (1) { - switch (_context4.prev = _context4.next) { - case 0: - if (this.hasCapability(_Capabilities.MatrixCapabilities.MSC3846TurnServers)) { - _context4.next = 5; - break; - } - - _context4.next = 3; - return this.transport.reply(request, { - error: { - message: "Missing capability" - } - }); - - case 3: - _context4.next = 15; - break; - - case 5: - if (this.turnServers) { - _context4.next = 10; - break; - } - - _context4.next = 8; - return this.transport.reply(request, {}); - - case 8: - _context4.next = 15; - break; - - case 10: - _context4.next = 12; - return this.turnServers["return"](undefined); - - case 12: - this.turnServers = null; - _context4.next = 15; - return this.transport.reply(request, {}); - - case 15: - case "end": - return _context4.stop(); - } - } - }, _callee4, this); - })); - - function handleUnwatchTurnServers(_x5) { - return _handleUnwatchTurnServers.apply(this, arguments); - } - - return handleUnwatchTurnServers; - }() - }, { - key: "handleReadRelations", - value: function () { - var _handleReadRelations = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee5(request) { - var _this9 = this; - - var result, chunk; - return _regeneratorRuntime().wrap(function _callee5$(_context5) { - while (1) { - switch (_context5.prev = _context5.next) { - case 0: - if (request.data.event_id) { - _context5.next = 2; - break; - } - - return _context5.abrupt("return", this.transport.reply(request, { - error: { - message: "Invalid request - missing event ID" - } - })); - - case 2: - if (!(request.data.limit !== undefined && request.data.limit < 0)) { - _context5.next = 4; - break; - } - - return _context5.abrupt("return", this.transport.reply(request, { - error: { - message: "Invalid request - limit out of range" - } - })); - - case 4: - if (!(request.data.room_id !== undefined && !this.canUseRoomTimeline(request.data.room_id))) { - _context5.next = 6; - break; - } - - return _context5.abrupt("return", this.transport.reply(request, { - error: { - message: "Unable to access room timeline: ".concat(request.data.room_id) - } - })); - - case 6: - _context5.prev = 6; - _context5.next = 9; - return this.driver.readEventRelations(request.data.event_id, request.data.room_id, request.data.rel_type, request.data.event_type, request.data.from, request.data.to, request.data.limit, request.data.direction); - - case 9: - result = _context5.sent; - // only return events that the user has the permission to receive - chunk = result.chunk.filter(function (e) { - if (e.state_key !== undefined) { - return _this9.canReceiveStateEvent(e.type, e.state_key); - } else { - return _this9.canReceiveRoomEvent(e.type, e.content['msgtype']); - } - }); - return _context5.abrupt("return", this.transport.reply(request, { - chunk: chunk, - prev_batch: result.prevBatch, - next_batch: result.nextBatch - })); - - case 14: - _context5.prev = 14; - _context5.t0 = _context5["catch"](6); - console.error("error getting the relations", _context5.t0); - _context5.next = 19; - return this.transport.reply(request, { - error: { - message: "Unexpected error while reading relations" - } - }); - - case 19: - case "end": - return _context5.stop(); - } - } - }, _callee5, this, [[6, 14]]); - })); - - function handleReadRelations(_x6) { - return _handleReadRelations.apply(this, arguments); - } - - return handleReadRelations; - }() - }, { - key: "handleUserDirectorySearch", - value: function () { - var _handleUserDirectorySearch = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee6(request) { - var result; - return _regeneratorRuntime().wrap(function _callee6$(_context6) { - while (1) { - switch (_context6.prev = _context6.next) { - case 0: - if (this.hasCapability(_Capabilities.MatrixCapabilities.MSC3973UserDirectorySearch)) { - _context6.next = 2; - break; - } - - return _context6.abrupt("return", this.transport.reply(request, { - error: { - message: "Missing capability" - } - })); - - case 2: - if (!(typeof request.data.search_term !== 'string')) { - _context6.next = 4; - break; - } - - return _context6.abrupt("return", this.transport.reply(request, { - error: { - message: "Invalid request - missing search term" - } - })); - - case 4: - if (!(request.data.limit !== undefined && request.data.limit < 0)) { - _context6.next = 6; - break; - } - - return _context6.abrupt("return", this.transport.reply(request, { - error: { - message: "Invalid request - limit out of range" - } - })); - - case 6: - _context6.prev = 6; - _context6.next = 9; - return this.driver.searchUserDirectory(request.data.search_term, request.data.limit); - - case 9: - result = _context6.sent; - return _context6.abrupt("return", this.transport.reply(request, { - limited: result.limited, - results: result.results.map(function (r) { - return { - user_id: r.userId, - display_name: r.displayName, - avatar_url: r.avatarUrl - }; - }) - })); - - case 13: - _context6.prev = 13; - _context6.t0 = _context6["catch"](6); - console.error("error searching in the user directory", _context6.t0); - _context6.next = 18; - return this.transport.reply(request, { - error: { - message: "Unexpected error while searching in the user directory" - } - }); - - case 18: - case "end": - return _context6.stop(); - } - } - }, _callee6, this, [[6, 13]]); - })); - - function handleUserDirectorySearch(_x7) { - return _handleUserDirectorySearch.apply(this, arguments); - } - - return handleUserDirectorySearch; - }() - }, { - key: "handleMessage", - value: function handleMessage(ev) { - if (this.isStopped) return; - var actionEv = new CustomEvent("action:".concat(ev.detail.action), { - detail: ev.detail, - cancelable: true - }); - this.emit("action:".concat(ev.detail.action), actionEv); - - if (!actionEv.defaultPrevented) { - switch (ev.detail.action) { - case _WidgetApiAction.WidgetApiFromWidgetAction.ContentLoaded: - return this.handleContentLoadedAction(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.SupportedApiVersions: - return this.replyVersions(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.SendEvent: - return this.handleSendEvent(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.SendToDevice: - return this.handleSendToDevice(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.GetOpenIDCredentials: - return this.handleOIDC(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.MSC2931Navigate: - return this.handleNavigate(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.MSC2974RenegotiateCapabilities: - return this.handleCapabilitiesRenegotiate(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.MSC2876ReadEvents: - return this.handleReadEvents(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.WatchTurnServers: - return this.handleWatchTurnServers(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.UnwatchTurnServers: - return this.handleUnwatchTurnServers(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.MSC3869ReadRelations: - return this.handleReadRelations(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.MSC3973UserDirectorySearch: - return this.handleUserDirectorySearch(ev.detail); - - default: - return this.transport.reply(ev.detail, { - error: { - message: "Unknown or unsupported action: " + ev.detail.action - } - }); - } - } - } - /** - * Takes a screenshot of the widget. - * @returns Resolves to the widget's screenshot. - * @throws Throws if there is a problem. - */ - - }, { - key: "takeScreenshot", - value: function takeScreenshot() { - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.TakeScreenshot, {}); - } - /** - * Alerts the widget to whether or not it is currently visible. - * @param {boolean} isVisible Whether the widget is visible or not. - * @returns {Promise} Resolves when the widget acknowledges the update. - */ - - }, { - key: "updateVisibility", - value: function updateVisibility(isVisible) { - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.UpdateVisibility, { - visible: isVisible - }); - } - }, { - key: "sendWidgetConfig", - value: function sendWidgetConfig(data) { - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.WidgetConfig, data).then(); - } - }, { - key: "notifyModalWidgetButtonClicked", - value: function notifyModalWidgetButtonClicked(id) { - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.ButtonClicked, { - id: id - }).then(); - } - }, { - key: "notifyModalWidgetClose", - value: function notifyModalWidgetClose(data) { - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.CloseModalWidget, data).then(); - } - /** - * Feeds an event to the widget. If the widget is not able to accept the event due to - * permissions, this will no-op and return calmly. If the widget failed to handle the - * event, this will raise an error. - * @param {IRoomEvent} rawEvent The event to (try to) send to the widget. - * @param {string} currentViewedRoomId The room ID the user is currently interacting with. - * Not the room ID of the event. - * @returns {Promise} Resolves when complete, rejects if there was an error sending. - */ - - }, { - key: "feedEvent", - value: function () { - var _feedEvent = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee7(rawEvent, currentViewedRoomId) { - var _rawEvent$content; - - return _regeneratorRuntime().wrap(function _callee7$(_context7) { - while (1) { - switch (_context7.prev = _context7.next) { - case 0: - if (!(rawEvent.room_id !== currentViewedRoomId && !this.canUseRoomTimeline(rawEvent.room_id))) { - _context7.next = 2; - break; - } - - return _context7.abrupt("return"); - - case 2: - if (!(rawEvent.state_key !== undefined && rawEvent.state_key !== null)) { - _context7.next = 7; - break; - } - - if (this.canReceiveStateEvent(rawEvent.type, rawEvent.state_key)) { - _context7.next = 5; - break; - } - - return _context7.abrupt("return"); - - case 5: - _context7.next = 9; - break; - - case 7: - if (this.canReceiveRoomEvent(rawEvent.type, (_rawEvent$content = rawEvent.content) === null || _rawEvent$content === void 0 ? void 0 : _rawEvent$content["msgtype"])) { - _context7.next = 9; - break; - } - - return _context7.abrupt("return"); - - case 9: - _context7.next = 11; - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.SendEvent, rawEvent // it's compatible, but missing the index signature - ); - - case 11: - case "end": - return _context7.stop(); - } - } - }, _callee7, this); - })); - - function feedEvent(_x8, _x9) { - return _feedEvent.apply(this, arguments); - } - - return feedEvent; - }() - /** - * Feeds a to-device event to the widget. If the widget is not able to accept the - * event due to permissions, this will no-op and return calmly. If the widget failed - * to handle the event, this will raise an error. - * @param {IRoomEvent} rawEvent The event to (try to) send to the widget. - * @param {boolean} encrypted Whether the event contents were encrypted. - * @returns {Promise} Resolves when complete, rejects if there was an error sending. - */ - - }, { - key: "feedToDevice", - value: function () { - var _feedToDevice = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee8(rawEvent, encrypted) { - return _regeneratorRuntime().wrap(function _callee8$(_context8) { - while (1) { - switch (_context8.prev = _context8.next) { - case 0: - if (!this.canReceiveToDeviceEvent(rawEvent.type)) { - _context8.next = 3; - break; - } - - _context8.next = 3; - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.SendToDevice, // it's compatible, but missing the index signature - _objectSpread(_objectSpread({}, rawEvent), {}, { - encrypted: encrypted - })); - - case 3: - case "end": - return _context8.stop(); - } - } - }, _callee8, this); - })); - - function feedToDevice(_x10, _x11) { - return _feedToDevice.apply(this, arguments); - } - - return feedToDevice; - }() - }]); - - return ClientWidgetApi; -}(_events.EventEmitter); - -exports.ClientWidgetApi = ClientWidgetApi; -},{"./Symbols":2,"./interfaces/ApiVersion":6,"./interfaces/Capabilities":7,"./interfaces/GetOpenIDAction":10,"./interfaces/WidgetApiAction":34,"./interfaces/WidgetApiDirection":35,"./models/WidgetEventCapability":40,"./transport/PostmessageTransport":46,"./util/SimpleObservable":47,"events":48}],2:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.Symbols = void 0; - -/* - * Copyright 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var Symbols; -exports.Symbols = Symbols; - -(function (Symbols) { - Symbols["AnyRoom"] = "*"; -})(Symbols || (exports.Symbols = Symbols = {})); -},{}],3:[function(require,module,exports){ -"use strict"; - -function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetApi = void 0; - -var _events = require("events"); - -var _WidgetApiDirection = require("./interfaces/WidgetApiDirection"); - -var _ApiVersion = require("./interfaces/ApiVersion"); - -var _PostmessageTransport = require("./transport/PostmessageTransport"); - -var _WidgetApiAction = require("./interfaces/WidgetApiAction"); - -var _GetOpenIDAction = require("./interfaces/GetOpenIDAction"); - -var _WidgetType = require("./interfaces/WidgetType"); - -var _ModalWidgetActions = require("./interfaces/ModalWidgetActions"); - -var _WidgetEventCapability = require("./models/WidgetEventCapability"); - -var _Symbols = require("./Symbols"); - -function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, $Symbol = "function" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || "@@iterator", asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator", toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, ""); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return generator._invoke = function (innerFn, self, context) { var state = "suspendedStart"; return function (method, arg) { if ("executing" === state) throw new Error("Generator is already running"); if ("completed" === state) { if ("throw" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) { if ("suspendedStart" === state) throw state = "completed", context.arg; context.dispatchException(context.arg); } else "return" === context.method && context.abrupt("return", context.arg); state = "executing"; var record = tryCatch(innerFn, self, context); if ("normal" === record.type) { if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } "throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg); } }; }(innerFn, self, context), generator; } function tryCatch(fn, obj, arg) { try { return { type: "normal", arg: fn.call(obj, arg) }; } catch (err) { return { type: "throw", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { ["next", "throw", "return"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if ("throw" !== record.type) { var result = record.arg, value = result.value; return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke("next", value, resolve, reject); }, function (err) { invoke("throw", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke("throw", error, resolve, reject); }); } reject(record.arg); } var previousPromise; this._invoke = function (method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); }; } function maybeInvokeDelegate(delegate, context) { var method = delegate.iterator[context.method]; if (undefined === method) { if (context.delegate = null, "throw" === context.method) { if (delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method)) return ContinueSentinel; context.method = "throw", context.arg = new TypeError("The iterator does not provide a 'throw' method"); } return ContinueSentinel; } var record = tryCatch(method, delegate.iterator, context.arg); if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = "normal", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: "root" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if ("function" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) { if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; } return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, define(Gp, "constructor", GeneratorFunctionPrototype), define(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) { var ctor = "function" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, "toString", function () { return "[object Generator]"; }), exports.keys = function (object) { var keys = []; for (var key in object) { keys.push(key); } return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) { "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); } }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if ("throw" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, "catch": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; } - -function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } - -function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); } - -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } - -function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } - -function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); } - -function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } - -function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } - -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } - -function _awaitAsyncGenerator(value) { return new _AwaitValue(value); } - -function _wrapAsyncGenerator(fn) { return function () { return new _AsyncGenerator(fn.apply(this, arguments)); }; } - -function _AsyncGenerator(gen) { var front, back; function send(key, arg) { return new Promise(function (resolve, reject) { var request = { key: key, arg: arg, resolve: resolve, reject: reject, next: null }; if (back) { back = back.next = request; } else { front = back = request; resume(key, arg); } }); } function resume(key, arg) { try { var result = gen[key](arg); var value = result.value; var wrappedAwait = value instanceof _AwaitValue; Promise.resolve(wrappedAwait ? value.wrapped : value).then(function (arg) { if (wrappedAwait) { resume(key === "return" ? "return" : "next", arg); return; } settle(result.done ? "return" : "normal", arg); }, function (err) { resume("throw", err); }); } catch (err) { settle("throw", err); } } function settle(type, value) { switch (type) { case "return": front.resolve({ value: value, done: true }); break; case "throw": front.reject(value); break; default: front.resolve({ value: value, done: false }); break; } front = front.next; if (front) { resume(front.key, front.arg); } else { back = null; } } this._invoke = send; if (typeof gen["return"] !== "function") { this["return"] = undefined; } } - -_AsyncGenerator.prototype[typeof Symbol === "function" && Symbol.asyncIterator || "@@asyncIterator"] = function () { return this; }; - -_AsyncGenerator.prototype.next = function (arg) { return this._invoke("next", arg); }; - -_AsyncGenerator.prototype["throw"] = function (arg) { return this._invoke("throw", arg); }; - -_AsyncGenerator.prototype["return"] = function (arg) { return this._invoke("return", arg); }; - -function _AwaitValue(value) { this.wrapped = value; } - -/** - * API handler for widgets. This raises events for each action - * received as `action:${action}` (eg: "action:screenshot"). - * Default handling can be prevented by using preventDefault() - * on the raised event. The default handling varies for each - * action: ones which the SDK can handle safely are acknowledged - * appropriately and ones which are unhandled (custom or require - * the widget to do something) are rejected with an error. - * - * Events which are preventDefault()ed must reply using the - * transport. The events raised will have a detail of an - * IWidgetApiRequest interface. - * - * When the WidgetApi is ready to start sending requests, it will - * raise a "ready" CustomEvent. After the ready event fires, actions - * can be sent and the transport will be ready. - */ -var WidgetApi = /*#__PURE__*/function (_EventEmitter) { - _inherits(WidgetApi, _EventEmitter); - - var _super = _createSuper(WidgetApi); - - /** - * Creates a new API handler for the given widget. - * @param {string} widgetId The widget ID to listen for. If not supplied then - * the API will use the widget ID from the first valid request it receives. - * @param {string} clientOrigin The origin of the client, or null if not known. - */ - function WidgetApi() { - var _this2; - - var widgetId = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; - var clientOrigin = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; - - _classCallCheck(this, WidgetApi); - - _this2 = _super.call(this); - _this2.clientOrigin = clientOrigin; - - _defineProperty(_assertThisInitialized(_this2), "transport", void 0); - - _defineProperty(_assertThisInitialized(_this2), "capabilitiesFinished", false); - - _defineProperty(_assertThisInitialized(_this2), "supportsMSC2974Renegotiate", false); - - _defineProperty(_assertThisInitialized(_this2), "requestedCapabilities", []); - - _defineProperty(_assertThisInitialized(_this2), "approvedCapabilities", void 0); - - _defineProperty(_assertThisInitialized(_this2), "cachedClientVersions", void 0); - - _defineProperty(_assertThisInitialized(_this2), "turnServerWatchers", 0); - - if (!window.parent) { - throw new Error("No parent window. This widget doesn't appear to be embedded properly."); - } - - _this2.transport = new _PostmessageTransport.PostmessageTransport(_WidgetApiDirection.WidgetApiDirection.FromWidget, widgetId, window.parent, window); - _this2.transport.targetOrigin = clientOrigin; - - _this2.transport.on("message", _this2.handleMessage.bind(_assertThisInitialized(_this2))); - - return _this2; - } - /** - * Determines if the widget was granted a particular capability. Note that on - * clients where the capabilities are not fed back to the widget this function - * will rely on requested capabilities instead. - * @param {Capability} capability The capability to check for approval of. - * @returns {boolean} True if the widget has approval for the given capability. - */ - - - _createClass(WidgetApi, [{ - key: "hasCapability", - value: function hasCapability(capability) { - if (Array.isArray(this.approvedCapabilities)) { - return this.approvedCapabilities.includes(capability); - } - - return this.requestedCapabilities.includes(capability); - } - /** - * Request a capability from the client. It is not guaranteed to be allowed, - * but will be asked for. - * @param {Capability} capability The capability to request. - * @throws Throws if the capabilities negotiation has already started and the - * widget is unable to request additional capabilities. - */ - - }, { - key: "requestCapability", - value: function requestCapability(capability) { - if (this.capabilitiesFinished && !this.supportsMSC2974Renegotiate) { - throw new Error("Capabilities have already been negotiated"); - } - - this.requestedCapabilities.push(capability); - } - /** - * Request capabilities from the client. They are not guaranteed to be allowed, - * but will be asked for if the negotiation has not already happened. - * @param {Capability[]} capabilities The capabilities to request. - * @throws Throws if the capabilities negotiation has already started. - */ - - }, { - key: "requestCapabilities", - value: function requestCapabilities(capabilities) { - var _this3 = this; - - capabilities.forEach(function (cap) { - return _this3.requestCapability(cap); - }); - } - /** - * Requests the capability to interact with rooms other than the user's currently - * viewed room. Applies to event receiving and sending. - * @param {string | Symbols.AnyRoom} roomId The room ID, or `Symbols.AnyRoom` to - * denote all known rooms. - */ - - }, { - key: "requestCapabilityForRoomTimeline", - value: function requestCapabilityForRoomTimeline(roomId) { - this.requestCapability("org.matrix.msc2762.timeline:".concat(roomId)); - } - /** - * Requests the capability to send a given state event with optional explicit - * state key. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} eventType The state event type to ask for. - * @param {string} stateKey If specified, the specific state key to request. - * Otherwise all state keys will be requested. - */ - - }, { - key: "requestCapabilityToSendState", - value: function requestCapabilityToSendState(eventType, stateKey) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forStateEvent(_WidgetEventCapability.EventDirection.Send, eventType, stateKey).raw); - } - /** - * Requests the capability to receive a given state event with optional explicit - * state key. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} eventType The state event type to ask for. - * @param {string} stateKey If specified, the specific state key to request. - * Otherwise all state keys will be requested. - */ - - }, { - key: "requestCapabilityToReceiveState", - value: function requestCapabilityToReceiveState(eventType, stateKey) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forStateEvent(_WidgetEventCapability.EventDirection.Receive, eventType, stateKey).raw); - } - /** - * Requests the capability to send a given to-device event. It is not - * guaranteed to be allowed, but will be asked for if the negotiation has - * not already happened. - * @param {string} eventType The room event type to ask for. - */ - - }, { - key: "requestCapabilityToSendToDevice", - value: function requestCapabilityToSendToDevice(eventType) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forToDeviceEvent(_WidgetEventCapability.EventDirection.Send, eventType).raw); - } - /** - * Requests the capability to receive a given to-device event. It is not - * guaranteed to be allowed, but will be asked for if the negotiation has - * not already happened. - * @param {string} eventType The room event type to ask for. - */ - - }, { - key: "requestCapabilityToReceiveToDevice", - value: function requestCapabilityToReceiveToDevice(eventType) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forToDeviceEvent(_WidgetEventCapability.EventDirection.Receive, eventType).raw); - } - /** - * Requests the capability to send a given room event. It is not guaranteed to be - * allowed, but will be asked for if the negotiation has not already happened. - * @param {string} eventType The room event type to ask for. - */ - - }, { - key: "requestCapabilityToSendEvent", - value: function requestCapabilityToSendEvent(eventType) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forRoomEvent(_WidgetEventCapability.EventDirection.Send, eventType).raw); - } - /** - * Requests the capability to receive a given room event. It is not guaranteed to be - * allowed, but will be asked for if the negotiation has not already happened. - * @param {string} eventType The room event type to ask for. - */ - - }, { - key: "requestCapabilityToReceiveEvent", - value: function requestCapabilityToReceiveEvent(eventType) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forRoomEvent(_WidgetEventCapability.EventDirection.Receive, eventType).raw); - } - /** - * Requests the capability to send a given message event with optional explicit - * `msgtype`. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} msgtype If specified, the specific msgtype to request. - * Otherwise all message types will be requested. - */ - - }, { - key: "requestCapabilityToSendMessage", - value: function requestCapabilityToSendMessage(msgtype) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forRoomMessageEvent(_WidgetEventCapability.EventDirection.Send, msgtype).raw); - } - /** - * Requests the capability to receive a given message event with optional explicit - * `msgtype`. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} msgtype If specified, the specific msgtype to request. - * Otherwise all message types will be requested. - */ - - }, { - key: "requestCapabilityToReceiveMessage", - value: function requestCapabilityToReceiveMessage(msgtype) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forRoomMessageEvent(_WidgetEventCapability.EventDirection.Receive, msgtype).raw); - } - /** - * Requests an OpenID Connect token from the client for the currently logged in - * user. This token can be validated server-side with the federation API. Note - * that the widget is responsible for validating the token and caching any results - * it needs. - * @returns {Promise} Resolves to a token for verification. - * @throws Throws if the user rejected the request or the request failed. - */ - - }, { - key: "requestOpenIDConnectToken", - value: function requestOpenIDConnectToken() { - var _this4 = this; - - return new Promise(function (resolve, reject) { - _this4.transport.sendComplete(_WidgetApiAction.WidgetApiFromWidgetAction.GetOpenIDCredentials, {}).then(function (response) { - var rdata = response.response; - - if (rdata.state === _GetOpenIDAction.OpenIDRequestState.Allowed) { - resolve(rdata); - } else if (rdata.state === _GetOpenIDAction.OpenIDRequestState.Blocked) { - reject(new Error("User declined to verify their identity")); - } else if (rdata.state === _GetOpenIDAction.OpenIDRequestState.PendingUserConfirmation) { - var handlerFn = function handlerFn(ev) { - ev.preventDefault(); - var request = ev.detail; - if (request.data.original_request_id !== response.requestId) return; - - if (request.data.state === _GetOpenIDAction.OpenIDRequestState.Allowed) { - resolve(request.data); - - _this4.transport.reply(request, {}); // ack - - } else if (request.data.state === _GetOpenIDAction.OpenIDRequestState.Blocked) { - reject(new Error("User declined to verify their identity")); - - _this4.transport.reply(request, {}); // ack - - } else { - reject(new Error("Invalid state on reply: " + rdata.state)); - - _this4.transport.reply(request, { - error: { - message: "Invalid state" - } - }); - } - - _this4.off("action:".concat(_WidgetApiAction.WidgetApiToWidgetAction.OpenIDCredentials), handlerFn); - }; - - _this4.on("action:".concat(_WidgetApiAction.WidgetApiToWidgetAction.OpenIDCredentials), handlerFn); - } else { - reject(new Error("Invalid state: " + rdata.state)); - } - })["catch"](reject); - }); - } - /** - * Asks the client for additional capabilities. Capabilities can be queued for this - * request with the requestCapability() functions. - * @returns {Promise} Resolves when complete. Note that the promise resolves when - * the capabilities request has gone through, not when the capabilities are approved/denied. - * Use the WidgetApiToWidgetAction.NotifyCapabilities action to detect changes. - */ - - }, { - key: "updateRequestedCapabilities", - value: function updateRequestedCapabilities() { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC2974RenegotiateCapabilities, { - capabilities: this.requestedCapabilities - }).then(); - } - /** - * Tell the client that the content has been loaded. - * @returns {Promise} Resolves when the client acknowledges the request. - */ - - }, { - key: "sendContentLoaded", - value: function sendContentLoaded() { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.ContentLoaded, {}).then(); - } - /** - * Sends a sticker to the client. - * @param {IStickerActionRequestData} sticker The sticker to send. - * @returns {Promise} Resolves when the client acknowledges the request. - */ - - }, { - key: "sendSticker", - value: function sendSticker(sticker) { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SendSticker, sticker).then(); - } - /** - * Asks the client to set the always-on-screen status for this widget. - * @param {boolean} value The new state to request. - * @returns {Promise} Resolve with true if the client was able to fulfill - * the request, resolves to false otherwise. Rejects if an error occurred. - */ - - }, { - key: "setAlwaysOnScreen", - value: function setAlwaysOnScreen(value) { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.UpdateAlwaysOnScreen, { - value: value - }).then(function (res) { - return res.success; - }); - } - /** - * Opens a modal widget. - * @param {string} url The URL to the modal widget. - * @param {string} name The name of the widget. - * @param {IModalWidgetOpenRequestDataButton[]} buttons The buttons to have on the widget. - * @param {IModalWidgetCreateData} data Data to supply to the modal widget. - * @param {WidgetType} type The type of modal widget. - * @returns {Promise} Resolves when the modal widget has been opened. - */ - - }, { - key: "openModalWidget", - value: function openModalWidget(url, name) { - var buttons = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : []; - var data = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {}; - var type = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : _WidgetType.MatrixWidgetType.Custom; - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.OpenModalWidget, { - type: type, - url: url, - name: name, - buttons: buttons, - data: data - }).then(); - } - /** - * Closes the modal widget. The widget's session will be terminated shortly after. - * @param {IModalWidgetReturnData} data Optional data to close the modal widget with. - * @returns {Promise} Resolves when complete. - */ - - }, { - key: "closeModalWidget", - value: function closeModalWidget() { - var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.CloseModalWidget, data).then(); - } - }, { - key: "sendRoomEvent", - value: function sendRoomEvent(eventType, content, roomId) { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SendEvent, { - type: eventType, - content: content, - room_id: roomId - }); - } - }, { - key: "sendStateEvent", - value: function sendStateEvent(eventType, stateKey, content, roomId) { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SendEvent, { - type: eventType, - content: content, - state_key: stateKey, - room_id: roomId - }); - } - /** - * Sends a to-device event. - * @param {string} eventType The type of events being sent. - * @param {boolean} encrypted Whether to encrypt the message contents. - * @param {Object} contentMap A map from user IDs to device IDs to message contents. - * @returns {Promise} Resolves when complete. - */ - - }, { - key: "sendToDevice", - value: function sendToDevice(eventType, encrypted, contentMap) { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SendToDevice, { - type: eventType, - encrypted: encrypted, - messages: contentMap - }); - } - }, { - key: "readRoomEvents", - value: function readRoomEvents(eventType, limit, msgtype, roomIds) { - var data = { - type: eventType, - msgtype: msgtype - }; - - if (limit !== undefined) { - data.limit = limit; - } - - if (roomIds) { - if (roomIds.includes(_Symbols.Symbols.AnyRoom)) { - data.room_ids = _Symbols.Symbols.AnyRoom; - } else { - data.room_ids = roomIds; - } - } - - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC2876ReadEvents, data).then(function (r) { - return r.events; - }); - } - /** - * Reads all related events given a known eventId. - * @param eventId The id of the parent event to be read. - * @param roomId The room to look within. When undefined, the user's currently - * viewed room. - * @param relationType The relationship type of child events to search for. - * When undefined, all relations are returned. - * @param eventType The event type of child events to search for. When undefined, - * all related events are returned. - * @param limit The maximum number of events to retrieve per room. If not - * supplied, the server will apply a default limit. - * @param from The pagination token to start returning results from, as - * received from a previous call. If not supplied, results start at the most - * recent topological event known to the server. - * @param to The pagination token to stop returning results at. If not - * supplied, results continue up to limit or until there are no more events. - * @param direction The direction to search for according to MSC3715. - * @returns Resolves to the room relations. - */ - - }, { - key: "readEventRelations", - value: function () { - var _readEventRelations = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(eventId, roomId, relationType, eventType, limit, from, to, direction) { - var versions, data; - return _regeneratorRuntime().wrap(function _callee$(_context) { - while (1) { - switch (_context.prev = _context.next) { - case 0: - _context.next = 2; - return this.getClientVersions(); - - case 2: - versions = _context.sent; - - if (versions.includes(_ApiVersion.UnstableApiVersion.MSC3869)) { - _context.next = 5; - break; - } - - throw new Error("The read_relations action is not supported by the client."); - - case 5: - data = { - event_id: eventId, - rel_type: relationType, - event_type: eventType, - room_id: roomId, - to: to, - from: from, - limit: limit, - direction: direction - }; - return _context.abrupt("return", this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC3869ReadRelations, data)); - - case 7: - case "end": - return _context.stop(); - } - } - }, _callee, this); - })); - - function readEventRelations(_x, _x2, _x3, _x4, _x5, _x6, _x7, _x8) { - return _readEventRelations.apply(this, arguments); - } - - return readEventRelations; - }() - }, { - key: "readStateEvents", - value: function readStateEvents(eventType, limit, stateKey, roomIds) { - var data = { - type: eventType, - state_key: stateKey === undefined ? true : stateKey - }; - - if (limit !== undefined) { - data.limit = limit; - } - - if (roomIds) { - if (roomIds.includes(_Symbols.Symbols.AnyRoom)) { - data.room_ids = _Symbols.Symbols.AnyRoom; - } else { - data.room_ids = roomIds; - } - } - - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC2876ReadEvents, data).then(function (r) { - return r.events; - }); - } - /** - * Sets a button as disabled or enabled on the modal widget. Buttons are enabled by default. - * @param {ModalButtonID} buttonId The button ID to enable/disable. - * @param {boolean} isEnabled Whether or not the button is enabled. - * @returns {Promise} Resolves when complete. - * @throws Throws if the button cannot be disabled, or the client refuses to disable the button. - */ - - }, { - key: "setModalButtonEnabled", - value: function setModalButtonEnabled(buttonId, isEnabled) { - if (buttonId === _ModalWidgetActions.BuiltInModalButtonID.Close) { - throw new Error("The close button cannot be disabled"); - } - - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SetModalButtonEnabled, { - button: buttonId, - enabled: isEnabled - }).then(); - } - /** - * Attempts to navigate the client to the given URI. This can only be called with Matrix URIs - * (currently only matrix.to, but in future a Matrix URI scheme will be defined). - * @param {string} uri The URI to navigate to. - * @returns {Promise} Resolves when complete. - * @throws Throws if the URI is invalid or cannot be processed. - * @deprecated This currently relies on an unstable MSC (MSC2931). - */ - - }, { - key: "navigateTo", - value: function navigateTo(uri) { - if (!uri || !uri.startsWith("https://matrix.to/#")) { - throw new Error("Invalid matrix.to URI"); - } - - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC2931Navigate, { - uri: uri - }).then(); - } - /** - * Starts watching for TURN servers, yielding an initial set of credentials as soon as possible, - * and thereafter yielding new credentials whenever the previous ones expire. - * @yields {ITurnServer} The TURN server URIs and credentials currently available to the widget. - */ - - }, { - key: "getTurnServers", - value: function getTurnServers() { - var _this = this; - - return _wrapAsyncGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3() { - var setTurnServer, onUpdateTurnServers; - return _regeneratorRuntime().wrap(function _callee3$(_context3) { - while (1) { - switch (_context3.prev = _context3.next) { - case 0: - onUpdateTurnServers = /*#__PURE__*/function () { - var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(ev) { - return _regeneratorRuntime().wrap(function _callee2$(_context2) { - while (1) { - switch (_context2.prev = _context2.next) { - case 0: - ev.preventDefault(); - setTurnServer(ev.detail.data); - _context2.next = 4; - return _this.transport.reply(ev.detail, {}); - - case 4: - case "end": - return _context2.stop(); - } - } - }, _callee2); - })); - - return function onUpdateTurnServers(_x9) { - return _ref.apply(this, arguments); - }; - }(); // Start listening for updates before we even start watching, to catch - // TURN data that is sent immediately - - - _this.on("action:".concat(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers), onUpdateTurnServers); // Only send the 'watch' action if we aren't already watching - - - if (!(_this.turnServerWatchers === 0)) { - _context3.next = 12; - break; - } - - _context3.prev = 3; - _context3.next = 6; - return _awaitAsyncGenerator(_this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.WatchTurnServers, {})); - - case 6: - _context3.next = 12; - break; - - case 8: - _context3.prev = 8; - _context3.t0 = _context3["catch"](3); - - _this.off("action:".concat(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers), onUpdateTurnServers); - - throw _context3.t0; - - case 12: - _this.turnServerWatchers++; - _context3.prev = 13; - - case 14: - if (!true) { - _context3.next = 21; - break; - } - - _context3.next = 17; - return _awaitAsyncGenerator(new Promise(function (resolve) { - return setTurnServer = resolve; - })); - - case 17: - _context3.next = 19; - return _context3.sent; - - case 19: - _context3.next = 14; - break; - - case 21: - _context3.prev = 21; - - // The loop was broken by the caller - clean up - _this.off("action:".concat(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers), onUpdateTurnServers); // Since sending the 'unwatch' action will end updates for all other - // consumers, only send it if we're the only consumer remaining - - - _this.turnServerWatchers--; - - if (!(_this.turnServerWatchers === 0)) { - _context3.next = 27; - break; - } - - _context3.next = 27; - return _awaitAsyncGenerator(_this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.UnwatchTurnServers, {})); - - case 27: - return _context3.finish(21); - - case 28: - case "end": - return _context3.stop(); - } - } - }, _callee3, null, [[3, 8], [13,, 21, 28]]); - }))(); - } - /** - * Search for users in the user directory. - * @param searchTerm The term to search for. - * @param limit The maximum number of results to return. If not supplied, the - * @returns Resolves to the search results. - */ - - }, { - key: "searchUserDirectory", - value: function () { - var _searchUserDirectory = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee4(searchTerm, limit) { - var versions, data; - return _regeneratorRuntime().wrap(function _callee4$(_context4) { - while (1) { - switch (_context4.prev = _context4.next) { - case 0: - _context4.next = 2; - return this.getClientVersions(); - - case 2: - versions = _context4.sent; - - if (versions.includes(_ApiVersion.UnstableApiVersion.MSC3973)) { - _context4.next = 5; - break; - } - - throw new Error("The user_directory_search action is not supported by the client."); - - case 5: - data = { - search_term: searchTerm, - limit: limit - }; - return _context4.abrupt("return", this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC3973UserDirectorySearch, data)); - - case 7: - case "end": - return _context4.stop(); - } - } - }, _callee4, this); - })); - - function searchUserDirectory(_x10, _x11) { - return _searchUserDirectory.apply(this, arguments); - } - - return searchUserDirectory; - }() - /** - * Starts the communication channel. This should be done early to ensure - * that messages are not missed. Communication can only be stopped by the client. - */ - - }, { - key: "start", - value: function start() { - var _this5 = this; - - this.transport.start(); - this.getClientVersions().then(function (v) { - if (v.includes(_ApiVersion.UnstableApiVersion.MSC2974)) { - _this5.supportsMSC2974Renegotiate = true; - } - }); - } - }, { - key: "handleMessage", - value: function handleMessage(ev) { - var actionEv = new CustomEvent("action:".concat(ev.detail.action), { - detail: ev.detail, - cancelable: true - }); - this.emit("action:".concat(ev.detail.action), actionEv); - - if (!actionEv.defaultPrevented) { - switch (ev.detail.action) { - case _WidgetApiAction.WidgetApiToWidgetAction.SupportedApiVersions: - return this.replyVersions(ev.detail); - - case _WidgetApiAction.WidgetApiToWidgetAction.Capabilities: - return this.handleCapabilities(ev.detail); - - case _WidgetApiAction.WidgetApiToWidgetAction.UpdateVisibility: - return this.transport.reply(ev.detail, {}); - // ack to avoid error spam - - case _WidgetApiAction.WidgetApiToWidgetAction.NotifyCapabilities: - return this.transport.reply(ev.detail, {}); - // ack to avoid error spam - - default: - return this.transport.reply(ev.detail, { - error: { - message: "Unknown or unsupported action: " + ev.detail.action - } - }); - } - } - } - }, { - key: "replyVersions", - value: function replyVersions(request) { - this.transport.reply(request, { - supported_versions: _ApiVersion.CurrentApiVersions - }); - } - }, { - key: "getClientVersions", - value: function getClientVersions() { - var _this6 = this; - - if (Array.isArray(this.cachedClientVersions)) { - return Promise.resolve(this.cachedClientVersions); - } - - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SupportedApiVersions, {}).then(function (r) { - _this6.cachedClientVersions = r.supported_versions; - return r.supported_versions; - })["catch"](function (e) { - console.warn("non-fatal error getting supported client versions: ", e); - return []; - }); - } - }, { - key: "handleCapabilities", - value: function handleCapabilities(request) { - var _this7 = this; - - if (this.capabilitiesFinished) { - return this.transport.reply(request, { - error: { - message: "Capability negotiation already completed" - } - }); - } // See if we can expect a capabilities notification or not - - - return this.getClientVersions().then(function (v) { - if (v.includes(_ApiVersion.UnstableApiVersion.MSC2871)) { - _this7.once("action:".concat(_WidgetApiAction.WidgetApiToWidgetAction.NotifyCapabilities), function (ev) { - _this7.approvedCapabilities = ev.detail.data.approved; - - _this7.emit("ready"); - }); - } else { - // if we can't expect notification, we're as done as we can be - _this7.emit("ready"); - } // in either case, reply to that capabilities request - - - _this7.capabilitiesFinished = true; - return _this7.transport.reply(request, { - capabilities: _this7.requestedCapabilities - }); - }); - } - }]); - - return WidgetApi; -}(_events.EventEmitter); - -exports.WidgetApi = WidgetApi; -},{"./Symbols":2,"./interfaces/ApiVersion":6,"./interfaces/GetOpenIDAction":10,"./interfaces/ModalWidgetActions":20,"./interfaces/WidgetApiAction":34,"./interfaces/WidgetApiDirection":35,"./interfaces/WidgetType":38,"./models/WidgetEventCapability":40,"./transport/PostmessageTransport":46,"events":48}],4:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetDriver = void 0; - -var _ = require(".."); - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -/** - * Represents the functions and behaviour the widget-api is unable to - * do, such as prompting the user for information or interacting with - * the UI. Clients are expected to implement this class and override - * any functions they need/want to support. - * - * This class assumes the client will have a context of a Widget - * instance already. - */ -var WidgetDriver = /*#__PURE__*/function () { - function WidgetDriver() { - _classCallCheck(this, WidgetDriver); - } - - _createClass(WidgetDriver, [{ - key: "validateCapabilities", - value: - /** - * Verifies the widget's requested capabilities, returning the ones - * it is approved to use. Mutating the requested capabilities will - * have no effect. - * - * This SHOULD result in the user being prompted to approve/deny - * capabilities. - * - * By default this rejects all capabilities (returns an empty set). - * @param {Set} requested The set of requested capabilities. - * @returns {Promise>} Resolves to the allowed capabilities. - */ - function validateCapabilities(requested) { - return Promise.resolve(new Set()); - } - /** - * Sends an event into a room. If `roomId` is falsy, the client should send the event - * into the room the user is currently looking at. The widget API will have already - * verified that the widget is capable of sending the event to that room. - * @param {string} eventType The event type to be sent. - * @param {*} content The content for the event. - * @param {string|null} stateKey The state key if this is a state event, otherwise null. - * May be an empty string. - * @param {string|null} roomId The room ID to send the event to. If falsy, the room the - * user is currently looking at. - * @returns {Promise} Resolves when the event has been sent with - * details of that event. - * @throws Rejected when the event could not be sent. - */ - - }, { - key: "sendEvent", - value: function sendEvent(eventType, content) { - var stateKey = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; - var roomId = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; - return Promise.reject(new Error("Failed to override function")); - } - /** - * Sends a to-device event. The widget API will have already verified that the widget - * is capable of sending the event. - * @param {string} eventType The event type to be sent. - * @param {boolean} encrypted Whether to encrypt the message contents. - * @param {Object} contentMap A map from user ID and device ID to event content. - * @returns {Promise} Resolves when the event has been sent. - * @throws Rejected when the event could not be sent. - */ - - }, { - key: "sendToDevice", - value: function sendToDevice(eventType, encrypted, contentMap) { - return Promise.reject(new Error("Failed to override function")); - } - /** - * Reads all events of the given type, and optionally `msgtype` (if applicable/defined), - * the user has access to. The widget API will have already verified that the widget is - * capable of receiving the events. Less events than the limit are allowed to be returned, - * but not more. If `roomIds` is supplied, it may contain `Symbols.AnyRoom` to denote that - * `limit` in each of the client's known rooms should be returned. When `null`, only the - * room the user is currently looking at should be considered. - * @param eventType The event type to be read. - * @param msgtype The msgtype of the events to be read, if applicable/defined. - * @param limit The maximum number of events to retrieve per room. Will be zero to denote "as many - * as possible". - * @param roomIds When null, the user's currently viewed room. Otherwise, the list of room IDs - * to look within, possibly containing Symbols.AnyRoom to denote all known rooms. - * @returns {Promise} Resolves to the room events, or an empty array. - */ - - }, { - key: "readRoomEvents", - value: function readRoomEvents(eventType, msgtype, limit) { - var roomIds = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; - return Promise.resolve([]); - } - /** - * Reads all events of the given type, and optionally state key (if applicable/defined), - * the user has access to. The widget API will have already verified that the widget is - * capable of receiving the events. Less events than the limit are allowed to be returned, - * but not more. If `roomIds` is supplied, it may contain `Symbols.AnyRoom` to denote that - * `limit` in each of the client's known rooms should be returned. When `null`, only the - * room the user is currently looking at should be considered. - * @param eventType The event type to be read. - * @param stateKey The state key of the events to be read, if applicable/defined. - * @param limit The maximum number of events to retrieve. Will be zero to denote "as many - * as possible". - * @param roomIds When null, the user's currently viewed room. Otherwise, the list of room IDs - * to look within, possibly containing Symbols.AnyRoom to denote all known rooms. - * @returns {Promise} Resolves to the state events, or an empty array. - */ - - }, { - key: "readStateEvents", - value: function readStateEvents(eventType, stateKey, limit) { - var roomIds = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; - return Promise.resolve([]); - } - /** - * Reads all events that are related to a given event. The widget API will - * have already verified that the widget is capable of receiving the event, - * or will make sure to reject access to events which are returned from this - * function, but are not capable of receiving. If `relationType` or `eventType` - * are set, the returned events should already be filtered. Less events than - * the limit are allowed to be returned, but not more. - * @param eventId The id of the parent event to be read. - * @param roomId The room to look within. When undefined, the user's - * currently viewed room. - * @param relationType The relationship type of child events to search for. - * When undefined, all relations are returned. - * @param eventType The event type of child events to search for. When undefined, - * all related events are returned. - * @param from The pagination token to start returning results from, as - * received from a previous call. If not supplied, results start at the most - * recent topological event known to the server. - * @param to The pagination token to stop returning results at. If not - * supplied, results continue up to limit or until there are no more events. - * @param limit The maximum number of events to retrieve per room. If not - * supplied, the server will apply a default limit. - * @param direction The direction to search for according to MSC3715 - * @returns Resolves to the room relations. - */ - - }, { - key: "readEventRelations", - value: function readEventRelations(eventId, roomId, relationType, eventType, from, to, limit, direction) { - return Promise.resolve({ - chunk: [] - }); - } - /** - * Asks the user for permission to validate their identity through OpenID Connect. The - * interface for this function is an observable which accepts the state machine of the - * OIDC exchange flow. For example, if the client/user blocks the request then it would - * feed back a `{state: Blocked}` into the observable. Similarly, if the user already - * approved the widget then a `{state: Allowed}` would be fed into the observable alongside - * the token itself. If the client is asking for permission, it should feed in a - * `{state: PendingUserConfirmation}` followed by the relevant Allowed or Blocked state. - * - * The widget API will reject the widget's request with an error if this contract is not - * met properly. By default, the widget driver will block all OIDC requests. - * @param {SimpleObservable} observer The observable to feed updates into. - */ - - }, { - key: "askOpenID", - value: function askOpenID(observer) { - observer.update({ - state: _.OpenIDRequestState.Blocked - }); - } - /** - * Navigates the client with a matrix.to URI. In future this function will also be provided - * with the Matrix URIs once matrix.to is replaced. The given URI will have already been - * lightly checked to ensure it looks like a valid URI, though the implementation is recommended - * to do further checks on the URI. - * @param {string} uri The URI to navigate to. - * @returns {Promise} Resolves when complete. - * @throws Throws if there's a problem with the navigation, such as invalid format. - */ - - }, { - key: "navigate", - value: function navigate(uri) { - throw new Error("Navigation is not implemented"); - } - /** - * Polls for TURN server data, yielding an initial set of credentials as soon as possible, and - * thereafter yielding new credentials whenever the previous ones expire. The widget API will - * have already verified that the widget has permission to access TURN servers. - * @yields {ITurnServer} The TURN server URIs and credentials currently available to the client. - */ - - }, { - key: "getTurnServers", - value: function getTurnServers() { - throw new Error("TURN server support is not implemented"); - } - /** - * Search for users in the user directory. - * @param searchTerm The term to search for. - * @param limit The maximum number of results to return. If not supplied, the - * @returns Resolves to the search results. - */ - - }, { - key: "searchUserDirectory", - value: function searchUserDirectory(searchTerm, limit) { - return Promise.resolve({ - limited: false, - results: [] - }); - } - }]); - - return WidgetDriver; -}(); - -exports.WidgetDriver = WidgetDriver; -},{"..":5}],5:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); - -var _WidgetApi = require("./WidgetApi"); - -Object.keys(_WidgetApi).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetApi[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetApi[key]; - } - }); -}); - -var _ClientWidgetApi = require("./ClientWidgetApi"); - -Object.keys(_ClientWidgetApi).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ClientWidgetApi[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ClientWidgetApi[key]; - } - }); -}); - -var _Symbols = require("./Symbols"); - -Object.keys(_Symbols).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _Symbols[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _Symbols[key]; - } - }); -}); - -var _ITransport = require("./transport/ITransport"); - -Object.keys(_ITransport).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ITransport[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ITransport[key]; - } - }); -}); - -var _PostmessageTransport = require("./transport/PostmessageTransport"); - -Object.keys(_PostmessageTransport).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _PostmessageTransport[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _PostmessageTransport[key]; - } - }); -}); - -var _ICustomWidgetData = require("./interfaces/ICustomWidgetData"); - -Object.keys(_ICustomWidgetData).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ICustomWidgetData[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ICustomWidgetData[key]; - } - }); -}); - -var _IJitsiWidgetData = require("./interfaces/IJitsiWidgetData"); - -Object.keys(_IJitsiWidgetData).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IJitsiWidgetData[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IJitsiWidgetData[key]; - } - }); -}); - -var _IStickerpickerWidgetData = require("./interfaces/IStickerpickerWidgetData"); - -Object.keys(_IStickerpickerWidgetData).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IStickerpickerWidgetData[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IStickerpickerWidgetData[key]; - } - }); -}); - -var _IWidget = require("./interfaces/IWidget"); - -Object.keys(_IWidget).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IWidget[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IWidget[key]; - } - }); -}); - -var _WidgetType = require("./interfaces/WidgetType"); - -Object.keys(_WidgetType).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetType[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetType[key]; - } - }); -}); - -var _IWidgetApiErrorResponse = require("./interfaces/IWidgetApiErrorResponse"); - -Object.keys(_IWidgetApiErrorResponse).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IWidgetApiErrorResponse[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IWidgetApiErrorResponse[key]; - } - }); -}); - -var _IWidgetApiRequest = require("./interfaces/IWidgetApiRequest"); - -Object.keys(_IWidgetApiRequest).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IWidgetApiRequest[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IWidgetApiRequest[key]; - } - }); -}); - -var _IWidgetApiResponse = require("./interfaces/IWidgetApiResponse"); - -Object.keys(_IWidgetApiResponse).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IWidgetApiResponse[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IWidgetApiResponse[key]; - } - }); -}); - -var _WidgetApiAction = require("./interfaces/WidgetApiAction"); - -Object.keys(_WidgetApiAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetApiAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetApiAction[key]; - } - }); -}); - -var _WidgetApiDirection = require("./interfaces/WidgetApiDirection"); - -Object.keys(_WidgetApiDirection).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetApiDirection[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetApiDirection[key]; - } - }); -}); - -var _ApiVersion = require("./interfaces/ApiVersion"); - -Object.keys(_ApiVersion).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ApiVersion[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ApiVersion[key]; - } - }); -}); - -var _Capabilities = require("./interfaces/Capabilities"); - -Object.keys(_Capabilities).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _Capabilities[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _Capabilities[key]; - } - }); -}); - -var _CapabilitiesAction = require("./interfaces/CapabilitiesAction"); - -Object.keys(_CapabilitiesAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _CapabilitiesAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _CapabilitiesAction[key]; - } - }); -}); - -var _ContentLoadedAction = require("./interfaces/ContentLoadedAction"); - -Object.keys(_ContentLoadedAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ContentLoadedAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ContentLoadedAction[key]; - } - }); -}); - -var _ScreenshotAction = require("./interfaces/ScreenshotAction"); - -Object.keys(_ScreenshotAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ScreenshotAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ScreenshotAction[key]; - } - }); -}); - -var _StickerAction = require("./interfaces/StickerAction"); - -Object.keys(_StickerAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _StickerAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _StickerAction[key]; - } - }); -}); - -var _StickyAction = require("./interfaces/StickyAction"); - -Object.keys(_StickyAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _StickyAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _StickyAction[key]; - } - }); -}); - -var _SupportedVersionsAction = require("./interfaces/SupportedVersionsAction"); - -Object.keys(_SupportedVersionsAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _SupportedVersionsAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _SupportedVersionsAction[key]; - } - }); -}); - -var _VisibilityAction = require("./interfaces/VisibilityAction"); - -Object.keys(_VisibilityAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _VisibilityAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _VisibilityAction[key]; - } - }); -}); - -var _GetOpenIDAction = require("./interfaces/GetOpenIDAction"); - -Object.keys(_GetOpenIDAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _GetOpenIDAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _GetOpenIDAction[key]; - } - }); -}); - -var _OpenIDCredentialsAction = require("./interfaces/OpenIDCredentialsAction"); - -Object.keys(_OpenIDCredentialsAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _OpenIDCredentialsAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _OpenIDCredentialsAction[key]; - } - }); -}); - -var _WidgetKind = require("./interfaces/WidgetKind"); - -Object.keys(_WidgetKind).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetKind[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetKind[key]; - } - }); -}); - -var _ModalButtonKind = require("./interfaces/ModalButtonKind"); - -Object.keys(_ModalButtonKind).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ModalButtonKind[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ModalButtonKind[key]; - } - }); -}); - -var _ModalWidgetActions = require("./interfaces/ModalWidgetActions"); - -Object.keys(_ModalWidgetActions).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ModalWidgetActions[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ModalWidgetActions[key]; - } - }); -}); - -var _SetModalButtonEnabledAction = require("./interfaces/SetModalButtonEnabledAction"); - -Object.keys(_SetModalButtonEnabledAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _SetModalButtonEnabledAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _SetModalButtonEnabledAction[key]; - } - }); -}); - -var _WidgetConfigAction = require("./interfaces/WidgetConfigAction"); - -Object.keys(_WidgetConfigAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetConfigAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetConfigAction[key]; - } - }); -}); - -var _SendEventAction = require("./interfaces/SendEventAction"); - -Object.keys(_SendEventAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _SendEventAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _SendEventAction[key]; - } - }); -}); - -var _SendToDeviceAction = require("./interfaces/SendToDeviceAction"); - -Object.keys(_SendToDeviceAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _SendToDeviceAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _SendToDeviceAction[key]; - } - }); -}); - -var _ReadEventAction = require("./interfaces/ReadEventAction"); - -Object.keys(_ReadEventAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ReadEventAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ReadEventAction[key]; - } - }); -}); - -var _IRoomEvent = require("./interfaces/IRoomEvent"); - -Object.keys(_IRoomEvent).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IRoomEvent[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IRoomEvent[key]; - } - }); -}); - -var _NavigateAction = require("./interfaces/NavigateAction"); - -Object.keys(_NavigateAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _NavigateAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _NavigateAction[key]; - } - }); -}); - -var _TurnServerActions = require("./interfaces/TurnServerActions"); - -Object.keys(_TurnServerActions).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _TurnServerActions[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _TurnServerActions[key]; - } - }); -}); - -var _ReadRelationsAction = require("./interfaces/ReadRelationsAction"); - -Object.keys(_ReadRelationsAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ReadRelationsAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ReadRelationsAction[key]; - } - }); -}); - -var _WidgetEventCapability = require("./models/WidgetEventCapability"); - -Object.keys(_WidgetEventCapability).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetEventCapability[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetEventCapability[key]; - } - }); -}); - -var _url = require("./models/validation/url"); - -Object.keys(_url).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _url[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _url[key]; - } - }); -}); - -var _utils = require("./models/validation/utils"); - -Object.keys(_utils).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _utils[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _utils[key]; - } - }); -}); - -var _Widget = require("./models/Widget"); - -Object.keys(_Widget).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _Widget[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _Widget[key]; - } - }); -}); - -var _WidgetParser = require("./models/WidgetParser"); - -Object.keys(_WidgetParser).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetParser[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetParser[key]; - } - }); -}); - -var _urlTemplate = require("./templating/url-template"); - -Object.keys(_urlTemplate).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _urlTemplate[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _urlTemplate[key]; - } - }); -}); - -var _SimpleObservable = require("./util/SimpleObservable"); - -Object.keys(_SimpleObservable).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _SimpleObservable[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _SimpleObservable[key]; - } - }); -}); - -var _WidgetDriver = require("./driver/WidgetDriver"); - -Object.keys(_WidgetDriver).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetDriver[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetDriver[key]; - } - }); -}); -},{"./ClientWidgetApi":1,"./Symbols":2,"./WidgetApi":3,"./driver/WidgetDriver":4,"./interfaces/ApiVersion":6,"./interfaces/Capabilities":7,"./interfaces/CapabilitiesAction":8,"./interfaces/ContentLoadedAction":9,"./interfaces/GetOpenIDAction":10,"./interfaces/ICustomWidgetData":11,"./interfaces/IJitsiWidgetData":12,"./interfaces/IRoomEvent":13,"./interfaces/IStickerpickerWidgetData":14,"./interfaces/IWidget":15,"./interfaces/IWidgetApiErrorResponse":16,"./interfaces/IWidgetApiRequest":17,"./interfaces/IWidgetApiResponse":18,"./interfaces/ModalButtonKind":19,"./interfaces/ModalWidgetActions":20,"./interfaces/NavigateAction":21,"./interfaces/OpenIDCredentialsAction":22,"./interfaces/ReadEventAction":23,"./interfaces/ReadRelationsAction":24,"./interfaces/ScreenshotAction":25,"./interfaces/SendEventAction":26,"./interfaces/SendToDeviceAction":27,"./interfaces/SetModalButtonEnabledAction":28,"./interfaces/StickerAction":29,"./interfaces/StickyAction":30,"./interfaces/SupportedVersionsAction":31,"./interfaces/TurnServerActions":32,"./interfaces/VisibilityAction":33,"./interfaces/WidgetApiAction":34,"./interfaces/WidgetApiDirection":35,"./interfaces/WidgetConfigAction":36,"./interfaces/WidgetKind":37,"./interfaces/WidgetType":38,"./models/Widget":39,"./models/WidgetEventCapability":40,"./models/WidgetParser":41,"./models/validation/url":42,"./models/validation/utils":43,"./templating/url-template":44,"./transport/ITransport":45,"./transport/PostmessageTransport":46,"./util/SimpleObservable":47}],6:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.UnstableApiVersion = exports.MatrixApiVersion = exports.CurrentApiVersions = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var MatrixApiVersion; -exports.MatrixApiVersion = MatrixApiVersion; - -(function (MatrixApiVersion) { - MatrixApiVersion["Prerelease1"] = "0.0.1"; - MatrixApiVersion["Prerelease2"] = "0.0.2"; -})(MatrixApiVersion || (exports.MatrixApiVersion = MatrixApiVersion = {})); - -var UnstableApiVersion; -exports.UnstableApiVersion = UnstableApiVersion; - -(function (UnstableApiVersion) { - UnstableApiVersion["MSC2762"] = "org.matrix.msc2762"; - UnstableApiVersion["MSC2871"] = "org.matrix.msc2871"; - UnstableApiVersion["MSC2931"] = "org.matrix.msc2931"; - UnstableApiVersion["MSC2974"] = "org.matrix.msc2974"; - UnstableApiVersion["MSC2876"] = "org.matrix.msc2876"; - UnstableApiVersion["MSC3819"] = "org.matrix.msc3819"; - UnstableApiVersion["MSC3846"] = "town.robin.msc3846"; - UnstableApiVersion["MSC3869"] = "org.matrix.msc3869"; - UnstableApiVersion["MSC3973"] = "org.matrix.msc3973"; -})(UnstableApiVersion || (exports.UnstableApiVersion = UnstableApiVersion = {})); - -var CurrentApiVersions = [MatrixApiVersion.Prerelease1, MatrixApiVersion.Prerelease2, //MatrixApiVersion.V010, -UnstableApiVersion.MSC2762, UnstableApiVersion.MSC2871, UnstableApiVersion.MSC2931, UnstableApiVersion.MSC2974, UnstableApiVersion.MSC2876, UnstableApiVersion.MSC3819, UnstableApiVersion.MSC3846, UnstableApiVersion.MSC3869, UnstableApiVersion.MSC3973]; -exports.CurrentApiVersions = CurrentApiVersions; -},{}],7:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.VideoConferenceCapabilities = exports.StickerpickerCapabilities = exports.MatrixCapabilities = void 0; -exports.getTimelineRoomIDFromCapability = getTimelineRoomIDFromCapability; -exports.isTimelineCapability = isTimelineCapability; -exports.isTimelineCapabilityFor = isTimelineCapabilityFor; - -/* - * Copyright 2020 - 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var MatrixCapabilities; -exports.MatrixCapabilities = MatrixCapabilities; - -(function (MatrixCapabilities) { - MatrixCapabilities["Screenshots"] = "m.capability.screenshot"; - MatrixCapabilities["StickerSending"] = "m.sticker"; - MatrixCapabilities["AlwaysOnScreen"] = "m.always_on_screen"; - MatrixCapabilities["RequiresClient"] = "io.element.requires_client"; - MatrixCapabilities["MSC2931Navigate"] = "org.matrix.msc2931.navigate"; - MatrixCapabilities["MSC3846TurnServers"] = "town.robin.msc3846.turn_servers"; - MatrixCapabilities["MSC3973UserDirectorySearch"] = "org.matrix.msc3973.user_directory_search"; -})(MatrixCapabilities || (exports.MatrixCapabilities = MatrixCapabilities = {})); - -var StickerpickerCapabilities = [MatrixCapabilities.StickerSending]; -exports.StickerpickerCapabilities = StickerpickerCapabilities; -var VideoConferenceCapabilities = [MatrixCapabilities.AlwaysOnScreen]; -/** - * Determines if a capability is a capability for a timeline. - * @param {Capability} capability The capability to test. - * @returns {boolean} True if a timeline capability, false otherwise. - */ - -exports.VideoConferenceCapabilities = VideoConferenceCapabilities; - -function isTimelineCapability(capability) { - // TODO: Change when MSC2762 becomes stable. - return capability === null || capability === void 0 ? void 0 : capability.startsWith("org.matrix.msc2762.timeline:"); -} -/** - * Determines if a capability is a timeline capability for the given room. - * @param {Capability} capability The capability to test. - * @param {string | Symbols.AnyRoom} roomId The room ID, or `Symbols.AnyRoom` for that designation. - * @returns {boolean} True if a matching capability, false otherwise. - */ - - -function isTimelineCapabilityFor(capability, roomId) { - return capability === "org.matrix.msc2762.timeline:".concat(roomId); -} -/** - * Gets the room ID described by a timeline capability. - * @param {string} capability The capability to parse. - * @returns {string} The room ID. - */ - - -function getTimelineRoomIDFromCapability(capability) { - return capability.substring(capability.indexOf(":") + 1); -} -},{}],8:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -},{}],9:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],10:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.OpenIDRequestState = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var OpenIDRequestState; -exports.OpenIDRequestState = OpenIDRequestState; - -(function (OpenIDRequestState) { - OpenIDRequestState["Allowed"] = "allowed"; - OpenIDRequestState["Blocked"] = "blocked"; - OpenIDRequestState["PendingUserConfirmation"] = "request"; -})(OpenIDRequestState || (exports.OpenIDRequestState = OpenIDRequestState = {})); -},{}],11:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],12:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],13:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],14:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],15:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],16:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.isErrorResponse = isErrorResponse; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function isErrorResponse(responseData) { - if ("error" in responseData) { - var err = responseData; - return !!err.error.message; - } - - return false; -} -},{}],17:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],18:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],19:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ModalButtonKind = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var ModalButtonKind; -exports.ModalButtonKind = ModalButtonKind; - -(function (ModalButtonKind) { - ModalButtonKind["Primary"] = "m.primary"; - ModalButtonKind["Secondary"] = "m.secondary"; - ModalButtonKind["Warning"] = "m.warning"; - ModalButtonKind["Danger"] = "m.danger"; - ModalButtonKind["Link"] = "m.link"; -})(ModalButtonKind || (exports.ModalButtonKind = ModalButtonKind = {})); -},{}],20:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.BuiltInModalButtonID = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var BuiltInModalButtonID; -exports.BuiltInModalButtonID = BuiltInModalButtonID; - -(function (BuiltInModalButtonID) { - BuiltInModalButtonID["Close"] = "m.close"; -})(BuiltInModalButtonID || (exports.BuiltInModalButtonID = BuiltInModalButtonID = {})); -},{}],21:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],22:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],23:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],24:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],25:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],26:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],27:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],28:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],29:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],30:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],31:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],32:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],33:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],34:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetApiToWidgetAction = exports.WidgetApiFromWidgetAction = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var WidgetApiToWidgetAction; -exports.WidgetApiToWidgetAction = WidgetApiToWidgetAction; - -(function (WidgetApiToWidgetAction) { - WidgetApiToWidgetAction["SupportedApiVersions"] = "supported_api_versions"; - WidgetApiToWidgetAction["Capabilities"] = "capabilities"; - WidgetApiToWidgetAction["NotifyCapabilities"] = "notify_capabilities"; - WidgetApiToWidgetAction["TakeScreenshot"] = "screenshot"; - WidgetApiToWidgetAction["UpdateVisibility"] = "visibility"; - WidgetApiToWidgetAction["OpenIDCredentials"] = "openid_credentials"; - WidgetApiToWidgetAction["WidgetConfig"] = "widget_config"; - WidgetApiToWidgetAction["CloseModalWidget"] = "close_modal"; - WidgetApiToWidgetAction["ButtonClicked"] = "button_clicked"; - WidgetApiToWidgetAction["SendEvent"] = "send_event"; - WidgetApiToWidgetAction["SendToDevice"] = "send_to_device"; - WidgetApiToWidgetAction["UpdateTurnServers"] = "update_turn_servers"; -})(WidgetApiToWidgetAction || (exports.WidgetApiToWidgetAction = WidgetApiToWidgetAction = {})); - -var WidgetApiFromWidgetAction; -exports.WidgetApiFromWidgetAction = WidgetApiFromWidgetAction; - -(function (WidgetApiFromWidgetAction) { - WidgetApiFromWidgetAction["SupportedApiVersions"] = "supported_api_versions"; - WidgetApiFromWidgetAction["ContentLoaded"] = "content_loaded"; - WidgetApiFromWidgetAction["SendSticker"] = "m.sticker"; - WidgetApiFromWidgetAction["UpdateAlwaysOnScreen"] = "set_always_on_screen"; - WidgetApiFromWidgetAction["GetOpenIDCredentials"] = "get_openid"; - WidgetApiFromWidgetAction["CloseModalWidget"] = "close_modal"; - WidgetApiFromWidgetAction["OpenModalWidget"] = "open_modal"; - WidgetApiFromWidgetAction["SetModalButtonEnabled"] = "set_button_enabled"; - WidgetApiFromWidgetAction["SendEvent"] = "send_event"; - WidgetApiFromWidgetAction["SendToDevice"] = "send_to_device"; - WidgetApiFromWidgetAction["WatchTurnServers"] = "watch_turn_servers"; - WidgetApiFromWidgetAction["UnwatchTurnServers"] = "unwatch_turn_servers"; - WidgetApiFromWidgetAction["MSC2876ReadEvents"] = "org.matrix.msc2876.read_events"; - WidgetApiFromWidgetAction["MSC2931Navigate"] = "org.matrix.msc2931.navigate"; - WidgetApiFromWidgetAction["MSC2974RenegotiateCapabilities"] = "org.matrix.msc2974.request_capabilities"; - WidgetApiFromWidgetAction["MSC3869ReadRelations"] = "org.matrix.msc3869.read_relations"; - WidgetApiFromWidgetAction["MSC3973UserDirectorySearch"] = "org.matrix.msc3973.user_directory_search"; -})(WidgetApiFromWidgetAction || (exports.WidgetApiFromWidgetAction = WidgetApiFromWidgetAction = {})); -},{}],35:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetApiDirection = void 0; -exports.invertedDirection = invertedDirection; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var WidgetApiDirection; -exports.WidgetApiDirection = WidgetApiDirection; - -(function (WidgetApiDirection) { - WidgetApiDirection["ToWidget"] = "toWidget"; - WidgetApiDirection["FromWidget"] = "fromWidget"; -})(WidgetApiDirection || (exports.WidgetApiDirection = WidgetApiDirection = {})); - -function invertedDirection(dir) { - if (dir === WidgetApiDirection.ToWidget) { - return WidgetApiDirection.FromWidget; - } else if (dir === WidgetApiDirection.FromWidget) { - return WidgetApiDirection.ToWidget; - } else { - throw new Error("Invalid direction"); - } -} -},{}],36:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],37:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetKind = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var WidgetKind; -exports.WidgetKind = WidgetKind; - -(function (WidgetKind) { - WidgetKind["Room"] = "room"; - WidgetKind["Account"] = "account"; - WidgetKind["Modal"] = "modal"; -})(WidgetKind || (exports.WidgetKind = WidgetKind = {})); -},{}],38:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MatrixWidgetType = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var MatrixWidgetType; -exports.MatrixWidgetType = MatrixWidgetType; - -(function (MatrixWidgetType) { - MatrixWidgetType["Custom"] = "m.custom"; - MatrixWidgetType["JitsiMeet"] = "m.jitsi"; - MatrixWidgetType["Stickerpicker"] = "m.stickerpicker"; -})(MatrixWidgetType || (exports.MatrixWidgetType = MatrixWidgetType = {})); -},{}],39:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.Widget = void 0; - -var _utils = require("./validation/utils"); - -var _ = require(".."); - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -/** - * Represents the barest form of widget. - */ -var Widget = /*#__PURE__*/function () { - function Widget(definition) { - _classCallCheck(this, Widget); - - this.definition = definition; - if (!this.definition) throw new Error("Definition is required"); - (0, _utils.assertPresent)(definition, "id"); - (0, _utils.assertPresent)(definition, "creatorUserId"); - (0, _utils.assertPresent)(definition, "type"); - (0, _utils.assertPresent)(definition, "url"); - } - /** - * The user ID who created the widget. - */ - - - _createClass(Widget, [{ - key: "creatorUserId", - get: function get() { - return this.definition.creatorUserId; - } - /** - * The type of widget. - */ - - }, { - key: "type", - get: function get() { - return this.definition.type; - } - /** - * The ID of the widget. - */ - - }, { - key: "id", - get: function get() { - return this.definition.id; - } - /** - * The name of the widget, or null if not set. - */ - - }, { - key: "name", - get: function get() { - return this.definition.name || null; - } - /** - * The title for the widget, or null if not set. - */ - - }, { - key: "title", - get: function get() { - return this.rawData.title || null; - } - /** - * The templated URL for the widget. - */ - - }, { - key: "templateUrl", - get: function get() { - return this.definition.url; - } - /** - * The origin for this widget. - */ - - }, { - key: "origin", - get: function get() { - return new URL(this.templateUrl).origin; - } - /** - * Whether or not the client should wait for the iframe to load. Defaults - * to true. - */ - - }, { - key: "waitForIframeLoad", - get: function get() { - if (this.definition.waitForIframeLoad === false) return false; - if (this.definition.waitForIframeLoad === true) return true; - return true; // default true - } - /** - * The raw data for the widget. This will always be defined, though - * may be empty. - */ - - }, { - key: "rawData", - get: function get() { - return this.definition.data || {}; - } - /** - * Gets a complete widget URL for the client to render. - * @param {ITemplateParams} params The template parameters. - * @returns {string} A templated URL. - */ - - }, { - key: "getCompleteUrl", - value: function getCompleteUrl(params) { - return (0, _.runTemplate)(this.templateUrl, this.definition, params); - } - }]); - - return Widget; -}(); - -exports.Widget = Widget; -},{"..":5,"./validation/utils":43}],40:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetEventCapability = exports.EventKind = exports.EventDirection = void 0; - -function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; } - -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } - -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var EventKind; -exports.EventKind = EventKind; - -(function (EventKind) { - EventKind["Event"] = "event"; - EventKind["State"] = "state_event"; - EventKind["ToDevice"] = "to_device"; -})(EventKind || (exports.EventKind = EventKind = {})); - -var EventDirection; -exports.EventDirection = EventDirection; - -(function (EventDirection) { - EventDirection["Send"] = "send"; - EventDirection["Receive"] = "receive"; -})(EventDirection || (exports.EventDirection = EventDirection = {})); - -var WidgetEventCapability = /*#__PURE__*/function () { - function WidgetEventCapability(direction, eventType, kind, keyStr, raw) { - _classCallCheck(this, WidgetEventCapability); - - this.direction = direction; - this.eventType = eventType; - this.kind = kind; - this.keyStr = keyStr; - this.raw = raw; - } - - _createClass(WidgetEventCapability, [{ - key: "matchesAsStateEvent", - value: function matchesAsStateEvent(direction, eventType, stateKey) { - if (this.kind !== EventKind.State) return false; // not a state event - - if (this.direction !== direction) return false; // direction mismatch - - if (this.eventType !== eventType) return false; // event type mismatch - - if (this.keyStr === null) return true; // all state keys are allowed - - if (this.keyStr === stateKey) return true; // this state key is allowed - // Default not allowed - - return false; - } - }, { - key: "matchesAsToDeviceEvent", - value: function matchesAsToDeviceEvent(direction, eventType) { - if (this.kind !== EventKind.ToDevice) return false; // not a to-device event - - if (this.direction !== direction) return false; // direction mismatch - - if (this.eventType !== eventType) return false; // event type mismatch - // Checks passed, the event is allowed - - return true; - } - }, { - key: "matchesAsRoomEvent", - value: function matchesAsRoomEvent(direction, eventType) { - var msgtype = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; - if (this.kind !== EventKind.Event) return false; // not a room event - - if (this.direction !== direction) return false; // direction mismatch - - if (this.eventType !== eventType) return false; // event type mismatch - - if (this.eventType === "m.room.message") { - if (this.keyStr === null) return true; // all message types are allowed - - if (this.keyStr === msgtype) return true; // this message type is allowed - } else { - return true; // already passed the check for if the event is allowed - } // Default not allowed - - - return false; - } - }], [{ - key: "forStateEvent", - value: function forStateEvent(direction, eventType, stateKey) { - // TODO: Enable support for m.* namespace once the MSC lands. - // https://github.com/matrix-org/matrix-widget-api/issues/22 - eventType = eventType.replace(/#/g, '\\#'); - stateKey = stateKey !== null && stateKey !== undefined ? "#".concat(stateKey) : ''; - var str = "org.matrix.msc2762.".concat(direction, ".state_event:").concat(eventType).concat(stateKey); // cheat by sending it through the processor - - return WidgetEventCapability.findEventCapabilities([str])[0]; - } - }, { - key: "forToDeviceEvent", - value: function forToDeviceEvent(direction, eventType) { - // TODO: Enable support for m.* namespace once the MSC lands. - // https://github.com/matrix-org/matrix-widget-api/issues/56 - var str = "org.matrix.msc3819.".concat(direction, ".to_device:").concat(eventType); // cheat by sending it through the processor - - return WidgetEventCapability.findEventCapabilities([str])[0]; - } - }, { - key: "forRoomEvent", - value: function forRoomEvent(direction, eventType) { - // TODO: Enable support for m.* namespace once the MSC lands. - // https://github.com/matrix-org/matrix-widget-api/issues/22 - var str = "org.matrix.msc2762.".concat(direction, ".event:").concat(eventType); // cheat by sending it through the processor - - return WidgetEventCapability.findEventCapabilities([str])[0]; - } - }, { - key: "forRoomMessageEvent", - value: function forRoomMessageEvent(direction, msgtype) { - // TODO: Enable support for m.* namespace once the MSC lands. - // https://github.com/matrix-org/matrix-widget-api/issues/22 - msgtype = msgtype === null || msgtype === undefined ? '' : msgtype; - var str = "org.matrix.msc2762.".concat(direction, ".event:m.room.message#").concat(msgtype); // cheat by sending it through the processor - - return WidgetEventCapability.findEventCapabilities([str])[0]; - } - /** - * Parses a capabilities request to find all the event capability requests. - * @param {Iterable} capabilities The capabilities requested/to parse. - * @returns {WidgetEventCapability[]} An array of event capability requests. May be empty, but never null. - */ - - }, { - key: "findEventCapabilities", - value: function findEventCapabilities(capabilities) { - var parsed = []; - - var _iterator = _createForOfIteratorHelper(capabilities), - _step; - - try { - for (_iterator.s(); !(_step = _iterator.n()).done;) { - var cap = _step.value; - var _direction = null; - var eventSegment = void 0; - var _kind = null; // TODO: Enable support for m.* namespace once the MSCs land. - // https://github.com/matrix-org/matrix-widget-api/issues/22 - // https://github.com/matrix-org/matrix-widget-api/issues/56 - - if (cap.startsWith("org.matrix.msc2762.send.event:")) { - _direction = EventDirection.Send; - _kind = EventKind.Event; - eventSegment = cap.substring("org.matrix.msc2762.send.event:".length); - } else if (cap.startsWith("org.matrix.msc2762.send.state_event:")) { - _direction = EventDirection.Send; - _kind = EventKind.State; - eventSegment = cap.substring("org.matrix.msc2762.send.state_event:".length); - } else if (cap.startsWith("org.matrix.msc3819.send.to_device:")) { - _direction = EventDirection.Send; - _kind = EventKind.ToDevice; - eventSegment = cap.substring("org.matrix.msc3819.send.to_device:".length); - } else if (cap.startsWith("org.matrix.msc2762.receive.event:")) { - _direction = EventDirection.Receive; - _kind = EventKind.Event; - eventSegment = cap.substring("org.matrix.msc2762.receive.event:".length); - } else if (cap.startsWith("org.matrix.msc2762.receive.state_event:")) { - _direction = EventDirection.Receive; - _kind = EventKind.State; - eventSegment = cap.substring("org.matrix.msc2762.receive.state_event:".length); - } else if (cap.startsWith("org.matrix.msc3819.receive.to_device:")) { - _direction = EventDirection.Receive; - _kind = EventKind.ToDevice; - eventSegment = cap.substring("org.matrix.msc3819.receive.to_device:".length); - } - - if (_direction === null || _kind === null || eventSegment === undefined) continue; // The capability uses `#` as a separator between event type and state key/msgtype, - // so we split on that. However, a # is also valid in either one of those so we - // join accordingly. - // Eg: `m.room.message##m.text` is "m.room.message" event with msgtype "#m.text". - - var expectingKeyStr = eventSegment.startsWith("m.room.message#") || _kind === EventKind.State; - - var _keyStr = null; - - if (eventSegment.includes('#') && expectingKeyStr) { - // Dev note: regex is difficult to write, so instead the rules are manually written - // out. This is probably just as understandable as a boring regex though, so win-win? - // Test cases: - // str eventSegment keyStr - // ------------------------------------------------------------- - // m.room.message# m.room.message - // m.room.message#test m.room.message test - // m.room.message\# m.room.message# test - // m.room.message##test m.room.message #test - // m.room.message\##test m.room.message# test - // m.room.message\\##test m.room.message\# test - // m.room.message\\###test m.room.message\# #test - // First step: explode the string - var parts = eventSegment.split('#'); // To form the eventSegment, we'll keep finding parts of the exploded string until - // there's one that doesn't end with the escape character (\). We'll then join those - // segments together with the exploding character. We have to remember to consume the - // escape character as well. - - var idx = parts.findIndex(function (p) { - return !p.endsWith("\\"); - }); - eventSegment = parts.slice(0, idx + 1).map(function (p) { - return p.endsWith('\\') ? p.substring(0, p.length - 1) : p; - }).join('#'); // The keyStr is whatever is left over. - - _keyStr = parts.slice(idx + 1).join('#'); - } - - parsed.push(new WidgetEventCapability(_direction, eventSegment, _kind, _keyStr, cap)); - } - } catch (err) { - _iterator.e(err); - } finally { - _iterator.f(); - } - - return parsed; - } - }]); - - return WidgetEventCapability; -}(); - -exports.WidgetEventCapability = WidgetEventCapability; -},{}],41:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetParser = void 0; - -var _Widget = require("./Widget"); - -var _url = require("./validation/url"); - -function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; } - -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } - -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -var WidgetParser = /*#__PURE__*/function () { - function WidgetParser() {// private constructor because this is a util class - - _classCallCheck(this, WidgetParser); - } - /** - * Parses widgets from the "m.widgets" account data event. This will always - * return an array, though may be empty if no valid widgets were found. - * @param {IAccountDataWidgets} content The content of the "m.widgets" account data. - * @returns {Widget[]} The widgets in account data, or an empty array. - */ - - - _createClass(WidgetParser, null, [{ - key: "parseAccountData", - value: function parseAccountData(content) { - if (!content) return []; - var result = []; - - for (var _i = 0, _Object$keys = Object.keys(content); _i < _Object$keys.length; _i++) { - var _widgetId = _Object$keys[_i]; - var roughWidget = content[_widgetId]; - if (!roughWidget) continue; - if (roughWidget.type !== "m.widget" && roughWidget.type !== "im.vector.modular.widgets") continue; - if (!roughWidget.sender) continue; - var probableWidgetId = roughWidget.state_key || roughWidget.id; - if (probableWidgetId !== _widgetId) continue; - var asStateEvent = { - content: roughWidget.content, - sender: roughWidget.sender, - type: "m.widget", - state_key: _widgetId, - event_id: "$example", - room_id: "!example", - origin_server_ts: 1 - }; - var widget = WidgetParser.parseRoomWidget(asStateEvent); - if (widget) result.push(widget); - } - - return result; - } - /** - * Parses all the widgets possible in the given array. This will always return - * an array, though may be empty if no widgets could be parsed. - * @param {IStateEvent[]} currentState The room state to parse. - * @returns {Widget[]} The widgets in the state, or an empty array. - */ - - }, { - key: "parseWidgetsFromRoomState", - value: function parseWidgetsFromRoomState(currentState) { - if (!currentState) return []; - var result = []; - - var _iterator = _createForOfIteratorHelper(currentState), - _step; - - try { - for (_iterator.s(); !(_step = _iterator.n()).done;) { - var state = _step.value; - var widget = WidgetParser.parseRoomWidget(state); - if (widget) result.push(widget); - } - } catch (err) { - _iterator.e(err); - } finally { - _iterator.f(); - } - - return result; - } - /** - * Parses a state event into a widget. If the state event does not represent - * a widget (wrong event type, invalid widget, etc) then null is returned. - * @param {IStateEvent} stateEvent The state event. - * @returns {Widget|null} The widget, or null if invalid - */ - - }, { - key: "parseRoomWidget", - value: function parseRoomWidget(stateEvent) { - if (!stateEvent) return null; // TODO: [Legacy] Remove legacy support - - if (stateEvent.type !== "m.widget" && stateEvent.type !== "im.vector.modular.widgets") { - return null; - } // Dev note: Throughout this function we have null safety to ensure that - // if the caller did not supply something useful that we don't error. This - // is done against the requirements of the interface because not everyone - // will have an interface to validate against. - - - var content = stateEvent.content || {}; // Form our best approximation of a widget with the information we have - - var estimatedWidget = { - id: stateEvent.state_key, - creatorUserId: content['creatorUserId'] || stateEvent.sender, - name: content['name'], - type: content['type'], - url: content['url'], - waitForIframeLoad: content['waitForIframeLoad'], - data: content['data'] - }; // Finally, process that widget - - return WidgetParser.processEstimatedWidget(estimatedWidget); - } - }, { - key: "processEstimatedWidget", - value: function processEstimatedWidget(widget) { - // Validate that the widget has the best chance of passing as a widget - if (!widget.id || !widget.creatorUserId || !widget.type) { - return null; - } - - if (!(0, _url.isValidUrl)(widget.url)) { - return null; - } // TODO: Validate data for known widget types - - - return new _Widget.Widget(widget); - } - }]); - - return WidgetParser; -}(); - -exports.WidgetParser = WidgetParser; -},{"./Widget":39,"./validation/url":42}],42:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.isValidUrl = isValidUrl; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function isValidUrl(val) { - if (!val) return false; // easy: not valid if not present - - try { - var parsed = new URL(val); - - if (parsed.protocol !== "http" && parsed.protocol !== "https") { - return false; - } - - return true; - } catch (e) { - if (e instanceof TypeError) { - return false; - } - - throw e; - } -} -},{}],43:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.assertPresent = assertPresent; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function assertPresent(obj, key) { - if (!obj[key]) { - throw new Error("".concat(key, " is required")); - } -} -},{}],44:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.runTemplate = runTemplate; -exports.toString = toString; - -/* - * Copyright 2020, 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function runTemplate(url, widget, params) { - // Always apply the supplied params over top of data to ensure the data can't lie about them. - var variables = Object.assign({}, widget.data, { - 'matrix_room_id': params.widgetRoomId || "", - 'matrix_user_id': params.currentUserId, - 'matrix_display_name': params.userDisplayName || params.currentUserId, - 'matrix_avatar_url': params.userHttpAvatarUrl || "", - 'matrix_widget_id': widget.id, - // TODO: Convert to stable (https://github.com/matrix-org/matrix-doc/pull/2873) - 'org.matrix.msc2873.client_id': params.clientId || "", - 'org.matrix.msc2873.client_theme': params.clientTheme || "", - 'org.matrix.msc2873.client_language': params.clientLanguage || "" - }); - var result = url; - - for (var _i = 0, _Object$keys = Object.keys(variables); _i < _Object$keys.length; _i++) { - var key = _Object$keys[_i]; - // Regex escape from https://stackoverflow.com/a/6969486/7037379 - var pattern = "$".concat(key).replace(/[.*+?^${}()|[\]\\]/g, '\\$&'); // $& means the whole matched string - - var rexp = new RegExp(pattern, 'g'); // This is technically not what we're supposed to do for a couple of reasons: - // 1. We are assuming that there won't later be a $key match after we replace a variable. - // 2. We are assuming that the variable is in a place where it can be escaped (eg: path or query string). - - result = result.replace(rexp, encodeURIComponent(toString(variables[key]))); - } - - return result; -} - -function toString(a) { - if (a === null || a === undefined) { - return "".concat(a); - } - - return String(a); -} -},{}],45:[function(require,module,exports){ -arguments[4][8][0].apply(exports,arguments) -},{"dup":8}],46:[function(require,module,exports){ -"use strict"; - -function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.PostmessageTransport = void 0; - -var _events = require("events"); - -var _ = require(".."); - -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } - -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); } - -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } - -function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } - -function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); } - -function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } - -function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } - -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } - -/** - * Transport for the Widget API over postMessage. - */ -var PostmessageTransport = /*#__PURE__*/function (_EventEmitter) { - _inherits(PostmessageTransport, _EventEmitter); - - var _super = _createSuper(PostmessageTransport); - - function PostmessageTransport(sendDirection, initialWidgetId, transportWindow, inboundWindow) { - var _this; - - _classCallCheck(this, PostmessageTransport); - - _this = _super.call(this); - _this.sendDirection = sendDirection; - _this.initialWidgetId = initialWidgetId; - _this.transportWindow = transportWindow; - _this.inboundWindow = inboundWindow; - - _defineProperty(_assertThisInitialized(_this), "strictOriginCheck", false); - - _defineProperty(_assertThisInitialized(_this), "targetOrigin", "*"); - - _defineProperty(_assertThisInitialized(_this), "timeoutSeconds", 10); - - _defineProperty(_assertThisInitialized(_this), "_ready", false); - - _defineProperty(_assertThisInitialized(_this), "_widgetId", null); - - _defineProperty(_assertThisInitialized(_this), "outboundRequests", new Map()); - - _defineProperty(_assertThisInitialized(_this), "stopController", new AbortController()); - - _this._widgetId = initialWidgetId; - return _this; - } - - _createClass(PostmessageTransport, [{ - key: "ready", - get: function get() { - return this._ready; - } - }, { - key: "widgetId", - get: function get() { - return this._widgetId || null; - } - }, { - key: "nextRequestId", - get: function get() { - var idBase = "widgetapi-".concat(Date.now()); - var index = 0; - var id = idBase; - - while (this.outboundRequests.has(id)) { - id = "".concat(idBase, "-").concat(index++); - } // reserve the ID - - - this.outboundRequests.set(id, null); - return id; - } - }, { - key: "sendInternal", - value: function sendInternal(message) { - console.log("[PostmessageTransport] Sending object to ".concat(this.targetOrigin, ": "), message); - this.transportWindow.postMessage(message, this.targetOrigin); - } - }, { - key: "reply", - value: function reply(request, responseData) { - return this.sendInternal(_objectSpread(_objectSpread({}, request), {}, { - response: responseData - })); - } - }, { - key: "send", - value: function send(action, data) { - return this.sendComplete(action, data).then(function (r) { - return r.response; - }); - } - }, { - key: "sendComplete", - value: function sendComplete(action, data) { - var _this2 = this; - - if (!this.ready || !this.widgetId) { - return Promise.reject(new Error("Not ready or unknown widget ID")); - } - - var request = { - api: this.sendDirection, - widgetId: this.widgetId, - requestId: this.nextRequestId, - action: action, - data: data - }; - - if (action === _.WidgetApiToWidgetAction.UpdateVisibility) { - request['visible'] = data['visible']; - } - - return new Promise(function (prResolve, prReject) { - var resolve = function resolve(response) { - cleanUp(); - prResolve(response); - }; - - var reject = function reject(err) { - cleanUp(); - prReject(err); - }; - - var timerId = setTimeout(function () { - return reject(new Error("Request timed out")); - }, (_this2.timeoutSeconds || 1) * 1000); - - var onStop = function onStop() { - return reject(new Error("Transport stopped")); - }; - - _this2.stopController.signal.addEventListener("abort", onStop); - - var cleanUp = function cleanUp() { - _this2.outboundRequests["delete"](request.requestId); - - clearTimeout(timerId); - - _this2.stopController.signal.removeEventListener("abort", onStop); - }; - - _this2.outboundRequests.set(request.requestId, { - request: request, - resolve: resolve, - reject: reject - }); - - _this2.sendInternal(request); - }); - } - }, { - key: "start", - value: function start() { - var _this3 = this; - - this.inboundWindow.addEventListener("message", function (ev) { - _this3.handleMessage(ev); - }); - this._ready = true; - } - }, { - key: "stop", - value: function stop() { - this._ready = false; - this.stopController.abort(); - } - }, { - key: "handleMessage", - value: function handleMessage(ev) { - if (this.stopController.signal.aborted) return; - if (!ev.data) return; // invalid event - - if (this.strictOriginCheck && ev.origin !== window.origin) return; // bad origin - // treat the message as a response first, then downgrade to a request - - var response = ev.data; - if (!response.action || !response.requestId || !response.widgetId) return; // invalid request/response - - if (!response.response) { - // it's a request - var request = response; - if (request.api !== (0, _.invertedDirection)(this.sendDirection)) return; // wrong direction - - this.handleRequest(request); - } else { - // it's a response - if (response.api !== this.sendDirection) return; // wrong direction - - this.handleResponse(response); - } - } - }, { - key: "handleRequest", - value: function handleRequest(request) { - if (this.widgetId) { - if (this.widgetId !== request.widgetId) return; // wrong widget - } else { - this._widgetId = request.widgetId; - } - - this.emit("message", new CustomEvent("message", { - detail: request - })); - } - }, { - key: "handleResponse", - value: function handleResponse(response) { - if (response.widgetId !== this.widgetId) return; // wrong widget - - var req = this.outboundRequests.get(response.requestId); - if (!req) return; // response to an unknown request - - if ((0, _.isErrorResponse)(response.response)) { - var _err = response.response; - req.reject(new Error(_err.error.message)); - } else { - req.resolve(response); - } - } - }]); - - return PostmessageTransport; -}(_events.EventEmitter); - -exports.PostmessageTransport = PostmessageTransport; -},{"..":5,"events":48}],47:[function(require,module,exports){ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SimpleObservable = void 0; - -function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; } - -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } - -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var SimpleObservable = /*#__PURE__*/function () { - function SimpleObservable(initialFn) { - _classCallCheck(this, SimpleObservable); - - _defineProperty(this, "listeners", []); - - if (initialFn) this.listeners.push(initialFn); - } - - _createClass(SimpleObservable, [{ - key: "onUpdate", - value: function onUpdate(fn) { - this.listeners.push(fn); - } - }, { - key: "update", - value: function update(val) { - var _iterator = _createForOfIteratorHelper(this.listeners), - _step; - - try { - for (_iterator.s(); !(_step = _iterator.n()).done;) { - var listener = _step.value; - listener(val); - } - } catch (err) { - _iterator.e(err); - } finally { - _iterator.f(); - } - } - }, { - key: "close", - value: function close() { - this.listeners = []; // reset - } - }]); - - return SimpleObservable; -}(); - -exports.SimpleObservable = SimpleObservable; -},{}],48:[function(require,module,exports){ -// Copyright Joyent, Inc. and other Node contributors. -// -// Permission is hereby granted, free of charge, to any person obtaining a -// copy of this software and associated documentation files (the -// "Software"), to deal in the Software without restriction, including -// without limitation the rights to use, copy, modify, merge, publish, -// distribute, sublicense, and/or sell copies of the Software, and to permit -// persons to whom the Software is furnished to do so, subject to the -// following conditions: -// -// The above copyright notice and this permission notice shall be included -// in all copies or substantial portions of the Software. -// -// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS -// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN -// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, -// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR -// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE -// USE OR OTHER DEALINGS IN THE SOFTWARE. - -'use strict'; - -var R = typeof Reflect === 'object' ? Reflect : null -var ReflectApply = R && typeof R.apply === 'function' - ? R.apply - : function ReflectApply(target, receiver, args) { - return Function.prototype.apply.call(target, receiver, args); - } - -var ReflectOwnKeys -if (R && typeof R.ownKeys === 'function') { - ReflectOwnKeys = R.ownKeys -} else if (Object.getOwnPropertySymbols) { - ReflectOwnKeys = function ReflectOwnKeys(target) { - return Object.getOwnPropertyNames(target) - .concat(Object.getOwnPropertySymbols(target)); - }; -} else { - ReflectOwnKeys = function ReflectOwnKeys(target) { - return Object.getOwnPropertyNames(target); - }; -} - -function ProcessEmitWarning(warning) { - if (console && console.warn) console.warn(warning); -} - -var NumberIsNaN = Number.isNaN || function NumberIsNaN(value) { - return value !== value; -} - -function EventEmitter() { - EventEmitter.init.call(this); -} -module.exports = EventEmitter; -module.exports.once = once; - -// Backwards-compat with node 0.10.x -EventEmitter.EventEmitter = EventEmitter; - -EventEmitter.prototype._events = undefined; -EventEmitter.prototype._eventsCount = 0; -EventEmitter.prototype._maxListeners = undefined; - -// By default EventEmitters will print a warning if more than 10 listeners are -// added to it. This is a useful default which helps finding memory leaks. -var defaultMaxListeners = 10; - -function checkListener(listener) { - if (typeof listener !== 'function') { - throw new TypeError('The "listener" argument must be of type Function. Received type ' + typeof listener); - } -} - -Object.defineProperty(EventEmitter, 'defaultMaxListeners', { - enumerable: true, - get: function() { - return defaultMaxListeners; - }, - set: function(arg) { - if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) { - throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received ' + arg + '.'); - } - defaultMaxListeners = arg; - } -}); - -EventEmitter.init = function() { - - if (this._events === undefined || - this._events === Object.getPrototypeOf(this)._events) { - this._events = Object.create(null); - this._eventsCount = 0; - } - - this._maxListeners = this._maxListeners || undefined; -}; - -// Obviously not all Emitters should be limited to 10. This function allows -// that to be increased. Set to zero for unlimited. -EventEmitter.prototype.setMaxListeners = function setMaxListeners(n) { - if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) { - throw new RangeError('The value of "n" is out of range. It must be a non-negative number. Received ' + n + '.'); - } - this._maxListeners = n; - return this; -}; - -function _getMaxListeners(that) { - if (that._maxListeners === undefined) - return EventEmitter.defaultMaxListeners; - return that._maxListeners; -} - -EventEmitter.prototype.getMaxListeners = function getMaxListeners() { - return _getMaxListeners(this); -}; - -EventEmitter.prototype.emit = function emit(type) { - var args = []; - for (var i = 1; i < arguments.length; i++) args.push(arguments[i]); - var doError = (type === 'error'); - - var events = this._events; - if (events !== undefined) - doError = (doError && events.error === undefined); - else if (!doError) - return false; - - // If there is no 'error' event listener then throw. - if (doError) { - var er; - if (args.length > 0) - er = args[0]; - if (er instanceof Error) { - // Note: The comments on the `throw` lines are intentional, they show - // up in Node's output if this results in an unhandled exception. - throw er; // Unhandled 'error' event - } - // At least give some kind of context to the user - var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : '')); - err.context = er; - throw err; // Unhandled 'error' event - } - - var handler = events[type]; - - if (handler === undefined) - return false; - - if (typeof handler === 'function') { - ReflectApply(handler, this, args); - } else { - var len = handler.length; - var listeners = arrayClone(handler, len); - for (var i = 0; i < len; ++i) - ReflectApply(listeners[i], this, args); - } - - return true; -}; - -function _addListener(target, type, listener, prepend) { - var m; - var events; - var existing; - - checkListener(listener); - - events = target._events; - if (events === undefined) { - events = target._events = Object.create(null); - target._eventsCount = 0; - } else { - // To avoid recursion in the case that type === "newListener"! Before - // adding it to the listeners, first emit "newListener". - if (events.newListener !== undefined) { - target.emit('newListener', type, - listener.listener ? listener.listener : listener); - - // Re-assign `events` because a newListener handler could have caused the - // this._events to be assigned to a new object - events = target._events; - } - existing = events[type]; - } - - if (existing === undefined) { - // Optimize the case of one listener. Don't need the extra array object. - existing = events[type] = listener; - ++target._eventsCount; - } else { - if (typeof existing === 'function') { - // Adding the second element, need to change to array. - existing = events[type] = - prepend ? [listener, existing] : [existing, listener]; - // If we've already got an array, just append. - } else if (prepend) { - existing.unshift(listener); - } else { - existing.push(listener); - } - - // Check for listener leak - m = _getMaxListeners(target); - if (m > 0 && existing.length > m && !existing.warned) { - existing.warned = true; - // No error code for this since it is a Warning - // eslint-disable-next-line no-restricted-syntax - var w = new Error('Possible EventEmitter memory leak detected. ' + - existing.length + ' ' + String(type) + ' listeners ' + - 'added. Use emitter.setMaxListeners() to ' + - 'increase limit'); - w.name = 'MaxListenersExceededWarning'; - w.emitter = target; - w.type = type; - w.count = existing.length; - ProcessEmitWarning(w); - } - } - - return target; -} - -EventEmitter.prototype.addListener = function addListener(type, listener) { - return _addListener(this, type, listener, false); -}; - -EventEmitter.prototype.on = EventEmitter.prototype.addListener; - -EventEmitter.prototype.prependListener = - function prependListener(type, listener) { - return _addListener(this, type, listener, true); - }; - -function onceWrapper() { - if (!this.fired) { - this.target.removeListener(this.type, this.wrapFn); - this.fired = true; - if (arguments.length === 0) - return this.listener.call(this.target); - return this.listener.apply(this.target, arguments); - } -} - -function _onceWrap(target, type, listener) { - var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener }; - var wrapped = onceWrapper.bind(state); - wrapped.listener = listener; - state.wrapFn = wrapped; - return wrapped; -} - -EventEmitter.prototype.once = function once(type, listener) { - checkListener(listener); - this.on(type, _onceWrap(this, type, listener)); - return this; -}; - -EventEmitter.prototype.prependOnceListener = - function prependOnceListener(type, listener) { - checkListener(listener); - this.prependListener(type, _onceWrap(this, type, listener)); - return this; - }; - -// Emits a 'removeListener' event if and only if the listener was removed. -EventEmitter.prototype.removeListener = - function removeListener(type, listener) { - var list, events, position, i, originalListener; - - checkListener(listener); - - events = this._events; - if (events === undefined) - return this; - - list = events[type]; - if (list === undefined) - return this; - - if (list === listener || list.listener === listener) { - if (--this._eventsCount === 0) - this._events = Object.create(null); - else { - delete events[type]; - if (events.removeListener) - this.emit('removeListener', type, list.listener || listener); - } - } else if (typeof list !== 'function') { - position = -1; - - for (i = list.length - 1; i >= 0; i--) { - if (list[i] === listener || list[i].listener === listener) { - originalListener = list[i].listener; - position = i; - break; - } - } - - if (position < 0) - return this; - - if (position === 0) - list.shift(); - else { - spliceOne(list, position); - } - - if (list.length === 1) - events[type] = list[0]; - - if (events.removeListener !== undefined) - this.emit('removeListener', type, originalListener || listener); - } - - return this; - }; - -EventEmitter.prototype.off = EventEmitter.prototype.removeListener; - -EventEmitter.prototype.removeAllListeners = - function removeAllListeners(type) { - var listeners, events, i; - - events = this._events; - if (events === undefined) - return this; - - // not listening for removeListener, no need to emit - if (events.removeListener === undefined) { - if (arguments.length === 0) { - this._events = Object.create(null); - this._eventsCount = 0; - } else if (events[type] !== undefined) { - if (--this._eventsCount === 0) - this._events = Object.create(null); - else - delete events[type]; - } - return this; - } - - // emit removeListener for all listeners on all events - if (arguments.length === 0) { - var keys = Object.keys(events); - var key; - for (i = 0; i < keys.length; ++i) { - key = keys[i]; - if (key === 'removeListener') continue; - this.removeAllListeners(key); - } - this.removeAllListeners('removeListener'); - this._events = Object.create(null); - this._eventsCount = 0; - return this; - } - - listeners = events[type]; - - if (typeof listeners === 'function') { - this.removeListener(type, listeners); - } else if (listeners !== undefined) { - // LIFO order - for (i = listeners.length - 1; i >= 0; i--) { - this.removeListener(type, listeners[i]); - } - } - - return this; - }; - -function _listeners(target, type, unwrap) { - var events = target._events; - - if (events === undefined) - return []; - - var evlistener = events[type]; - if (evlistener === undefined) - return []; - - if (typeof evlistener === 'function') - return unwrap ? [evlistener.listener || evlistener] : [evlistener]; - - return unwrap ? - unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length); -} - -EventEmitter.prototype.listeners = function listeners(type) { - return _listeners(this, type, true); -}; - -EventEmitter.prototype.rawListeners = function rawListeners(type) { - return _listeners(this, type, false); -}; - -EventEmitter.listenerCount = function(emitter, type) { - if (typeof emitter.listenerCount === 'function') { - return emitter.listenerCount(type); - } else { - return listenerCount.call(emitter, type); - } -}; - -EventEmitter.prototype.listenerCount = listenerCount; -function listenerCount(type) { - var events = this._events; - - if (events !== undefined) { - var evlistener = events[type]; - - if (typeof evlistener === 'function') { - return 1; - } else if (evlistener !== undefined) { - return evlistener.length; - } - } - - return 0; -} - -EventEmitter.prototype.eventNames = function eventNames() { - return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : []; -}; - -function arrayClone(arr, n) { - var copy = new Array(n); - for (var i = 0; i < n; ++i) - copy[i] = arr[i]; - return copy; -} - -function spliceOne(list, index) { - for (; index + 1 < list.length; index++) - list[index] = list[index + 1]; - list.pop(); -} - -function unwrapListeners(arr) { - var ret = new Array(arr.length); - for (var i = 0; i < ret.length; ++i) { - ret[i] = arr[i].listener || arr[i]; - } - return ret; -} - -function once(emitter, name) { - return new Promise(function (resolve, reject) { - function errorListener(err) { - emitter.removeListener(name, resolver); - reject(err); - } - - function resolver() { - if (typeof emitter.removeListener === 'function') { - emitter.removeListener('error', errorListener); - } - resolve([].slice.call(arguments)); - }; - - eventTargetAgnosticAddListener(emitter, name, resolver, { once: true }); - if (name !== 'error') { - addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true }); - } - }); -} - -function addErrorHandlerIfEventEmitter(emitter, handler, flags) { - if (typeof emitter.on === 'function') { - eventTargetAgnosticAddListener(emitter, 'error', handler, flags); - } -} - -function eventTargetAgnosticAddListener(emitter, name, listener, flags) { - if (typeof emitter.on === 'function') { - if (flags.once) { - emitter.once(name, listener); - } else { - emitter.on(name, listener); - } - } else if (typeof emitter.addEventListener === 'function') { - // EventTarget does not have `error` event semantics like Node - // EventEmitters, we do not listen for `error` events here. - emitter.addEventListener(name, function wrapListener(arg) { - // IE does not have builtin `{ once: true }` support so we - // have to do it manually. - if (flags.once) { - emitter.removeEventListener(name, wrapListener); - } - listener(arg); - }); - } else { - throw new TypeError('The "emitter" argument must be of type EventEmitter. Received type ' + typeof emitter); - } -} - -},{}]},{},[5])(5) -}); - -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","lib/ClientWidgetApi.js","lib/Symbols.js","lib/WidgetApi.js","lib/driver/WidgetDriver.js","lib/index.js","lib/interfaces/ApiVersion.js","lib/interfaces/Capabilities.js","lib/interfaces/CapabilitiesAction.js","lib/interfaces/GetOpenIDAction.js","lib/interfaces/IWidgetApiErrorResponse.js","lib/interfaces/ModalButtonKind.js","lib/interfaces/ModalWidgetActions.js","lib/interfaces/WidgetApiAction.js","lib/interfaces/WidgetApiDirection.js","lib/interfaces/WidgetKind.js","lib/interfaces/WidgetType.js","lib/models/Widget.js","lib/models/WidgetEventCapability.js","lib/models/WidgetParser.js","lib/models/validation/url.js","lib/models/validation/utils.js","lib/templating/url-template.js","lib/transport/PostmessageTransport.js","lib/util/SimpleObservable.js","node_modules/events/events.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9zCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACz5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1lBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzEA;AACA;AACA;AACA;AACA;;;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;AC7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;AC7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC3BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5PA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC3DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9PA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.ClientWidgetApi = void 0;\n\nvar _events = require(\"events\");\n\nvar _PostmessageTransport = require(\"./transport/PostmessageTransport\");\n\nvar _WidgetApiDirection = require(\"./interfaces/WidgetApiDirection\");\n\nvar _WidgetApiAction = require(\"./interfaces/WidgetApiAction\");\n\nvar _Capabilities = require(\"./interfaces/Capabilities\");\n\nvar _ApiVersion = require(\"./interfaces/ApiVersion\");\n\nvar _WidgetEventCapability = require(\"./models/WidgetEventCapability\");\n\nvar _GetOpenIDAction = require(\"./interfaces/GetOpenIDAction\");\n\nvar _SimpleObservable = require(\"./util/SimpleObservable\");\n\nvar _Symbols = require(\"./Symbols\");\n\nfunction _regeneratorRuntime() { \"use strict\"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, $Symbol = \"function\" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || \"@@iterator\", asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\", toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, \"\"); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return generator._invoke = function (innerFn, self, context) { var state = \"suspendedStart\"; return function (method, arg) { if (\"executing\" === state) throw new Error(\"Generator is already running\"); if (\"completed\" === state) { if (\"throw\" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if (\"next\" === context.method) context.sent = context._sent = context.arg;else if (\"throw\" === context.method) { if (\"suspendedStart\" === state) throw state = \"completed\", context.arg; context.dispatchException(context.arg); } else \"return\" === context.method && context.abrupt(\"return\", context.arg); state = \"executing\"; var record = tryCatch(innerFn, self, context); if (\"normal\" === record.type) { if (state = context.done ? \"completed\" : \"suspendedYield\", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } \"throw\" === record.type && (state = \"completed\", context.method = \"throw\", context.arg = record.arg); } }; }(innerFn, self, context), generator; } function tryCatch(fn, obj, arg) { try { return { type: \"normal\", arg: fn.call(obj, arg) }; } catch (err) { return { type: \"throw\", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { [\"next\", \"throw\", \"return\"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if (\"throw\" !== record.type) { var result = record.arg, value = result.value; return value && \"object\" == _typeof(value) && hasOwn.call(value, \"__await\") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke(\"next\", value, resolve, reject); }, function (err) { invoke(\"throw\", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke(\"throw\", error, resolve, reject); }); } reject(record.arg); } var previousPromise; this._invoke = function (method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); }; } function maybeInvokeDelegate(delegate, context) { var method = delegate.iterator[context.method]; if (undefined === method) { if (context.delegate = null, \"throw\" === context.method) { if (delegate.iterator[\"return\"] && (context.method = \"return\", context.arg = undefined, maybeInvokeDelegate(delegate, context), \"throw\" === context.method)) return ContinueSentinel; context.method = \"throw\", context.arg = new TypeError(\"The iterator does not provide a 'throw' method\"); } return ContinueSentinel; } var record = tryCatch(method, delegate.iterator, context.arg); if (\"throw\" === record.type) return context.method = \"throw\", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, \"return\" !== context.method && (context.method = \"next\", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = \"throw\", context.arg = new TypeError(\"iterator result is not an object\"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = \"normal\", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: \"root\" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if (\"function\" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) { if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; } return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, define(Gp, \"constructor\", GeneratorFunctionPrototype), define(GeneratorFunctionPrototype, \"constructor\", GeneratorFunction), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, \"GeneratorFunction\"), exports.isGeneratorFunction = function (genFun) { var ctor = \"function\" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || \"GeneratorFunction\" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, \"GeneratorFunction\")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, \"Generator\"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, \"toString\", function () { return \"[object Generator]\"; }), exports.keys = function (object) { var keys = []; for (var key in object) { keys.push(key); } return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = \"next\", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) { \"t\" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); } }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if (\"throw\" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = \"throw\", record.arg = exception, context.next = loc, caught && (context.method = \"next\", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if (\"root\" === entry.tryLoc) return handle(\"end\"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, \"catchLoc\"), hasFinally = hasOwn.call(entry, \"finallyLoc\"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error(\"try statement without catch or finally\"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && (\"break\" === type || \"continue\" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = \"next\", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if (\"throw\" === record.type) throw record.arg; return \"break\" === record.type || \"continue\" === record.type ? this.next = record.arg : \"return\" === record.type ? (this.rval = this.arg = record.arg, this.method = \"return\", this.next = \"end\") : \"normal\" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, \"catch\": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if (\"throw\" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error(\"illegal catch attempt\"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, \"next\" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; }\n\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it[\"return\"] != null) it[\"return\"](); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, \"prototype\", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } else if (call !== void 0) { throw new TypeError(\"Derived constructors may only return object or undefined\"); } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _asyncIterator(iterable) { var method, async, sync, retry = 2; for (\"undefined\" != typeof Symbol && (async = Symbol.asyncIterator, sync = Symbol.iterator); retry--;) { if (async && null != (method = iterable[async])) return method.call(iterable); if (sync && null != (method = iterable[sync])) return new AsyncFromSyncIterator(method.call(iterable)); async = \"@@asyncIterator\", sync = \"@@iterator\"; } throw new TypeError(\"Object is not async iterable\"); }\n\nfunction AsyncFromSyncIterator(s) { function AsyncFromSyncIteratorContinuation(r) { if (Object(r) !== r) return Promise.reject(new TypeError(r + \" is not an object.\")); var done = r.done; return Promise.resolve(r.value).then(function (value) { return { value: value, done: done }; }); } return AsyncFromSyncIterator = function AsyncFromSyncIterator(s) { this.s = s, this.n = s.next; }, AsyncFromSyncIterator.prototype = { s: null, n: null, next: function next() { return AsyncFromSyncIteratorContinuation(this.n.apply(this.s, arguments)); }, \"return\": function _return(value) { var ret = this.s[\"return\"]; return void 0 === ret ? Promise.resolve({ value: value, done: !0 }) : AsyncFromSyncIteratorContinuation(ret.apply(this.s, arguments)); }, \"throw\": function _throw(value) { var thr = this.s[\"return\"]; return void 0 === thr ? Promise.reject(value) : AsyncFromSyncIteratorContinuation(thr.apply(this.s, arguments)); } }, new AsyncFromSyncIterator(s); }\n\n/**\n * API handler for the client side of widgets. This raises events\n * for each action received as `action:${action}` (eg: \"action:screenshot\").\n * Default handling can be prevented by using preventDefault() on the\n * raised event. The default handling varies for each action: ones\n * which the SDK can handle safely are acknowledged appropriately and\n * ones which are unhandled (custom or require the client to do something)\n * are rejected with an error.\n *\n * Events which are preventDefault()ed must reply using the transport.\n * The events raised will have a default of an IWidgetApiRequest\n * interface.\n *\n * When the ClientWidgetApi is ready to start sending requests, it will\n * raise a \"ready\" CustomEvent. After the ready event fires, actions can\n * be sent and the transport will be ready.\n *\n * When the widget has indicated it has loaded, this class raises a\n * \"preparing\" CustomEvent. The preparing event does not indicate that\n * the widget is ready to receive communications - that is signified by\n * the ready event exclusively.\n *\n * This class only handles one widget at a time.\n */\nvar ClientWidgetApi = /*#__PURE__*/function (_EventEmitter) {\n  _inherits(ClientWidgetApi, _EventEmitter);\n\n  var _super = _createSuper(ClientWidgetApi);\n\n  // contentLoadedActionSent is used to check that only one ContentLoaded request is send.\n\n  /**\n   * Creates a new client widget API. This will instantiate the transport\n   * and start everything. When the iframe is loaded under the widget's\n   * conditions, a \"ready\" event will be raised.\n   * @param {Widget} widget The widget to communicate with.\n   * @param {HTMLIFrameElement} iframe The iframe the widget is in.\n   * @param {WidgetDriver} driver The driver for this widget/client.\n   */\n  function ClientWidgetApi(widget, iframe, driver) {\n    var _this;\n\n    _classCallCheck(this, ClientWidgetApi);\n\n    _this = _super.call(this);\n    _this.widget = widget;\n    _this.iframe = iframe;\n    _this.driver = driver;\n\n    _defineProperty(_assertThisInitialized(_this), \"transport\", void 0);\n\n    _defineProperty(_assertThisInitialized(_this), \"contentLoadedActionSent\", false);\n\n    _defineProperty(_assertThisInitialized(_this), \"allowedCapabilities\", new Set());\n\n    _defineProperty(_assertThisInitialized(_this), \"allowedEvents\", []);\n\n    _defineProperty(_assertThisInitialized(_this), \"isStopped\", false);\n\n    _defineProperty(_assertThisInitialized(_this), \"turnServers\", null);\n\n    if (!(iframe !== null && iframe !== void 0 && iframe.contentWindow)) {\n      throw new Error(\"No iframe supplied\");\n    }\n\n    if (!widget) {\n      throw new Error(\"Invalid widget\");\n    }\n\n    if (!driver) {\n      throw new Error(\"Invalid driver\");\n    }\n\n    _this.transport = new _PostmessageTransport.PostmessageTransport(_WidgetApiDirection.WidgetApiDirection.ToWidget, widget.id, iframe.contentWindow, window);\n    _this.transport.targetOrigin = widget.origin;\n\n    _this.transport.on(\"message\", _this.handleMessage.bind(_assertThisInitialized(_this)));\n\n    iframe.addEventListener(\"load\", _this.onIframeLoad.bind(_assertThisInitialized(_this)));\n\n    _this.transport.start();\n\n    return _this;\n  }\n\n  _createClass(ClientWidgetApi, [{\n    key: \"hasCapability\",\n    value: function hasCapability(capability) {\n      return this.allowedCapabilities.has(capability);\n    }\n  }, {\n    key: \"canUseRoomTimeline\",\n    value: function canUseRoomTimeline(roomId) {\n      return this.hasCapability(\"org.matrix.msc2762.timeline:\".concat(_Symbols.Symbols.AnyRoom)) || this.hasCapability(\"org.matrix.msc2762.timeline:\".concat(roomId));\n    }\n  }, {\n    key: \"canSendRoomEvent\",\n    value: function canSendRoomEvent(eventType) {\n      var msgtype = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n      return this.allowedEvents.some(function (e) {\n        return e.matchesAsRoomEvent(_WidgetEventCapability.EventDirection.Send, eventType, msgtype);\n      });\n    }\n  }, {\n    key: \"canSendStateEvent\",\n    value: function canSendStateEvent(eventType, stateKey) {\n      return this.allowedEvents.some(function (e) {\n        return e.matchesAsStateEvent(_WidgetEventCapability.EventDirection.Send, eventType, stateKey);\n      });\n    }\n  }, {\n    key: \"canSendToDeviceEvent\",\n    value: function canSendToDeviceEvent(eventType) {\n      return this.allowedEvents.some(function (e) {\n        return e.matchesAsToDeviceEvent(_WidgetEventCapability.EventDirection.Send, eventType);\n      });\n    }\n  }, {\n    key: \"canReceiveRoomEvent\",\n    value: function canReceiveRoomEvent(eventType) {\n      var msgtype = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n      return this.allowedEvents.some(function (e) {\n        return e.matchesAsRoomEvent(_WidgetEventCapability.EventDirection.Receive, eventType, msgtype);\n      });\n    }\n  }, {\n    key: \"canReceiveStateEvent\",\n    value: function canReceiveStateEvent(eventType, stateKey) {\n      return this.allowedEvents.some(function (e) {\n        return e.matchesAsStateEvent(_WidgetEventCapability.EventDirection.Receive, eventType, stateKey);\n      });\n    }\n  }, {\n    key: \"canReceiveToDeviceEvent\",\n    value: function canReceiveToDeviceEvent(eventType) {\n      return this.allowedEvents.some(function (e) {\n        return e.matchesAsToDeviceEvent(_WidgetEventCapability.EventDirection.Receive, eventType);\n      });\n    }\n  }, {\n    key: \"stop\",\n    value: function stop() {\n      this.isStopped = true;\n      this.transport.stop();\n    }\n  }, {\n    key: \"beginCapabilities\",\n    value: function beginCapabilities() {\n      var _this2 = this;\n\n      // widget has loaded - tell all the listeners that\n      this.emit(\"preparing\");\n      var requestedCaps;\n      this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.Capabilities, {}).then(function (caps) {\n        requestedCaps = caps.capabilities;\n        return _this2.driver.validateCapabilities(new Set(caps.capabilities));\n      }).then(function (allowedCaps) {\n        console.log(\"Widget \".concat(_this2.widget.id, \" is allowed capabilities:\"), Array.from(allowedCaps));\n        _this2.allowedCapabilities = allowedCaps;\n        _this2.allowedEvents = _WidgetEventCapability.WidgetEventCapability.findEventCapabilities(allowedCaps);\n\n        _this2.notifyCapabilities(requestedCaps);\n\n        _this2.emit(\"ready\");\n      });\n    }\n  }, {\n    key: \"notifyCapabilities\",\n    value: function notifyCapabilities(requested) {\n      var _this3 = this;\n\n      this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.NotifyCapabilities, {\n        requested: requested,\n        approved: Array.from(this.allowedCapabilities)\n      })[\"catch\"](function (e) {\n        console.warn(\"non-fatal error notifying widget of approved capabilities:\", e);\n      }).then(function () {\n        _this3.emit(\"capabilitiesNotified\");\n      });\n    }\n  }, {\n    key: \"onIframeLoad\",\n    value: function onIframeLoad(ev) {\n      if (this.widget.waitForIframeLoad) {\n        // If the widget is set to waitForIframeLoad the capabilities immediatly get setup after load.\n        // The client does not wait for the ContentLoaded action.\n        this.beginCapabilities();\n      } else {\n        // Reaching this means, that the Iframe got reloaded/loaded and\n        // the clientApi is awaiting the FIRST ContentLoaded action.\n        this.contentLoadedActionSent = false;\n      }\n    }\n  }, {\n    key: \"handleContentLoadedAction\",\n    value: function handleContentLoadedAction(action) {\n      if (this.contentLoadedActionSent) {\n        throw new Error(\"Improper sequence: ContentLoaded Action can only be send once after the widget loaded \" + \"and should only be used if waitForIframeLoad is false (default=true)\");\n      }\n\n      if (this.widget.waitForIframeLoad) {\n        this.transport.reply(action, {\n          error: {\n            message: \"Improper sequence: not expecting ContentLoaded event if \" + \"waitForIframLoad is true (default=true)\"\n          }\n        });\n      } else {\n        this.transport.reply(action, {});\n        this.beginCapabilities();\n      }\n\n      this.contentLoadedActionSent = true;\n    }\n  }, {\n    key: \"replyVersions\",\n    value: function replyVersions(request) {\n      this.transport.reply(request, {\n        supported_versions: _ApiVersion.CurrentApiVersions\n      });\n    }\n  }, {\n    key: \"handleCapabilitiesRenegotiate\",\n    value: function handleCapabilitiesRenegotiate(request) {\n      var _request$data,\n          _this4 = this;\n\n      // acknowledge first\n      this.transport.reply(request, {});\n      var requested = ((_request$data = request.data) === null || _request$data === void 0 ? void 0 : _request$data.capabilities) || [];\n      var newlyRequested = new Set(requested.filter(function (r) {\n        return !_this4.hasCapability(r);\n      }));\n\n      if (newlyRequested.size === 0) {\n        // Nothing to do - notify capabilities\n        return this.notifyCapabilities([]);\n      }\n\n      this.driver.validateCapabilities(newlyRequested).then(function (allowed) {\n        allowed.forEach(function (c) {\n          return _this4.allowedCapabilities.add(c);\n        });\n\n        var allowedEvents = _WidgetEventCapability.WidgetEventCapability.findEventCapabilities(allowed);\n\n        allowedEvents.forEach(function (c) {\n          return _this4.allowedEvents.push(c);\n        });\n        return _this4.notifyCapabilities(Array.from(newlyRequested));\n      });\n    }\n  }, {\n    key: \"handleNavigate\",\n    value: function handleNavigate(request) {\n      var _request$data2,\n          _request$data3,\n          _this5 = this;\n\n      if (!this.hasCapability(_Capabilities.MatrixCapabilities.MSC2931Navigate)) {\n        return this.transport.reply(request, {\n          error: {\n            message: \"Missing capability\"\n          }\n        });\n      }\n\n      if (!((_request$data2 = request.data) !== null && _request$data2 !== void 0 && _request$data2.uri) || !((_request$data3 = request.data) !== null && _request$data3 !== void 0 && _request$data3.uri.toString().startsWith(\"https://matrix.to/#\"))) {\n        return this.transport.reply(request, {\n          error: {\n            message: \"Invalid matrix.to URI\"\n          }\n        });\n      }\n\n      var onErr = function onErr(e) {\n        console.error(\"[ClientWidgetApi] Failed to handle navigation: \", e);\n        return _this5.transport.reply(request, {\n          error: {\n            message: \"Error handling navigation\"\n          }\n        });\n      };\n\n      try {\n        this.driver.navigate(request.data.uri.toString())[\"catch\"](function (e) {\n          return onErr(e);\n        }).then(function () {\n          return _this5.transport.reply(request, {});\n        });\n      } catch (e) {\n        return onErr(e);\n      }\n    }\n  }, {\n    key: \"handleOIDC\",\n    value: function handleOIDC(request) {\n      var _this6 = this;\n\n      var phase = 1; // 1 = initial request, 2 = after user manual confirmation\n\n      var replyState = function replyState(state, credential) {\n        credential = credential || {};\n\n        if (phase > 1) {\n          return _this6.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.OpenIDCredentials, _objectSpread({\n            state: state,\n            original_request_id: request.requestId\n          }, credential));\n        } else {\n          return _this6.transport.reply(request, _objectSpread({\n            state: state\n          }, credential));\n        }\n      };\n\n      var replyError = function replyError(msg) {\n        console.error(\"[ClientWidgetApi] Failed to handle OIDC: \", msg);\n\n        if (phase > 1) {\n          // We don't have a way to indicate that a random error happened in this flow, so\n          // just block the attempt.\n          return replyState(_GetOpenIDAction.OpenIDRequestState.Blocked);\n        } else {\n          return _this6.transport.reply(request, {\n            error: {\n              message: msg\n            }\n          });\n        }\n      };\n\n      var observer = new _SimpleObservable.SimpleObservable(function (update) {\n        if (update.state === _GetOpenIDAction.OpenIDRequestState.PendingUserConfirmation && phase > 1) {\n          observer.close();\n          return replyError(\"client provided out-of-phase response to OIDC flow\");\n        }\n\n        if (update.state === _GetOpenIDAction.OpenIDRequestState.PendingUserConfirmation) {\n          replyState(update.state);\n          phase++;\n          return;\n        }\n\n        if (update.state === _GetOpenIDAction.OpenIDRequestState.Allowed && !update.token) {\n          return replyError(\"client provided invalid OIDC token for an allowed request\");\n        }\n\n        if (update.state === _GetOpenIDAction.OpenIDRequestState.Blocked) {\n          update.token = undefined; // just in case the client did something weird\n        }\n\n        observer.close();\n        return replyState(update.state, update.token);\n      });\n      this.driver.askOpenID(observer);\n    }\n  }, {\n    key: \"handleReadEvents\",\n    value: function handleReadEvents(request) {\n      var _this7 = this;\n\n      if (!request.data.type) {\n        return this.transport.reply(request, {\n          error: {\n            message: \"Invalid request - missing event type\"\n          }\n        });\n      }\n\n      if (request.data.limit !== undefined && (!request.data.limit || request.data.limit < 0)) {\n        return this.transport.reply(request, {\n          error: {\n            message: \"Invalid request - limit out of range\"\n          }\n        });\n      }\n\n      var askRoomIds = null; // null denotes current room only\n\n      if (request.data.room_ids) {\n        askRoomIds = request.data.room_ids;\n\n        if (!Array.isArray(askRoomIds)) {\n          askRoomIds = [askRoomIds];\n        }\n\n        var _iterator2 = _createForOfIteratorHelper(askRoomIds),\n            _step2;\n\n        try {\n          for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n            var roomId = _step2.value;\n\n            if (!this.canUseRoomTimeline(roomId)) {\n              return this.transport.reply(request, {\n                error: {\n                  message: \"Unable to access room timeline: \".concat(roomId)\n                }\n              });\n            }\n          }\n        } catch (err) {\n          _iterator2.e(err);\n        } finally {\n          _iterator2.f();\n        }\n      }\n\n      var limit = request.data.limit || 0;\n      var events = Promise.resolve([]);\n\n      if (request.data.state_key !== undefined) {\n        var stateKey = request.data.state_key === true ? undefined : request.data.state_key.toString();\n\n        if (!this.canReceiveStateEvent(request.data.type, stateKey !== null && stateKey !== void 0 ? stateKey : null)) {\n          return this.transport.reply(request, {\n            error: {\n              message: \"Cannot read state events of this type\"\n            }\n          });\n        }\n\n        events = this.driver.readStateEvents(request.data.type, stateKey, limit, askRoomIds);\n      } else {\n        if (!this.canReceiveRoomEvent(request.data.type, request.data.msgtype)) {\n          return this.transport.reply(request, {\n            error: {\n              message: \"Cannot read room events of this type\"\n            }\n          });\n        }\n\n        events = this.driver.readRoomEvents(request.data.type, request.data.msgtype, limit, askRoomIds);\n      }\n\n      return events.then(function (evs) {\n        return _this7.transport.reply(request, {\n          events: evs\n        });\n      });\n    }\n  }, {\n    key: \"handleSendEvent\",\n    value: function handleSendEvent(request) {\n      var _this8 = this;\n\n      if (!request.data.type) {\n        return this.transport.reply(request, {\n          error: {\n            message: \"Invalid request - missing event type\"\n          }\n        });\n      }\n\n      if (!!request.data.room_id && !this.canUseRoomTimeline(request.data.room_id)) {\n        return this.transport.reply(request, {\n          error: {\n            message: \"Unable to access room timeline: \".concat(request.data.room_id)\n          }\n        });\n      }\n\n      var isState = request.data.state_key !== null && request.data.state_key !== undefined;\n      var sendEventPromise;\n\n      if (isState) {\n        if (!this.canSendStateEvent(request.data.type, request.data.state_key)) {\n          return this.transport.reply(request, {\n            error: {\n              message: \"Cannot send state events of this type\"\n            }\n          });\n        }\n\n        sendEventPromise = this.driver.sendEvent(request.data.type, request.data.content || {}, request.data.state_key, request.data.room_id);\n      } else {\n        var content = request.data.content || {};\n        var msgtype = content['msgtype'];\n\n        if (!this.canSendRoomEvent(request.data.type, msgtype)) {\n          return this.transport.reply(request, {\n            error: {\n              message: \"Cannot send room events of this type\"\n            }\n          });\n        }\n\n        sendEventPromise = this.driver.sendEvent(request.data.type, content, null, // not sending a state event\n        request.data.room_id);\n      }\n\n      sendEventPromise.then(function (sentEvent) {\n        return _this8.transport.reply(request, {\n          room_id: sentEvent.roomId,\n          event_id: sentEvent.eventId\n        });\n      })[\"catch\"](function (e) {\n        console.error(\"error sending event: \", e);\n        return _this8.transport.reply(request, {\n          error: {\n            message: \"Error sending event\"\n          }\n        });\n      });\n    }\n  }, {\n    key: \"handleSendToDevice\",\n    value: function () {\n      var _handleSendToDevice = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(request) {\n        return _regeneratorRuntime().wrap(function _callee$(_context) {\n          while (1) {\n            switch (_context.prev = _context.next) {\n              case 0:\n                if (request.data.type) {\n                  _context.next = 5;\n                  break;\n                }\n\n                _context.next = 3;\n                return this.transport.reply(request, {\n                  error: {\n                    message: \"Invalid request - missing event type\"\n                  }\n                });\n\n              case 3:\n                _context.next = 32;\n                break;\n\n              case 5:\n                if (request.data.messages) {\n                  _context.next = 10;\n                  break;\n                }\n\n                _context.next = 8;\n                return this.transport.reply(request, {\n                  error: {\n                    message: \"Invalid request - missing event contents\"\n                  }\n                });\n\n              case 8:\n                _context.next = 32;\n                break;\n\n              case 10:\n                if (!(typeof request.data.encrypted !== \"boolean\")) {\n                  _context.next = 15;\n                  break;\n                }\n\n                _context.next = 13;\n                return this.transport.reply(request, {\n                  error: {\n                    message: \"Invalid request - missing encryption flag\"\n                  }\n                });\n\n              case 13:\n                _context.next = 32;\n                break;\n\n              case 15:\n                if (this.canSendToDeviceEvent(request.data.type)) {\n                  _context.next = 20;\n                  break;\n                }\n\n                _context.next = 18;\n                return this.transport.reply(request, {\n                  error: {\n                    message: \"Cannot send to-device events of this type\"\n                  }\n                });\n\n              case 18:\n                _context.next = 32;\n                break;\n\n              case 20:\n                _context.prev = 20;\n                _context.next = 23;\n                return this.driver.sendToDevice(request.data.type, request.data.encrypted, request.data.messages);\n\n              case 23:\n                _context.next = 25;\n                return this.transport.reply(request, {});\n\n              case 25:\n                _context.next = 32;\n                break;\n\n              case 27:\n                _context.prev = 27;\n                _context.t0 = _context[\"catch\"](20);\n                console.error(\"error sending to-device event\", _context.t0);\n                _context.next = 32;\n                return this.transport.reply(request, {\n                  error: {\n                    message: \"Error sending event\"\n                  }\n                });\n\n              case 32:\n              case \"end\":\n                return _context.stop();\n            }\n          }\n        }, _callee, this, [[20, 27]]);\n      }));\n\n      function handleSendToDevice(_x) {\n        return _handleSendToDevice.apply(this, arguments);\n      }\n\n      return handleSendToDevice;\n    }()\n  }, {\n    key: \"pollTurnServers\",\n    value: function () {\n      var _pollTurnServers = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(turnServers, initialServer) {\n        var _iteratorAbruptCompletion, _didIteratorError, _iteratorError, _iterator, _step, server;\n\n        return _regeneratorRuntime().wrap(function _callee2$(_context2) {\n          while (1) {\n            switch (_context2.prev = _context2.next) {\n              case 0:\n                _context2.prev = 0;\n                _context2.next = 3;\n                return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers, initialServer // it's compatible, but missing the index signature\n                );\n\n              case 3:\n                // Pick the generator up where we left off\n                _iteratorAbruptCompletion = false;\n                _didIteratorError = false;\n                _context2.prev = 5;\n                _iterator = _asyncIterator(turnServers);\n\n              case 7:\n                _context2.next = 9;\n                return _iterator.next();\n\n              case 9:\n                if (!(_iteratorAbruptCompletion = !(_step = _context2.sent).done)) {\n                  _context2.next = 16;\n                  break;\n                }\n\n                server = _step.value;\n                _context2.next = 13;\n                return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers, server // it's compatible, but missing the index signature\n                );\n\n              case 13:\n                _iteratorAbruptCompletion = false;\n                _context2.next = 7;\n                break;\n\n              case 16:\n                _context2.next = 22;\n                break;\n\n              case 18:\n                _context2.prev = 18;\n                _context2.t0 = _context2[\"catch\"](5);\n                _didIteratorError = true;\n                _iteratorError = _context2.t0;\n\n              case 22:\n                _context2.prev = 22;\n                _context2.prev = 23;\n\n                if (!(_iteratorAbruptCompletion && _iterator[\"return\"] != null)) {\n                  _context2.next = 27;\n                  break;\n                }\n\n                _context2.next = 27;\n                return _iterator[\"return\"]();\n\n              case 27:\n                _context2.prev = 27;\n\n                if (!_didIteratorError) {\n                  _context2.next = 30;\n                  break;\n                }\n\n                throw _iteratorError;\n\n              case 30:\n                return _context2.finish(27);\n\n              case 31:\n                return _context2.finish(22);\n\n              case 32:\n                _context2.next = 37;\n                break;\n\n              case 34:\n                _context2.prev = 34;\n                _context2.t1 = _context2[\"catch\"](0);\n                console.error(\"error polling for TURN servers\", _context2.t1);\n\n              case 37:\n              case \"end\":\n                return _context2.stop();\n            }\n          }\n        }, _callee2, this, [[0, 34], [5, 18, 22, 32], [23,, 27, 31]]);\n      }));\n\n      function pollTurnServers(_x2, _x3) {\n        return _pollTurnServers.apply(this, arguments);\n      }\n\n      return pollTurnServers;\n    }()\n  }, {\n    key: \"handleWatchTurnServers\",\n    value: function () {\n      var _handleWatchTurnServers = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3(request) {\n        var turnServers, _yield$turnServers$ne, done, value;\n\n        return _regeneratorRuntime().wrap(function _callee3$(_context3) {\n          while (1) {\n            switch (_context3.prev = _context3.next) {\n              case 0:\n                if (this.hasCapability(_Capabilities.MatrixCapabilities.MSC3846TurnServers)) {\n                  _context3.next = 5;\n                  break;\n                }\n\n                _context3.next = 3;\n                return this.transport.reply(request, {\n                  error: {\n                    message: \"Missing capability\"\n                  }\n                });\n\n              case 3:\n                _context3.next = 30;\n                break;\n\n              case 5:\n                if (!this.turnServers) {\n                  _context3.next = 10;\n                  break;\n                }\n\n                _context3.next = 8;\n                return this.transport.reply(request, {});\n\n              case 8:\n                _context3.next = 30;\n                break;\n\n              case 10:\n                _context3.prev = 10;\n                turnServers = this.driver.getTurnServers(); // Peek at the first result, so we can at least verify that the\n                // client isn't banned from getting TURN servers entirely\n\n                _context3.next = 14;\n                return turnServers.next();\n\n              case 14:\n                _yield$turnServers$ne = _context3.sent;\n                done = _yield$turnServers$ne.done;\n                value = _yield$turnServers$ne.value;\n\n                if (!done) {\n                  _context3.next = 19;\n                  break;\n                }\n\n                throw new Error(\"Client refuses to provide any TURN servers\");\n\n              case 19:\n                _context3.next = 21;\n                return this.transport.reply(request, {});\n\n              case 21:\n                // Start the poll loop, sending the widget the initial result\n                this.pollTurnServers(turnServers, value);\n                this.turnServers = turnServers;\n                _context3.next = 30;\n                break;\n\n              case 25:\n                _context3.prev = 25;\n                _context3.t0 = _context3[\"catch\"](10);\n                console.error(\"error getting first TURN server results\", _context3.t0);\n                _context3.next = 30;\n                return this.transport.reply(request, {\n                  error: {\n                    message: \"TURN servers not available\"\n                  }\n                });\n\n              case 30:\n              case \"end\":\n                return _context3.stop();\n            }\n          }\n        }, _callee3, this, [[10, 25]]);\n      }));\n\n      function handleWatchTurnServers(_x4) {\n        return _handleWatchTurnServers.apply(this, arguments);\n      }\n\n      return handleWatchTurnServers;\n    }()\n  }, {\n    key: \"handleUnwatchTurnServers\",\n    value: function () {\n      var _handleUnwatchTurnServers = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee4(request) {\n        return _regeneratorRuntime().wrap(function _callee4$(_context4) {\n          while (1) {\n            switch (_context4.prev = _context4.next) {\n              case 0:\n                if (this.hasCapability(_Capabilities.MatrixCapabilities.MSC3846TurnServers)) {\n                  _context4.next = 5;\n                  break;\n                }\n\n                _context4.next = 3;\n                return this.transport.reply(request, {\n                  error: {\n                    message: \"Missing capability\"\n                  }\n                });\n\n              case 3:\n                _context4.next = 15;\n                break;\n\n              case 5:\n                if (this.turnServers) {\n                  _context4.next = 10;\n                  break;\n                }\n\n                _context4.next = 8;\n                return this.transport.reply(request, {});\n\n              case 8:\n                _context4.next = 15;\n                break;\n\n              case 10:\n                _context4.next = 12;\n                return this.turnServers[\"return\"](undefined);\n\n              case 12:\n                this.turnServers = null;\n                _context4.next = 15;\n                return this.transport.reply(request, {});\n\n              case 15:\n              case \"end\":\n                return _context4.stop();\n            }\n          }\n        }, _callee4, this);\n      }));\n\n      function handleUnwatchTurnServers(_x5) {\n        return _handleUnwatchTurnServers.apply(this, arguments);\n      }\n\n      return handleUnwatchTurnServers;\n    }()\n  }, {\n    key: \"handleReadRelations\",\n    value: function () {\n      var _handleReadRelations = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee5(request) {\n        var _this9 = this;\n\n        var result, chunk;\n        return _regeneratorRuntime().wrap(function _callee5$(_context5) {\n          while (1) {\n            switch (_context5.prev = _context5.next) {\n              case 0:\n                if (request.data.event_id) {\n                  _context5.next = 2;\n                  break;\n                }\n\n                return _context5.abrupt(\"return\", this.transport.reply(request, {\n                  error: {\n                    message: \"Invalid request - missing event ID\"\n                  }\n                }));\n\n              case 2:\n                if (!(request.data.limit !== undefined && request.data.limit < 0)) {\n                  _context5.next = 4;\n                  break;\n                }\n\n                return _context5.abrupt(\"return\", this.transport.reply(request, {\n                  error: {\n                    message: \"Invalid request - limit out of range\"\n                  }\n                }));\n\n              case 4:\n                if (!(request.data.room_id !== undefined && !this.canUseRoomTimeline(request.data.room_id))) {\n                  _context5.next = 6;\n                  break;\n                }\n\n                return _context5.abrupt(\"return\", this.transport.reply(request, {\n                  error: {\n                    message: \"Unable to access room timeline: \".concat(request.data.room_id)\n                  }\n                }));\n\n              case 6:\n                _context5.prev = 6;\n                _context5.next = 9;\n                return this.driver.readEventRelations(request.data.event_id, request.data.room_id, request.data.rel_type, request.data.event_type, request.data.from, request.data.to, request.data.limit, request.data.direction);\n\n              case 9:\n                result = _context5.sent;\n                // only return events that the user has the permission to receive\n                chunk = result.chunk.filter(function (e) {\n                  if (e.state_key !== undefined) {\n                    return _this9.canReceiveStateEvent(e.type, e.state_key);\n                  } else {\n                    return _this9.canReceiveRoomEvent(e.type, e.content['msgtype']);\n                  }\n                });\n                return _context5.abrupt(\"return\", this.transport.reply(request, {\n                  chunk: chunk,\n                  prev_batch: result.prevBatch,\n                  next_batch: result.nextBatch\n                }));\n\n              case 14:\n                _context5.prev = 14;\n                _context5.t0 = _context5[\"catch\"](6);\n                console.error(\"error getting the relations\", _context5.t0);\n                _context5.next = 19;\n                return this.transport.reply(request, {\n                  error: {\n                    message: \"Unexpected error while reading relations\"\n                  }\n                });\n\n              case 19:\n              case \"end\":\n                return _context5.stop();\n            }\n          }\n        }, _callee5, this, [[6, 14]]);\n      }));\n\n      function handleReadRelations(_x6) {\n        return _handleReadRelations.apply(this, arguments);\n      }\n\n      return handleReadRelations;\n    }()\n  }, {\n    key: \"handleUserDirectorySearch\",\n    value: function () {\n      var _handleUserDirectorySearch = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee6(request) {\n        var result;\n        return _regeneratorRuntime().wrap(function _callee6$(_context6) {\n          while (1) {\n            switch (_context6.prev = _context6.next) {\n              case 0:\n                if (this.hasCapability(_Capabilities.MatrixCapabilities.MSC3973UserDirectorySearch)) {\n                  _context6.next = 2;\n                  break;\n                }\n\n                return _context6.abrupt(\"return\", this.transport.reply(request, {\n                  error: {\n                    message: \"Missing capability\"\n                  }\n                }));\n\n              case 2:\n                if (!(typeof request.data.search_term !== 'string')) {\n                  _context6.next = 4;\n                  break;\n                }\n\n                return _context6.abrupt(\"return\", this.transport.reply(request, {\n                  error: {\n                    message: \"Invalid request - missing search term\"\n                  }\n                }));\n\n              case 4:\n                if (!(request.data.limit !== undefined && request.data.limit < 0)) {\n                  _context6.next = 6;\n                  break;\n                }\n\n                return _context6.abrupt(\"return\", this.transport.reply(request, {\n                  error: {\n                    message: \"Invalid request - limit out of range\"\n                  }\n                }));\n\n              case 6:\n                _context6.prev = 6;\n                _context6.next = 9;\n                return this.driver.searchUserDirectory(request.data.search_term, request.data.limit);\n\n              case 9:\n                result = _context6.sent;\n                return _context6.abrupt(\"return\", this.transport.reply(request, {\n                  limited: result.limited,\n                  results: result.results.map(function (r) {\n                    return {\n                      user_id: r.userId,\n                      display_name: r.displayName,\n                      avatar_url: r.avatarUrl\n                    };\n                  })\n                }));\n\n              case 13:\n                _context6.prev = 13;\n                _context6.t0 = _context6[\"catch\"](6);\n                console.error(\"error searching in the user directory\", _context6.t0);\n                _context6.next = 18;\n                return this.transport.reply(request, {\n                  error: {\n                    message: \"Unexpected error while searching in the user directory\"\n                  }\n                });\n\n              case 18:\n              case \"end\":\n                return _context6.stop();\n            }\n          }\n        }, _callee6, this, [[6, 13]]);\n      }));\n\n      function handleUserDirectorySearch(_x7) {\n        return _handleUserDirectorySearch.apply(this, arguments);\n      }\n\n      return handleUserDirectorySearch;\n    }()\n  }, {\n    key: \"handleMessage\",\n    value: function handleMessage(ev) {\n      if (this.isStopped) return;\n      var actionEv = new CustomEvent(\"action:\".concat(ev.detail.action), {\n        detail: ev.detail,\n        cancelable: true\n      });\n      this.emit(\"action:\".concat(ev.detail.action), actionEv);\n\n      if (!actionEv.defaultPrevented) {\n        switch (ev.detail.action) {\n          case _WidgetApiAction.WidgetApiFromWidgetAction.ContentLoaded:\n            return this.handleContentLoadedAction(ev.detail);\n\n          case _WidgetApiAction.WidgetApiFromWidgetAction.SupportedApiVersions:\n            return this.replyVersions(ev.detail);\n\n          case _WidgetApiAction.WidgetApiFromWidgetAction.SendEvent:\n            return this.handleSendEvent(ev.detail);\n\n          case _WidgetApiAction.WidgetApiFromWidgetAction.SendToDevice:\n            return this.handleSendToDevice(ev.detail);\n\n          case _WidgetApiAction.WidgetApiFromWidgetAction.GetOpenIDCredentials:\n            return this.handleOIDC(ev.detail);\n\n          case _WidgetApiAction.WidgetApiFromWidgetAction.MSC2931Navigate:\n            return this.handleNavigate(ev.detail);\n\n          case _WidgetApiAction.WidgetApiFromWidgetAction.MSC2974RenegotiateCapabilities:\n            return this.handleCapabilitiesRenegotiate(ev.detail);\n\n          case _WidgetApiAction.WidgetApiFromWidgetAction.MSC2876ReadEvents:\n            return this.handleReadEvents(ev.detail);\n\n          case _WidgetApiAction.WidgetApiFromWidgetAction.WatchTurnServers:\n            return this.handleWatchTurnServers(ev.detail);\n\n          case _WidgetApiAction.WidgetApiFromWidgetAction.UnwatchTurnServers:\n            return this.handleUnwatchTurnServers(ev.detail);\n\n          case _WidgetApiAction.WidgetApiFromWidgetAction.MSC3869ReadRelations:\n            return this.handleReadRelations(ev.detail);\n\n          case _WidgetApiAction.WidgetApiFromWidgetAction.MSC3973UserDirectorySearch:\n            return this.handleUserDirectorySearch(ev.detail);\n\n          default:\n            return this.transport.reply(ev.detail, {\n              error: {\n                message: \"Unknown or unsupported action: \" + ev.detail.action\n              }\n            });\n        }\n      }\n    }\n    /**\n     * Takes a screenshot of the widget.\n     * @returns Resolves to the widget's screenshot.\n     * @throws Throws if there is a problem.\n     */\n\n  }, {\n    key: \"takeScreenshot\",\n    value: function takeScreenshot() {\n      return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.TakeScreenshot, {});\n    }\n    /**\n     * Alerts the widget to whether or not it is currently visible.\n     * @param {boolean} isVisible Whether the widget is visible or not.\n     * @returns {Promise<IWidgetApiResponseData>} Resolves when the widget acknowledges the update.\n     */\n\n  }, {\n    key: \"updateVisibility\",\n    value: function updateVisibility(isVisible) {\n      return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.UpdateVisibility, {\n        visible: isVisible\n      });\n    }\n  }, {\n    key: \"sendWidgetConfig\",\n    value: function sendWidgetConfig(data) {\n      return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.WidgetConfig, data).then();\n    }\n  }, {\n    key: \"notifyModalWidgetButtonClicked\",\n    value: function notifyModalWidgetButtonClicked(id) {\n      return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.ButtonClicked, {\n        id: id\n      }).then();\n    }\n  }, {\n    key: \"notifyModalWidgetClose\",\n    value: function notifyModalWidgetClose(data) {\n      return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.CloseModalWidget, data).then();\n    }\n    /**\n     * Feeds an event to the widget. If the widget is not able to accept the event due to\n     * permissions, this will no-op and return calmly. If the widget failed to handle the\n     * event, this will raise an error.\n     * @param {IRoomEvent} rawEvent The event to (try to) send to the widget.\n     * @param {string} currentViewedRoomId The room ID the user is currently interacting with.\n     * Not the room ID of the event.\n     * @returns {Promise<void>} Resolves when complete, rejects if there was an error sending.\n     */\n\n  }, {\n    key: \"feedEvent\",\n    value: function () {\n      var _feedEvent = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee7(rawEvent, currentViewedRoomId) {\n        var _rawEvent$content;\n\n        return _regeneratorRuntime().wrap(function _callee7$(_context7) {\n          while (1) {\n            switch (_context7.prev = _context7.next) {\n              case 0:\n                if (!(rawEvent.room_id !== currentViewedRoomId && !this.canUseRoomTimeline(rawEvent.room_id))) {\n                  _context7.next = 2;\n                  break;\n                }\n\n                return _context7.abrupt(\"return\");\n\n              case 2:\n                if (!(rawEvent.state_key !== undefined && rawEvent.state_key !== null)) {\n                  _context7.next = 7;\n                  break;\n                }\n\n                if (this.canReceiveStateEvent(rawEvent.type, rawEvent.state_key)) {\n                  _context7.next = 5;\n                  break;\n                }\n\n                return _context7.abrupt(\"return\");\n\n              case 5:\n                _context7.next = 9;\n                break;\n\n              case 7:\n                if (this.canReceiveRoomEvent(rawEvent.type, (_rawEvent$content = rawEvent.content) === null || _rawEvent$content === void 0 ? void 0 : _rawEvent$content[\"msgtype\"])) {\n                  _context7.next = 9;\n                  break;\n                }\n\n                return _context7.abrupt(\"return\");\n\n              case 9:\n                _context7.next = 11;\n                return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.SendEvent, rawEvent // it's compatible, but missing the index signature\n                );\n\n              case 11:\n              case \"end\":\n                return _context7.stop();\n            }\n          }\n        }, _callee7, this);\n      }));\n\n      function feedEvent(_x8, _x9) {\n        return _feedEvent.apply(this, arguments);\n      }\n\n      return feedEvent;\n    }()\n    /**\n     * Feeds a to-device event to the widget. If the widget is not able to accept the\n     * event due to permissions, this will no-op and return calmly. If the widget failed\n     * to handle the event, this will raise an error.\n     * @param {IRoomEvent} rawEvent The event to (try to) send to the widget.\n     * @param {boolean} encrypted Whether the event contents were encrypted.\n     * @returns {Promise<void>} Resolves when complete, rejects if there was an error sending.\n     */\n\n  }, {\n    key: \"feedToDevice\",\n    value: function () {\n      var _feedToDevice = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee8(rawEvent, encrypted) {\n        return _regeneratorRuntime().wrap(function _callee8$(_context8) {\n          while (1) {\n            switch (_context8.prev = _context8.next) {\n              case 0:\n                if (!this.canReceiveToDeviceEvent(rawEvent.type)) {\n                  _context8.next = 3;\n                  break;\n                }\n\n                _context8.next = 3;\n                return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.SendToDevice, // it's compatible, but missing the index signature\n                _objectSpread(_objectSpread({}, rawEvent), {}, {\n                  encrypted: encrypted\n                }));\n\n              case 3:\n              case \"end\":\n                return _context8.stop();\n            }\n          }\n        }, _callee8, this);\n      }));\n\n      function feedToDevice(_x10, _x11) {\n        return _feedToDevice.apply(this, arguments);\n      }\n\n      return feedToDevice;\n    }()\n  }]);\n\n  return ClientWidgetApi;\n}(_events.EventEmitter);\n\nexports.ClientWidgetApi = ClientWidgetApi;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.Symbols = void 0;\n\n/*\n * Copyright 2021 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar Symbols;\nexports.Symbols = Symbols;\n\n(function (Symbols) {\n  Symbols[\"AnyRoom\"] = \"*\";\n})(Symbols || (exports.Symbols = Symbols = {}));","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.WidgetApi = void 0;\n\nvar _events = require(\"events\");\n\nvar _WidgetApiDirection = require(\"./interfaces/WidgetApiDirection\");\n\nvar _ApiVersion = require(\"./interfaces/ApiVersion\");\n\nvar _PostmessageTransport = require(\"./transport/PostmessageTransport\");\n\nvar _WidgetApiAction = require(\"./interfaces/WidgetApiAction\");\n\nvar _GetOpenIDAction = require(\"./interfaces/GetOpenIDAction\");\n\nvar _WidgetType = require(\"./interfaces/WidgetType\");\n\nvar _ModalWidgetActions = require(\"./interfaces/ModalWidgetActions\");\n\nvar _WidgetEventCapability = require(\"./models/WidgetEventCapability\");\n\nvar _Symbols = require(\"./Symbols\");\n\nfunction _regeneratorRuntime() { \"use strict\"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, $Symbol = \"function\" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || \"@@iterator\", asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\", toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, \"\"); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return generator._invoke = function (innerFn, self, context) { var state = \"suspendedStart\"; return function (method, arg) { if (\"executing\" === state) throw new Error(\"Generator is already running\"); if (\"completed\" === state) { if (\"throw\" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if (\"next\" === context.method) context.sent = context._sent = context.arg;else if (\"throw\" === context.method) { if (\"suspendedStart\" === state) throw state = \"completed\", context.arg; context.dispatchException(context.arg); } else \"return\" === context.method && context.abrupt(\"return\", context.arg); state = \"executing\"; var record = tryCatch(innerFn, self, context); if (\"normal\" === record.type) { if (state = context.done ? \"completed\" : \"suspendedYield\", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } \"throw\" === record.type && (state = \"completed\", context.method = \"throw\", context.arg = record.arg); } }; }(innerFn, self, context), generator; } function tryCatch(fn, obj, arg) { try { return { type: \"normal\", arg: fn.call(obj, arg) }; } catch (err) { return { type: \"throw\", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { [\"next\", \"throw\", \"return\"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if (\"throw\" !== record.type) { var result = record.arg, value = result.value; return value && \"object\" == _typeof(value) && hasOwn.call(value, \"__await\") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke(\"next\", value, resolve, reject); }, function (err) { invoke(\"throw\", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke(\"throw\", error, resolve, reject); }); } reject(record.arg); } var previousPromise; this._invoke = function (method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); }; } function maybeInvokeDelegate(delegate, context) { var method = delegate.iterator[context.method]; if (undefined === method) { if (context.delegate = null, \"throw\" === context.method) { if (delegate.iterator[\"return\"] && (context.method = \"return\", context.arg = undefined, maybeInvokeDelegate(delegate, context), \"throw\" === context.method)) return ContinueSentinel; context.method = \"throw\", context.arg = new TypeError(\"The iterator does not provide a 'throw' method\"); } return ContinueSentinel; } var record = tryCatch(method, delegate.iterator, context.arg); if (\"throw\" === record.type) return context.method = \"throw\", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, \"return\" !== context.method && (context.method = \"next\", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = \"throw\", context.arg = new TypeError(\"iterator result is not an object\"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = \"normal\", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: \"root\" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if (\"function\" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) { if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; } return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, define(Gp, \"constructor\", GeneratorFunctionPrototype), define(GeneratorFunctionPrototype, \"constructor\", GeneratorFunction), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, \"GeneratorFunction\"), exports.isGeneratorFunction = function (genFun) { var ctor = \"function\" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || \"GeneratorFunction\" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, \"GeneratorFunction\")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, \"Generator\"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, \"toString\", function () { return \"[object Generator]\"; }), exports.keys = function (object) { var keys = []; for (var key in object) { keys.push(key); } return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = \"next\", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) { \"t\" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); } }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if (\"throw\" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = \"throw\", record.arg = exception, context.next = loc, caught && (context.method = \"next\", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if (\"root\" === entry.tryLoc) return handle(\"end\"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, \"catchLoc\"), hasFinally = hasOwn.call(entry, \"finallyLoc\"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error(\"try statement without catch or finally\"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && (\"break\" === type || \"continue\" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = \"next\", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if (\"throw\" === record.type) throw record.arg; return \"break\" === record.type || \"continue\" === record.type ? this.next = record.arg : \"return\" === record.type ? (this.rval = this.arg = record.arg, this.method = \"return\", this.next = \"end\") : \"normal\" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, \"catch\": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if (\"throw\" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error(\"illegal catch attempt\"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, \"next\" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; }\n\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, \"prototype\", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } else if (call !== void 0) { throw new TypeError(\"Derived constructors may only return object or undefined\"); } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _awaitAsyncGenerator(value) { return new _AwaitValue(value); }\n\nfunction _wrapAsyncGenerator(fn) { return function () { return new _AsyncGenerator(fn.apply(this, arguments)); }; }\n\nfunction _AsyncGenerator(gen) { var front, back; function send(key, arg) { return new Promise(function (resolve, reject) { var request = { key: key, arg: arg, resolve: resolve, reject: reject, next: null }; if (back) { back = back.next = request; } else { front = back = request; resume(key, arg); } }); } function resume(key, arg) { try { var result = gen[key](arg); var value = result.value; var wrappedAwait = value instanceof _AwaitValue; Promise.resolve(wrappedAwait ? value.wrapped : value).then(function (arg) { if (wrappedAwait) { resume(key === \"return\" ? \"return\" : \"next\", arg); return; } settle(result.done ? \"return\" : \"normal\", arg); }, function (err) { resume(\"throw\", err); }); } catch (err) { settle(\"throw\", err); } } function settle(type, value) { switch (type) { case \"return\": front.resolve({ value: value, done: true }); break; case \"throw\": front.reject(value); break; default: front.resolve({ value: value, done: false }); break; } front = front.next; if (front) { resume(front.key, front.arg); } else { back = null; } } this._invoke = send; if (typeof gen[\"return\"] !== \"function\") { this[\"return\"] = undefined; } }\n\n_AsyncGenerator.prototype[typeof Symbol === \"function\" && Symbol.asyncIterator || \"@@asyncIterator\"] = function () { return this; };\n\n_AsyncGenerator.prototype.next = function (arg) { return this._invoke(\"next\", arg); };\n\n_AsyncGenerator.prototype[\"throw\"] = function (arg) { return this._invoke(\"throw\", arg); };\n\n_AsyncGenerator.prototype[\"return\"] = function (arg) { return this._invoke(\"return\", arg); };\n\nfunction _AwaitValue(value) { this.wrapped = value; }\n\n/**\n * API handler for widgets. This raises events for each action\n * received as `action:${action}` (eg: \"action:screenshot\").\n * Default handling can be prevented by using preventDefault()\n * on the raised event. The default handling varies for each\n * action: ones which the SDK can handle safely are acknowledged\n * appropriately and ones which are unhandled (custom or require\n * the widget to do something) are rejected with an error.\n *\n * Events which are preventDefault()ed must reply using the\n * transport. The events raised will have a detail of an\n * IWidgetApiRequest interface.\n *\n * When the WidgetApi is ready to start sending requests, it will\n * raise a \"ready\" CustomEvent. After the ready event fires, actions\n * can be sent and the transport will be ready.\n */\nvar WidgetApi = /*#__PURE__*/function (_EventEmitter) {\n  _inherits(WidgetApi, _EventEmitter);\n\n  var _super = _createSuper(WidgetApi);\n\n  /**\n   * Creates a new API handler for the given widget.\n   * @param {string} widgetId The widget ID to listen for. If not supplied then\n   * the API will use the widget ID from the first valid request it receives.\n   * @param {string} clientOrigin The origin of the client, or null if not known.\n   */\n  function WidgetApi() {\n    var _this2;\n\n    var widgetId = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n    var clientOrigin = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n\n    _classCallCheck(this, WidgetApi);\n\n    _this2 = _super.call(this);\n    _this2.clientOrigin = clientOrigin;\n\n    _defineProperty(_assertThisInitialized(_this2), \"transport\", void 0);\n\n    _defineProperty(_assertThisInitialized(_this2), \"capabilitiesFinished\", false);\n\n    _defineProperty(_assertThisInitialized(_this2), \"supportsMSC2974Renegotiate\", false);\n\n    _defineProperty(_assertThisInitialized(_this2), \"requestedCapabilities\", []);\n\n    _defineProperty(_assertThisInitialized(_this2), \"approvedCapabilities\", void 0);\n\n    _defineProperty(_assertThisInitialized(_this2), \"cachedClientVersions\", void 0);\n\n    _defineProperty(_assertThisInitialized(_this2), \"turnServerWatchers\", 0);\n\n    if (!window.parent) {\n      throw new Error(\"No parent window. This widget doesn't appear to be embedded properly.\");\n    }\n\n    _this2.transport = new _PostmessageTransport.PostmessageTransport(_WidgetApiDirection.WidgetApiDirection.FromWidget, widgetId, window.parent, window);\n    _this2.transport.targetOrigin = clientOrigin;\n\n    _this2.transport.on(\"message\", _this2.handleMessage.bind(_assertThisInitialized(_this2)));\n\n    return _this2;\n  }\n  /**\n   * Determines if the widget was granted a particular capability. Note that on\n   * clients where the capabilities are not fed back to the widget this function\n   * will rely on requested capabilities instead.\n   * @param {Capability} capability The capability to check for approval of.\n   * @returns {boolean} True if the widget has approval for the given capability.\n   */\n\n\n  _createClass(WidgetApi, [{\n    key: \"hasCapability\",\n    value: function hasCapability(capability) {\n      if (Array.isArray(this.approvedCapabilities)) {\n        return this.approvedCapabilities.includes(capability);\n      }\n\n      return this.requestedCapabilities.includes(capability);\n    }\n    /**\n     * Request a capability from the client. It is not guaranteed to be allowed,\n     * but will be asked for.\n     * @param {Capability} capability The capability to request.\n     * @throws Throws if the capabilities negotiation has already started and the\n     * widget is unable to request additional capabilities.\n     */\n\n  }, {\n    key: \"requestCapability\",\n    value: function requestCapability(capability) {\n      if (this.capabilitiesFinished && !this.supportsMSC2974Renegotiate) {\n        throw new Error(\"Capabilities have already been negotiated\");\n      }\n\n      this.requestedCapabilities.push(capability);\n    }\n    /**\n     * Request capabilities from the client. They are not guaranteed to be allowed,\n     * but will be asked for if the negotiation has not already happened.\n     * @param {Capability[]} capabilities The capabilities to request.\n     * @throws Throws if the capabilities negotiation has already started.\n     */\n\n  }, {\n    key: \"requestCapabilities\",\n    value: function requestCapabilities(capabilities) {\n      var _this3 = this;\n\n      capabilities.forEach(function (cap) {\n        return _this3.requestCapability(cap);\n      });\n    }\n    /**\n     * Requests the capability to interact with rooms other than the user's currently\n     * viewed room. Applies to event receiving and sending.\n     * @param {string | Symbols.AnyRoom} roomId The room ID, or `Symbols.AnyRoom` to\n     * denote all known rooms.\n     */\n\n  }, {\n    key: \"requestCapabilityForRoomTimeline\",\n    value: function requestCapabilityForRoomTimeline(roomId) {\n      this.requestCapability(\"org.matrix.msc2762.timeline:\".concat(roomId));\n    }\n    /**\n     * Requests the capability to send a given state event with optional explicit\n     * state key. It is not guaranteed to be allowed, but will be asked for if the\n     * negotiation has not already happened.\n     * @param {string} eventType The state event type to ask for.\n     * @param {string} stateKey If specified, the specific state key to request.\n     * Otherwise all state keys will be requested.\n     */\n\n  }, {\n    key: \"requestCapabilityToSendState\",\n    value: function requestCapabilityToSendState(eventType, stateKey) {\n      this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forStateEvent(_WidgetEventCapability.EventDirection.Send, eventType, stateKey).raw);\n    }\n    /**\n     * Requests the capability to receive a given state event with optional explicit\n     * state key. It is not guaranteed to be allowed, but will be asked for if the\n     * negotiation has not already happened.\n     * @param {string} eventType The state event type to ask for.\n     * @param {string} stateKey If specified, the specific state key to request.\n     * Otherwise all state keys will be requested.\n     */\n\n  }, {\n    key: \"requestCapabilityToReceiveState\",\n    value: function requestCapabilityToReceiveState(eventType, stateKey) {\n      this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forStateEvent(_WidgetEventCapability.EventDirection.Receive, eventType, stateKey).raw);\n    }\n    /**\n     * Requests the capability to send a given to-device event. It is not\n     * guaranteed to be allowed, but will be asked for if the negotiation has\n     * not already happened.\n     * @param {string} eventType The room event type to ask for.\n     */\n\n  }, {\n    key: \"requestCapabilityToSendToDevice\",\n    value: function requestCapabilityToSendToDevice(eventType) {\n      this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forToDeviceEvent(_WidgetEventCapability.EventDirection.Send, eventType).raw);\n    }\n    /**\n     * Requests the capability to receive a given to-device event. It is not\n     * guaranteed to be allowed, but will be asked for if the negotiation has\n     * not already happened.\n     * @param {string} eventType The room event type to ask for.\n     */\n\n  }, {\n    key: \"requestCapabilityToReceiveToDevice\",\n    value: function requestCapabilityToReceiveToDevice(eventType) {\n      this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forToDeviceEvent(_WidgetEventCapability.EventDirection.Receive, eventType).raw);\n    }\n    /**\n     * Requests the capability to send a given room event. It is not guaranteed to be\n     * allowed, but will be asked for if the negotiation has not already happened.\n     * @param {string} eventType The room event type to ask for.\n     */\n\n  }, {\n    key: \"requestCapabilityToSendEvent\",\n    value: function requestCapabilityToSendEvent(eventType) {\n      this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forRoomEvent(_WidgetEventCapability.EventDirection.Send, eventType).raw);\n    }\n    /**\n     * Requests the capability to receive a given room event. It is not guaranteed to be\n     * allowed, but will be asked for if the negotiation has not already happened.\n     * @param {string} eventType The room event type to ask for.\n     */\n\n  }, {\n    key: \"requestCapabilityToReceiveEvent\",\n    value: function requestCapabilityToReceiveEvent(eventType) {\n      this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forRoomEvent(_WidgetEventCapability.EventDirection.Receive, eventType).raw);\n    }\n    /**\n     * Requests the capability to send a given message event with optional explicit\n     * `msgtype`. It is not guaranteed to be allowed, but will be asked for if the\n     * negotiation has not already happened.\n     * @param {string} msgtype If specified, the specific msgtype to request.\n     * Otherwise all message types will be requested.\n     */\n\n  }, {\n    key: \"requestCapabilityToSendMessage\",\n    value: function requestCapabilityToSendMessage(msgtype) {\n      this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forRoomMessageEvent(_WidgetEventCapability.EventDirection.Send, msgtype).raw);\n    }\n    /**\n     * Requests the capability to receive a given message event with optional explicit\n     * `msgtype`. It is not guaranteed to be allowed, but will be asked for if the\n     * negotiation has not already happened.\n     * @param {string} msgtype If specified, the specific msgtype to request.\n     * Otherwise all message types will be requested.\n     */\n\n  }, {\n    key: \"requestCapabilityToReceiveMessage\",\n    value: function requestCapabilityToReceiveMessage(msgtype) {\n      this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forRoomMessageEvent(_WidgetEventCapability.EventDirection.Receive, msgtype).raw);\n    }\n    /**\n     * Requests an OpenID Connect token from the client for the currently logged in\n     * user. This token can be validated server-side with the federation API. Note\n     * that the widget is responsible for validating the token and caching any results\n     * it needs.\n     * @returns {Promise<IOpenIDCredentials>} Resolves to a token for verification.\n     * @throws Throws if the user rejected the request or the request failed.\n     */\n\n  }, {\n    key: \"requestOpenIDConnectToken\",\n    value: function requestOpenIDConnectToken() {\n      var _this4 = this;\n\n      return new Promise(function (resolve, reject) {\n        _this4.transport.sendComplete(_WidgetApiAction.WidgetApiFromWidgetAction.GetOpenIDCredentials, {}).then(function (response) {\n          var rdata = response.response;\n\n          if (rdata.state === _GetOpenIDAction.OpenIDRequestState.Allowed) {\n            resolve(rdata);\n          } else if (rdata.state === _GetOpenIDAction.OpenIDRequestState.Blocked) {\n            reject(new Error(\"User declined to verify their identity\"));\n          } else if (rdata.state === _GetOpenIDAction.OpenIDRequestState.PendingUserConfirmation) {\n            var handlerFn = function handlerFn(ev) {\n              ev.preventDefault();\n              var request = ev.detail;\n              if (request.data.original_request_id !== response.requestId) return;\n\n              if (request.data.state === _GetOpenIDAction.OpenIDRequestState.Allowed) {\n                resolve(request.data);\n\n                _this4.transport.reply(request, {}); // ack\n\n              } else if (request.data.state === _GetOpenIDAction.OpenIDRequestState.Blocked) {\n                reject(new Error(\"User declined to verify their identity\"));\n\n                _this4.transport.reply(request, {}); // ack\n\n              } else {\n                reject(new Error(\"Invalid state on reply: \" + rdata.state));\n\n                _this4.transport.reply(request, {\n                  error: {\n                    message: \"Invalid state\"\n                  }\n                });\n              }\n\n              _this4.off(\"action:\".concat(_WidgetApiAction.WidgetApiToWidgetAction.OpenIDCredentials), handlerFn);\n            };\n\n            _this4.on(\"action:\".concat(_WidgetApiAction.WidgetApiToWidgetAction.OpenIDCredentials), handlerFn);\n          } else {\n            reject(new Error(\"Invalid state: \" + rdata.state));\n          }\n        })[\"catch\"](reject);\n      });\n    }\n    /**\n     * Asks the client for additional capabilities. Capabilities can be queued for this\n     * request with the requestCapability() functions.\n     * @returns {Promise<void>} Resolves when complete. Note that the promise resolves when\n     * the capabilities request has gone through, not when the capabilities are approved/denied.\n     * Use the WidgetApiToWidgetAction.NotifyCapabilities action to detect changes.\n     */\n\n  }, {\n    key: \"updateRequestedCapabilities\",\n    value: function updateRequestedCapabilities() {\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC2974RenegotiateCapabilities, {\n        capabilities: this.requestedCapabilities\n      }).then();\n    }\n    /**\n     * Tell the client that the content has been loaded.\n     * @returns {Promise} Resolves when the client acknowledges the request.\n     */\n\n  }, {\n    key: \"sendContentLoaded\",\n    value: function sendContentLoaded() {\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.ContentLoaded, {}).then();\n    }\n    /**\n     * Sends a sticker to the client.\n     * @param {IStickerActionRequestData} sticker The sticker to send.\n     * @returns {Promise} Resolves when the client acknowledges the request.\n     */\n\n  }, {\n    key: \"sendSticker\",\n    value: function sendSticker(sticker) {\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SendSticker, sticker).then();\n    }\n    /**\n     * Asks the client to set the always-on-screen status for this widget.\n     * @param {boolean} value The new state to request.\n     * @returns {Promise<boolean>} Resolve with true if the client was able to fulfill\n     * the request, resolves to false otherwise. Rejects if an error occurred.\n     */\n\n  }, {\n    key: \"setAlwaysOnScreen\",\n    value: function setAlwaysOnScreen(value) {\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.UpdateAlwaysOnScreen, {\n        value: value\n      }).then(function (res) {\n        return res.success;\n      });\n    }\n    /**\n     * Opens a modal widget.\n     * @param {string} url The URL to the modal widget.\n     * @param {string} name The name of the widget.\n     * @param {IModalWidgetOpenRequestDataButton[]} buttons The buttons to have on the widget.\n     * @param {IModalWidgetCreateData} data Data to supply to the modal widget.\n     * @param {WidgetType} type The type of modal widget.\n     * @returns {Promise<void>} Resolves when the modal widget has been opened.\n     */\n\n  }, {\n    key: \"openModalWidget\",\n    value: function openModalWidget(url, name) {\n      var buttons = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];\n      var data = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n      var type = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : _WidgetType.MatrixWidgetType.Custom;\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.OpenModalWidget, {\n        type: type,\n        url: url,\n        name: name,\n        buttons: buttons,\n        data: data\n      }).then();\n    }\n    /**\n     * Closes the modal widget. The widget's session will be terminated shortly after.\n     * @param {IModalWidgetReturnData} data Optional data to close the modal widget with.\n     * @returns {Promise<void>} Resolves when complete.\n     */\n\n  }, {\n    key: \"closeModalWidget\",\n    value: function closeModalWidget() {\n      var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.CloseModalWidget, data).then();\n    }\n  }, {\n    key: \"sendRoomEvent\",\n    value: function sendRoomEvent(eventType, content, roomId) {\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SendEvent, {\n        type: eventType,\n        content: content,\n        room_id: roomId\n      });\n    }\n  }, {\n    key: \"sendStateEvent\",\n    value: function sendStateEvent(eventType, stateKey, content, roomId) {\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SendEvent, {\n        type: eventType,\n        content: content,\n        state_key: stateKey,\n        room_id: roomId\n      });\n    }\n    /**\n     * Sends a to-device event.\n     * @param {string} eventType The type of events being sent.\n     * @param {boolean} encrypted Whether to encrypt the message contents.\n     * @param {Object} contentMap A map from user IDs to device IDs to message contents.\n     * @returns {Promise<ISendToDeviceFromWidgetResponseData>} Resolves when complete.\n     */\n\n  }, {\n    key: \"sendToDevice\",\n    value: function sendToDevice(eventType, encrypted, contentMap) {\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SendToDevice, {\n        type: eventType,\n        encrypted: encrypted,\n        messages: contentMap\n      });\n    }\n  }, {\n    key: \"readRoomEvents\",\n    value: function readRoomEvents(eventType, limit, msgtype, roomIds) {\n      var data = {\n        type: eventType,\n        msgtype: msgtype\n      };\n\n      if (limit !== undefined) {\n        data.limit = limit;\n      }\n\n      if (roomIds) {\n        if (roomIds.includes(_Symbols.Symbols.AnyRoom)) {\n          data.room_ids = _Symbols.Symbols.AnyRoom;\n        } else {\n          data.room_ids = roomIds;\n        }\n      }\n\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC2876ReadEvents, data).then(function (r) {\n        return r.events;\n      });\n    }\n    /**\n     * Reads all related events given a known eventId.\n     * @param eventId The id of the parent event to be read.\n     * @param roomId The room to look within. When undefined, the user's currently\n     * viewed room.\n     * @param relationType The relationship type of child events to search for.\n     * When undefined, all relations are returned.\n     * @param eventType The event type of child events to search for. When undefined,\n     * all related events are returned.\n     * @param limit The maximum number of events to retrieve per room. If not\n     * supplied, the server will apply a default limit.\n     * @param from The pagination token to start returning results from, as\n     * received from a previous call. If not supplied, results start at the most\n     * recent topological event known to the server.\n     * @param to The pagination token to stop returning results at. If not\n     * supplied, results continue up to limit or until there are no more events.\n     * @param direction The direction to search for according to MSC3715.\n     * @returns Resolves to the room relations.\n     */\n\n  }, {\n    key: \"readEventRelations\",\n    value: function () {\n      var _readEventRelations = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(eventId, roomId, relationType, eventType, limit, from, to, direction) {\n        var versions, data;\n        return _regeneratorRuntime().wrap(function _callee$(_context) {\n          while (1) {\n            switch (_context.prev = _context.next) {\n              case 0:\n                _context.next = 2;\n                return this.getClientVersions();\n\n              case 2:\n                versions = _context.sent;\n\n                if (versions.includes(_ApiVersion.UnstableApiVersion.MSC3869)) {\n                  _context.next = 5;\n                  break;\n                }\n\n                throw new Error(\"The read_relations action is not supported by the client.\");\n\n              case 5:\n                data = {\n                  event_id: eventId,\n                  rel_type: relationType,\n                  event_type: eventType,\n                  room_id: roomId,\n                  to: to,\n                  from: from,\n                  limit: limit,\n                  direction: direction\n                };\n                return _context.abrupt(\"return\", this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC3869ReadRelations, data));\n\n              case 7:\n              case \"end\":\n                return _context.stop();\n            }\n          }\n        }, _callee, this);\n      }));\n\n      function readEventRelations(_x, _x2, _x3, _x4, _x5, _x6, _x7, _x8) {\n        return _readEventRelations.apply(this, arguments);\n      }\n\n      return readEventRelations;\n    }()\n  }, {\n    key: \"readStateEvents\",\n    value: function readStateEvents(eventType, limit, stateKey, roomIds) {\n      var data = {\n        type: eventType,\n        state_key: stateKey === undefined ? true : stateKey\n      };\n\n      if (limit !== undefined) {\n        data.limit = limit;\n      }\n\n      if (roomIds) {\n        if (roomIds.includes(_Symbols.Symbols.AnyRoom)) {\n          data.room_ids = _Symbols.Symbols.AnyRoom;\n        } else {\n          data.room_ids = roomIds;\n        }\n      }\n\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC2876ReadEvents, data).then(function (r) {\n        return r.events;\n      });\n    }\n    /**\n     * Sets a button as disabled or enabled on the modal widget. Buttons are enabled by default.\n     * @param {ModalButtonID} buttonId The button ID to enable/disable.\n     * @param {boolean} isEnabled Whether or not the button is enabled.\n     * @returns {Promise<void>} Resolves when complete.\n     * @throws Throws if the button cannot be disabled, or the client refuses to disable the button.\n     */\n\n  }, {\n    key: \"setModalButtonEnabled\",\n    value: function setModalButtonEnabled(buttonId, isEnabled) {\n      if (buttonId === _ModalWidgetActions.BuiltInModalButtonID.Close) {\n        throw new Error(\"The close button cannot be disabled\");\n      }\n\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SetModalButtonEnabled, {\n        button: buttonId,\n        enabled: isEnabled\n      }).then();\n    }\n    /**\n     * Attempts to navigate the client to the given URI. This can only be called with Matrix URIs\n     * (currently only matrix.to, but in future a Matrix URI scheme will be defined).\n     * @param {string} uri The URI to navigate to.\n     * @returns {Promise<void>} Resolves when complete.\n     * @throws Throws if the URI is invalid or cannot be processed.\n     * @deprecated This currently relies on an unstable MSC (MSC2931).\n     */\n\n  }, {\n    key: \"navigateTo\",\n    value: function navigateTo(uri) {\n      if (!uri || !uri.startsWith(\"https://matrix.to/#\")) {\n        throw new Error(\"Invalid matrix.to URI\");\n      }\n\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC2931Navigate, {\n        uri: uri\n      }).then();\n    }\n    /**\n     * Starts watching for TURN servers, yielding an initial set of credentials as soon as possible,\n     * and thereafter yielding new credentials whenever the previous ones expire.\n     * @yields {ITurnServer} The TURN server URIs and credentials currently available to the widget.\n     */\n\n  }, {\n    key: \"getTurnServers\",\n    value: function getTurnServers() {\n      var _this = this;\n\n      return _wrapAsyncGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3() {\n        var setTurnServer, onUpdateTurnServers;\n        return _regeneratorRuntime().wrap(function _callee3$(_context3) {\n          while (1) {\n            switch (_context3.prev = _context3.next) {\n              case 0:\n                onUpdateTurnServers = /*#__PURE__*/function () {\n                  var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(ev) {\n                    return _regeneratorRuntime().wrap(function _callee2$(_context2) {\n                      while (1) {\n                        switch (_context2.prev = _context2.next) {\n                          case 0:\n                            ev.preventDefault();\n                            setTurnServer(ev.detail.data);\n                            _context2.next = 4;\n                            return _this.transport.reply(ev.detail, {});\n\n                          case 4:\n                          case \"end\":\n                            return _context2.stop();\n                        }\n                      }\n                    }, _callee2);\n                  }));\n\n                  return function onUpdateTurnServers(_x9) {\n                    return _ref.apply(this, arguments);\n                  };\n                }(); // Start listening for updates before we even start watching, to catch\n                // TURN data that is sent immediately\n\n\n                _this.on(\"action:\".concat(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers), onUpdateTurnServers); // Only send the 'watch' action if we aren't already watching\n\n\n                if (!(_this.turnServerWatchers === 0)) {\n                  _context3.next = 12;\n                  break;\n                }\n\n                _context3.prev = 3;\n                _context3.next = 6;\n                return _awaitAsyncGenerator(_this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.WatchTurnServers, {}));\n\n              case 6:\n                _context3.next = 12;\n                break;\n\n              case 8:\n                _context3.prev = 8;\n                _context3.t0 = _context3[\"catch\"](3);\n\n                _this.off(\"action:\".concat(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers), onUpdateTurnServers);\n\n                throw _context3.t0;\n\n              case 12:\n                _this.turnServerWatchers++;\n                _context3.prev = 13;\n\n              case 14:\n                if (!true) {\n                  _context3.next = 21;\n                  break;\n                }\n\n                _context3.next = 17;\n                return _awaitAsyncGenerator(new Promise(function (resolve) {\n                  return setTurnServer = resolve;\n                }));\n\n              case 17:\n                _context3.next = 19;\n                return _context3.sent;\n\n              case 19:\n                _context3.next = 14;\n                break;\n\n              case 21:\n                _context3.prev = 21;\n\n                // The loop was broken by the caller - clean up\n                _this.off(\"action:\".concat(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers), onUpdateTurnServers); // Since sending the 'unwatch' action will end updates for all other\n                // consumers, only send it if we're the only consumer remaining\n\n\n                _this.turnServerWatchers--;\n\n                if (!(_this.turnServerWatchers === 0)) {\n                  _context3.next = 27;\n                  break;\n                }\n\n                _context3.next = 27;\n                return _awaitAsyncGenerator(_this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.UnwatchTurnServers, {}));\n\n              case 27:\n                return _context3.finish(21);\n\n              case 28:\n              case \"end\":\n                return _context3.stop();\n            }\n          }\n        }, _callee3, null, [[3, 8], [13,, 21, 28]]);\n      }))();\n    }\n    /**\n     * Search for users in the user directory.\n     * @param searchTerm The term to search for.\n     * @param limit The maximum number of results to return. If not supplied, the\n     * @returns Resolves to the search results.\n     */\n\n  }, {\n    key: \"searchUserDirectory\",\n    value: function () {\n      var _searchUserDirectory = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee4(searchTerm, limit) {\n        var versions, data;\n        return _regeneratorRuntime().wrap(function _callee4$(_context4) {\n          while (1) {\n            switch (_context4.prev = _context4.next) {\n              case 0:\n                _context4.next = 2;\n                return this.getClientVersions();\n\n              case 2:\n                versions = _context4.sent;\n\n                if (versions.includes(_ApiVersion.UnstableApiVersion.MSC3973)) {\n                  _context4.next = 5;\n                  break;\n                }\n\n                throw new Error(\"The user_directory_search action is not supported by the client.\");\n\n              case 5:\n                data = {\n                  search_term: searchTerm,\n                  limit: limit\n                };\n                return _context4.abrupt(\"return\", this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC3973UserDirectorySearch, data));\n\n              case 7:\n              case \"end\":\n                return _context4.stop();\n            }\n          }\n        }, _callee4, this);\n      }));\n\n      function searchUserDirectory(_x10, _x11) {\n        return _searchUserDirectory.apply(this, arguments);\n      }\n\n      return searchUserDirectory;\n    }()\n    /**\n     * Starts the communication channel. This should be done early to ensure\n     * that messages are not missed. Communication can only be stopped by the client.\n     */\n\n  }, {\n    key: \"start\",\n    value: function start() {\n      var _this5 = this;\n\n      this.transport.start();\n      this.getClientVersions().then(function (v) {\n        if (v.includes(_ApiVersion.UnstableApiVersion.MSC2974)) {\n          _this5.supportsMSC2974Renegotiate = true;\n        }\n      });\n    }\n  }, {\n    key: \"handleMessage\",\n    value: function handleMessage(ev) {\n      var actionEv = new CustomEvent(\"action:\".concat(ev.detail.action), {\n        detail: ev.detail,\n        cancelable: true\n      });\n      this.emit(\"action:\".concat(ev.detail.action), actionEv);\n\n      if (!actionEv.defaultPrevented) {\n        switch (ev.detail.action) {\n          case _WidgetApiAction.WidgetApiToWidgetAction.SupportedApiVersions:\n            return this.replyVersions(ev.detail);\n\n          case _WidgetApiAction.WidgetApiToWidgetAction.Capabilities:\n            return this.handleCapabilities(ev.detail);\n\n          case _WidgetApiAction.WidgetApiToWidgetAction.UpdateVisibility:\n            return this.transport.reply(ev.detail, {});\n          // ack to avoid error spam\n\n          case _WidgetApiAction.WidgetApiToWidgetAction.NotifyCapabilities:\n            return this.transport.reply(ev.detail, {});\n          // ack to avoid error spam\n\n          default:\n            return this.transport.reply(ev.detail, {\n              error: {\n                message: \"Unknown or unsupported action: \" + ev.detail.action\n              }\n            });\n        }\n      }\n    }\n  }, {\n    key: \"replyVersions\",\n    value: function replyVersions(request) {\n      this.transport.reply(request, {\n        supported_versions: _ApiVersion.CurrentApiVersions\n      });\n    }\n  }, {\n    key: \"getClientVersions\",\n    value: function getClientVersions() {\n      var _this6 = this;\n\n      if (Array.isArray(this.cachedClientVersions)) {\n        return Promise.resolve(this.cachedClientVersions);\n      }\n\n      return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SupportedApiVersions, {}).then(function (r) {\n        _this6.cachedClientVersions = r.supported_versions;\n        return r.supported_versions;\n      })[\"catch\"](function (e) {\n        console.warn(\"non-fatal error getting supported client versions: \", e);\n        return [];\n      });\n    }\n  }, {\n    key: \"handleCapabilities\",\n    value: function handleCapabilities(request) {\n      var _this7 = this;\n\n      if (this.capabilitiesFinished) {\n        return this.transport.reply(request, {\n          error: {\n            message: \"Capability negotiation already completed\"\n          }\n        });\n      } // See if we can expect a capabilities notification or not\n\n\n      return this.getClientVersions().then(function (v) {\n        if (v.includes(_ApiVersion.UnstableApiVersion.MSC2871)) {\n          _this7.once(\"action:\".concat(_WidgetApiAction.WidgetApiToWidgetAction.NotifyCapabilities), function (ev) {\n            _this7.approvedCapabilities = ev.detail.data.approved;\n\n            _this7.emit(\"ready\");\n          });\n        } else {\n          // if we can't expect notification, we're as done as we can be\n          _this7.emit(\"ready\");\n        } // in either case, reply to that capabilities request\n\n\n        _this7.capabilitiesFinished = true;\n        return _this7.transport.reply(request, {\n          capabilities: _this7.requestedCapabilities\n        });\n      });\n    }\n  }]);\n\n  return WidgetApi;\n}(_events.EventEmitter);\n\nexports.WidgetApi = WidgetApi;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.WidgetDriver = void 0;\n\nvar _ = require(\"..\");\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n/**\n * Represents the functions and behaviour the widget-api is unable to\n * do, such as prompting the user for information or interacting with\n * the UI. Clients are expected to implement this class and override\n * any functions they need/want to support.\n *\n * This class assumes the client will have a context of a Widget\n * instance already.\n */\nvar WidgetDriver = /*#__PURE__*/function () {\n  function WidgetDriver() {\n    _classCallCheck(this, WidgetDriver);\n  }\n\n  _createClass(WidgetDriver, [{\n    key: \"validateCapabilities\",\n    value:\n    /**\n     * Verifies the widget's requested capabilities, returning the ones\n     * it is approved to use. Mutating the requested capabilities will\n     * have no effect.\n     *\n     * This SHOULD result in the user being prompted to approve/deny\n     * capabilities.\n     *\n     * By default this rejects all capabilities (returns an empty set).\n     * @param {Set<Capability>} requested The set of requested capabilities.\n     * @returns {Promise<Set<Capability>>} Resolves to the allowed capabilities.\n     */\n    function validateCapabilities(requested) {\n      return Promise.resolve(new Set());\n    }\n    /**\n     * Sends an event into a room. If `roomId` is falsy, the client should send the event\n     * into the room the user is currently looking at. The widget API will have already\n     * verified that the widget is capable of sending the event to that room.\n     * @param {string} eventType The event type to be sent.\n     * @param {*} content The content for the event.\n     * @param {string|null} stateKey The state key if this is a state event, otherwise null.\n     * May be an empty string.\n     * @param {string|null} roomId The room ID to send the event to. If falsy, the room the\n     * user is currently looking at.\n     * @returns {Promise<ISendEventDetails>} Resolves when the event has been sent with\n     * details of that event.\n     * @throws Rejected when the event could not be sent.\n     */\n\n  }, {\n    key: \"sendEvent\",\n    value: function sendEvent(eventType, content) {\n      var stateKey = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;\n      var roomId = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null;\n      return Promise.reject(new Error(\"Failed to override function\"));\n    }\n    /**\n     * Sends a to-device event. The widget API will have already verified that the widget\n     * is capable of sending the event.\n     * @param {string} eventType The event type to be sent.\n     * @param {boolean} encrypted Whether to encrypt the message contents.\n     * @param {Object} contentMap A map from user ID and device ID to event content.\n     * @returns {Promise<void>} Resolves when the event has been sent.\n     * @throws Rejected when the event could not be sent.\n     */\n\n  }, {\n    key: \"sendToDevice\",\n    value: function sendToDevice(eventType, encrypted, contentMap) {\n      return Promise.reject(new Error(\"Failed to override function\"));\n    }\n    /**\n     * Reads all events of the given type, and optionally `msgtype` (if applicable/defined),\n     * the user has access to. The widget API will have already verified that the widget is\n     * capable of receiving the events. Less events than the limit are allowed to be returned,\n     * but not more. If `roomIds` is supplied, it may contain `Symbols.AnyRoom` to denote that\n     * `limit` in each of the client's known rooms should be returned. When `null`, only the\n     * room the user is currently looking at should be considered.\n     * @param eventType The event type to be read.\n     * @param msgtype The msgtype of the events to be read, if applicable/defined.\n     * @param limit The maximum number of events to retrieve per room. Will be zero to denote \"as many\n     * as possible\".\n     * @param roomIds When null, the user's currently viewed room. Otherwise, the list of room IDs\n     * to look within, possibly containing Symbols.AnyRoom to denote all known rooms.\n     * @returns {Promise<IRoomEvent[]>} Resolves to the room events, or an empty array.\n     */\n\n  }, {\n    key: \"readRoomEvents\",\n    value: function readRoomEvents(eventType, msgtype, limit) {\n      var roomIds = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null;\n      return Promise.resolve([]);\n    }\n    /**\n     * Reads all events of the given type, and optionally state key (if applicable/defined),\n     * the user has access to. The widget API will have already verified that the widget is\n     * capable of receiving the events. Less events than the limit are allowed to be returned,\n     * but not more. If `roomIds` is supplied, it may contain `Symbols.AnyRoom` to denote that\n     * `limit` in each of the client's known rooms should be returned. When `null`, only the\n     * room the user is currently looking at should be considered.\n     * @param eventType The event type to be read.\n     * @param stateKey The state key of the events to be read, if applicable/defined.\n     * @param limit The maximum number of events to retrieve. Will be zero to denote \"as many\n     * as possible\".\n     * @param roomIds When null, the user's currently viewed room. Otherwise, the list of room IDs\n     * to look within, possibly containing Symbols.AnyRoom to denote all known rooms.\n     * @returns {Promise<IRoomEvent[]>} Resolves to the state events, or an empty array.\n     */\n\n  }, {\n    key: \"readStateEvents\",\n    value: function readStateEvents(eventType, stateKey, limit) {\n      var roomIds = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null;\n      return Promise.resolve([]);\n    }\n    /**\n     * Reads all events that are related to a given event. The widget API will\n     * have already verified that the widget is capable of receiving the event,\n     * or will make sure to reject access to events which are returned from this\n     * function, but are not capable of receiving. If `relationType` or `eventType`\n     * are set, the returned events should already be filtered. Less events than\n     * the limit are allowed to be returned, but not more.\n     * @param eventId The id of the parent event to be read.\n     * @param roomId The room to look within. When undefined, the user's\n     * currently viewed room.\n     * @param relationType The relationship type of child events to search for.\n     * When undefined, all relations are returned.\n     * @param eventType The event type of child events to search for. When undefined,\n     * all related events are returned.\n     * @param from The pagination token to start returning results from, as\n     * received from a previous call. If not supplied, results start at the most\n     * recent topological event known to the server.\n     * @param to The pagination token to stop returning results at. If not\n     * supplied, results continue up to limit or until there are no more events.\n     * @param limit The maximum number of events to retrieve per room. If not\n     * supplied, the server will apply a default limit.\n     * @param direction The direction to search for according to MSC3715\n     * @returns Resolves to the room relations.\n     */\n\n  }, {\n    key: \"readEventRelations\",\n    value: function readEventRelations(eventId, roomId, relationType, eventType, from, to, limit, direction) {\n      return Promise.resolve({\n        chunk: []\n      });\n    }\n    /**\n     * Asks the user for permission to validate their identity through OpenID Connect. The\n     * interface for this function is an observable which accepts the state machine of the\n     * OIDC exchange flow. For example, if the client/user blocks the request then it would\n     * feed back a `{state: Blocked}` into the observable. Similarly, if the user already\n     * approved the widget then a `{state: Allowed}` would be fed into the observable alongside\n     * the token itself. If the client is asking for permission, it should feed in a\n     * `{state: PendingUserConfirmation}` followed by the relevant Allowed or Blocked state.\n     *\n     * The widget API will reject the widget's request with an error if this contract is not\n     * met properly. By default, the widget driver will block all OIDC requests.\n     * @param {SimpleObservable<IOpenIDUpdate>} observer The observable to feed updates into.\n     */\n\n  }, {\n    key: \"askOpenID\",\n    value: function askOpenID(observer) {\n      observer.update({\n        state: _.OpenIDRequestState.Blocked\n      });\n    }\n    /**\n     * Navigates the client with a matrix.to URI. In future this function will also be provided\n     * with the Matrix URIs once matrix.to is replaced. The given URI will have already been\n     * lightly checked to ensure it looks like a valid URI, though the implementation is recommended\n     * to do further checks on the URI.\n     * @param {string} uri The URI to navigate to.\n     * @returns {Promise<void>} Resolves when complete.\n     * @throws Throws if there's a problem with the navigation, such as invalid format.\n     */\n\n  }, {\n    key: \"navigate\",\n    value: function navigate(uri) {\n      throw new Error(\"Navigation is not implemented\");\n    }\n    /**\n     * Polls for TURN server data, yielding an initial set of credentials as soon as possible, and\n     * thereafter yielding new credentials whenever the previous ones expire. The widget API will\n     * have already verified that the widget has permission to access TURN servers.\n     * @yields {ITurnServer} The TURN server URIs and credentials currently available to the client.\n     */\n\n  }, {\n    key: \"getTurnServers\",\n    value: function getTurnServers() {\n      throw new Error(\"TURN server support is not implemented\");\n    }\n    /**\n     * Search for users in the user directory.\n     * @param searchTerm The term to search for.\n     * @param limit The maximum number of results to return. If not supplied, the\n     * @returns Resolves to the search results.\n     */\n\n  }, {\n    key: \"searchUserDirectory\",\n    value: function searchUserDirectory(searchTerm, limit) {\n      return Promise.resolve({\n        limited: false,\n        results: []\n      });\n    }\n  }]);\n\n  return WidgetDriver;\n}();\n\nexports.WidgetDriver = WidgetDriver;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _WidgetApi = require(\"./WidgetApi\");\n\nObject.keys(_WidgetApi).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _WidgetApi[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _WidgetApi[key];\n    }\n  });\n});\n\nvar _ClientWidgetApi = require(\"./ClientWidgetApi\");\n\nObject.keys(_ClientWidgetApi).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _ClientWidgetApi[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _ClientWidgetApi[key];\n    }\n  });\n});\n\nvar _Symbols = require(\"./Symbols\");\n\nObject.keys(_Symbols).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _Symbols[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _Symbols[key];\n    }\n  });\n});\n\nvar _ITransport = require(\"./transport/ITransport\");\n\nObject.keys(_ITransport).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _ITransport[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _ITransport[key];\n    }\n  });\n});\n\nvar _PostmessageTransport = require(\"./transport/PostmessageTransport\");\n\nObject.keys(_PostmessageTransport).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _PostmessageTransport[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _PostmessageTransport[key];\n    }\n  });\n});\n\nvar _ICustomWidgetData = require(\"./interfaces/ICustomWidgetData\");\n\nObject.keys(_ICustomWidgetData).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _ICustomWidgetData[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _ICustomWidgetData[key];\n    }\n  });\n});\n\nvar _IJitsiWidgetData = require(\"./interfaces/IJitsiWidgetData\");\n\nObject.keys(_IJitsiWidgetData).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _IJitsiWidgetData[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _IJitsiWidgetData[key];\n    }\n  });\n});\n\nvar _IStickerpickerWidgetData = require(\"./interfaces/IStickerpickerWidgetData\");\n\nObject.keys(_IStickerpickerWidgetData).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _IStickerpickerWidgetData[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _IStickerpickerWidgetData[key];\n    }\n  });\n});\n\nvar _IWidget = require(\"./interfaces/IWidget\");\n\nObject.keys(_IWidget).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _IWidget[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _IWidget[key];\n    }\n  });\n});\n\nvar _WidgetType = require(\"./interfaces/WidgetType\");\n\nObject.keys(_WidgetType).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _WidgetType[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _WidgetType[key];\n    }\n  });\n});\n\nvar _IWidgetApiErrorResponse = require(\"./interfaces/IWidgetApiErrorResponse\");\n\nObject.keys(_IWidgetApiErrorResponse).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _IWidgetApiErrorResponse[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _IWidgetApiErrorResponse[key];\n    }\n  });\n});\n\nvar _IWidgetApiRequest = require(\"./interfaces/IWidgetApiRequest\");\n\nObject.keys(_IWidgetApiRequest).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _IWidgetApiRequest[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _IWidgetApiRequest[key];\n    }\n  });\n});\n\nvar _IWidgetApiResponse = require(\"./interfaces/IWidgetApiResponse\");\n\nObject.keys(_IWidgetApiResponse).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _IWidgetApiResponse[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _IWidgetApiResponse[key];\n    }\n  });\n});\n\nvar _WidgetApiAction = require(\"./interfaces/WidgetApiAction\");\n\nObject.keys(_WidgetApiAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _WidgetApiAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _WidgetApiAction[key];\n    }\n  });\n});\n\nvar _WidgetApiDirection = require(\"./interfaces/WidgetApiDirection\");\n\nObject.keys(_WidgetApiDirection).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _WidgetApiDirection[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _WidgetApiDirection[key];\n    }\n  });\n});\n\nvar _ApiVersion = require(\"./interfaces/ApiVersion\");\n\nObject.keys(_ApiVersion).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _ApiVersion[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _ApiVersion[key];\n    }\n  });\n});\n\nvar _Capabilities = require(\"./interfaces/Capabilities\");\n\nObject.keys(_Capabilities).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _Capabilities[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _Capabilities[key];\n    }\n  });\n});\n\nvar _CapabilitiesAction = require(\"./interfaces/CapabilitiesAction\");\n\nObject.keys(_CapabilitiesAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _CapabilitiesAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _CapabilitiesAction[key];\n    }\n  });\n});\n\nvar _ContentLoadedAction = require(\"./interfaces/ContentLoadedAction\");\n\nObject.keys(_ContentLoadedAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _ContentLoadedAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _ContentLoadedAction[key];\n    }\n  });\n});\n\nvar _ScreenshotAction = require(\"./interfaces/ScreenshotAction\");\n\nObject.keys(_ScreenshotAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _ScreenshotAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _ScreenshotAction[key];\n    }\n  });\n});\n\nvar _StickerAction = require(\"./interfaces/StickerAction\");\n\nObject.keys(_StickerAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _StickerAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _StickerAction[key];\n    }\n  });\n});\n\nvar _StickyAction = require(\"./interfaces/StickyAction\");\n\nObject.keys(_StickyAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _StickyAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _StickyAction[key];\n    }\n  });\n});\n\nvar _SupportedVersionsAction = require(\"./interfaces/SupportedVersionsAction\");\n\nObject.keys(_SupportedVersionsAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _SupportedVersionsAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _SupportedVersionsAction[key];\n    }\n  });\n});\n\nvar _VisibilityAction = require(\"./interfaces/VisibilityAction\");\n\nObject.keys(_VisibilityAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _VisibilityAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _VisibilityAction[key];\n    }\n  });\n});\n\nvar _GetOpenIDAction = require(\"./interfaces/GetOpenIDAction\");\n\nObject.keys(_GetOpenIDAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _GetOpenIDAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _GetOpenIDAction[key];\n    }\n  });\n});\n\nvar _OpenIDCredentialsAction = require(\"./interfaces/OpenIDCredentialsAction\");\n\nObject.keys(_OpenIDCredentialsAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _OpenIDCredentialsAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _OpenIDCredentialsAction[key];\n    }\n  });\n});\n\nvar _WidgetKind = require(\"./interfaces/WidgetKind\");\n\nObject.keys(_WidgetKind).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _WidgetKind[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _WidgetKind[key];\n    }\n  });\n});\n\nvar _ModalButtonKind = require(\"./interfaces/ModalButtonKind\");\n\nObject.keys(_ModalButtonKind).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _ModalButtonKind[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _ModalButtonKind[key];\n    }\n  });\n});\n\nvar _ModalWidgetActions = require(\"./interfaces/ModalWidgetActions\");\n\nObject.keys(_ModalWidgetActions).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _ModalWidgetActions[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _ModalWidgetActions[key];\n    }\n  });\n});\n\nvar _SetModalButtonEnabledAction = require(\"./interfaces/SetModalButtonEnabledAction\");\n\nObject.keys(_SetModalButtonEnabledAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _SetModalButtonEnabledAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _SetModalButtonEnabledAction[key];\n    }\n  });\n});\n\nvar _WidgetConfigAction = require(\"./interfaces/WidgetConfigAction\");\n\nObject.keys(_WidgetConfigAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _WidgetConfigAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _WidgetConfigAction[key];\n    }\n  });\n});\n\nvar _SendEventAction = require(\"./interfaces/SendEventAction\");\n\nObject.keys(_SendEventAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _SendEventAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _SendEventAction[key];\n    }\n  });\n});\n\nvar _SendToDeviceAction = require(\"./interfaces/SendToDeviceAction\");\n\nObject.keys(_SendToDeviceAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _SendToDeviceAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _SendToDeviceAction[key];\n    }\n  });\n});\n\nvar _ReadEventAction = require(\"./interfaces/ReadEventAction\");\n\nObject.keys(_ReadEventAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _ReadEventAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _ReadEventAction[key];\n    }\n  });\n});\n\nvar _IRoomEvent = require(\"./interfaces/IRoomEvent\");\n\nObject.keys(_IRoomEvent).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _IRoomEvent[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _IRoomEvent[key];\n    }\n  });\n});\n\nvar _NavigateAction = require(\"./interfaces/NavigateAction\");\n\nObject.keys(_NavigateAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _NavigateAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _NavigateAction[key];\n    }\n  });\n});\n\nvar _TurnServerActions = require(\"./interfaces/TurnServerActions\");\n\nObject.keys(_TurnServerActions).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _TurnServerActions[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _TurnServerActions[key];\n    }\n  });\n});\n\nvar _ReadRelationsAction = require(\"./interfaces/ReadRelationsAction\");\n\nObject.keys(_ReadRelationsAction).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _ReadRelationsAction[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _ReadRelationsAction[key];\n    }\n  });\n});\n\nvar _WidgetEventCapability = require(\"./models/WidgetEventCapability\");\n\nObject.keys(_WidgetEventCapability).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _WidgetEventCapability[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _WidgetEventCapability[key];\n    }\n  });\n});\n\nvar _url = require(\"./models/validation/url\");\n\nObject.keys(_url).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _url[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _url[key];\n    }\n  });\n});\n\nvar _utils = require(\"./models/validation/utils\");\n\nObject.keys(_utils).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _utils[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _utils[key];\n    }\n  });\n});\n\nvar _Widget = require(\"./models/Widget\");\n\nObject.keys(_Widget).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _Widget[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _Widget[key];\n    }\n  });\n});\n\nvar _WidgetParser = require(\"./models/WidgetParser\");\n\nObject.keys(_WidgetParser).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _WidgetParser[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _WidgetParser[key];\n    }\n  });\n});\n\nvar _urlTemplate = require(\"./templating/url-template\");\n\nObject.keys(_urlTemplate).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _urlTemplate[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _urlTemplate[key];\n    }\n  });\n});\n\nvar _SimpleObservable = require(\"./util/SimpleObservable\");\n\nObject.keys(_SimpleObservable).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _SimpleObservable[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _SimpleObservable[key];\n    }\n  });\n});\n\nvar _WidgetDriver = require(\"./driver/WidgetDriver\");\n\nObject.keys(_WidgetDriver).forEach(function (key) {\n  if (key === \"default\" || key === \"__esModule\") return;\n  if (key in exports && exports[key] === _WidgetDriver[key]) return;\n  Object.defineProperty(exports, key, {\n    enumerable: true,\n    get: function get() {\n      return _WidgetDriver[key];\n    }\n  });\n});","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.UnstableApiVersion = exports.MatrixApiVersion = exports.CurrentApiVersions = void 0;\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar MatrixApiVersion;\nexports.MatrixApiVersion = MatrixApiVersion;\n\n(function (MatrixApiVersion) {\n  MatrixApiVersion[\"Prerelease1\"] = \"0.0.1\";\n  MatrixApiVersion[\"Prerelease2\"] = \"0.0.2\";\n})(MatrixApiVersion || (exports.MatrixApiVersion = MatrixApiVersion = {}));\n\nvar UnstableApiVersion;\nexports.UnstableApiVersion = UnstableApiVersion;\n\n(function (UnstableApiVersion) {\n  UnstableApiVersion[\"MSC2762\"] = \"org.matrix.msc2762\";\n  UnstableApiVersion[\"MSC2871\"] = \"org.matrix.msc2871\";\n  UnstableApiVersion[\"MSC2931\"] = \"org.matrix.msc2931\";\n  UnstableApiVersion[\"MSC2974\"] = \"org.matrix.msc2974\";\n  UnstableApiVersion[\"MSC2876\"] = \"org.matrix.msc2876\";\n  UnstableApiVersion[\"MSC3819\"] = \"org.matrix.msc3819\";\n  UnstableApiVersion[\"MSC3846\"] = \"town.robin.msc3846\";\n  UnstableApiVersion[\"MSC3869\"] = \"org.matrix.msc3869\";\n  UnstableApiVersion[\"MSC3973\"] = \"org.matrix.msc3973\";\n})(UnstableApiVersion || (exports.UnstableApiVersion = UnstableApiVersion = {}));\n\nvar CurrentApiVersions = [MatrixApiVersion.Prerelease1, MatrixApiVersion.Prerelease2, //MatrixApiVersion.V010,\nUnstableApiVersion.MSC2762, UnstableApiVersion.MSC2871, UnstableApiVersion.MSC2931, UnstableApiVersion.MSC2974, UnstableApiVersion.MSC2876, UnstableApiVersion.MSC3819, UnstableApiVersion.MSC3846, UnstableApiVersion.MSC3869, UnstableApiVersion.MSC3973];\nexports.CurrentApiVersions = CurrentApiVersions;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.VideoConferenceCapabilities = exports.StickerpickerCapabilities = exports.MatrixCapabilities = void 0;\nexports.getTimelineRoomIDFromCapability = getTimelineRoomIDFromCapability;\nexports.isTimelineCapability = isTimelineCapability;\nexports.isTimelineCapabilityFor = isTimelineCapabilityFor;\n\n/*\n * Copyright 2020 - 2021 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar MatrixCapabilities;\nexports.MatrixCapabilities = MatrixCapabilities;\n\n(function (MatrixCapabilities) {\n  MatrixCapabilities[\"Screenshots\"] = \"m.capability.screenshot\";\n  MatrixCapabilities[\"StickerSending\"] = \"m.sticker\";\n  MatrixCapabilities[\"AlwaysOnScreen\"] = \"m.always_on_screen\";\n  MatrixCapabilities[\"RequiresClient\"] = \"io.element.requires_client\";\n  MatrixCapabilities[\"MSC2931Navigate\"] = \"org.matrix.msc2931.navigate\";\n  MatrixCapabilities[\"MSC3846TurnServers\"] = \"town.robin.msc3846.turn_servers\";\n  MatrixCapabilities[\"MSC3973UserDirectorySearch\"] = \"org.matrix.msc3973.user_directory_search\";\n})(MatrixCapabilities || (exports.MatrixCapabilities = MatrixCapabilities = {}));\n\nvar StickerpickerCapabilities = [MatrixCapabilities.StickerSending];\nexports.StickerpickerCapabilities = StickerpickerCapabilities;\nvar VideoConferenceCapabilities = [MatrixCapabilities.AlwaysOnScreen];\n/**\n * Determines if a capability is a capability for a timeline.\n * @param {Capability} capability The capability to test.\n * @returns {boolean} True if a timeline capability, false otherwise.\n */\n\nexports.VideoConferenceCapabilities = VideoConferenceCapabilities;\n\nfunction isTimelineCapability(capability) {\n  // TODO: Change when MSC2762 becomes stable.\n  return capability === null || capability === void 0 ? void 0 : capability.startsWith(\"org.matrix.msc2762.timeline:\");\n}\n/**\n * Determines if a capability is a timeline capability for the given room.\n * @param {Capability} capability The capability to test.\n * @param {string | Symbols.AnyRoom} roomId The room ID, or `Symbols.AnyRoom` for that designation.\n * @returns {boolean} True if a matching capability, false otherwise.\n */\n\n\nfunction isTimelineCapabilityFor(capability, roomId) {\n  return capability === \"org.matrix.msc2762.timeline:\".concat(roomId);\n}\n/**\n * Gets the room ID described by a timeline capability.\n * @param {string} capability The capability to parse.\n * @returns {string} The room ID.\n */\n\n\nfunction getTimelineRoomIDFromCapability(capability) {\n  return capability.substring(capability.indexOf(\":\") + 1);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.OpenIDRequestState = void 0;\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar OpenIDRequestState;\nexports.OpenIDRequestState = OpenIDRequestState;\n\n(function (OpenIDRequestState) {\n  OpenIDRequestState[\"Allowed\"] = \"allowed\";\n  OpenIDRequestState[\"Blocked\"] = \"blocked\";\n  OpenIDRequestState[\"PendingUserConfirmation\"] = \"request\";\n})(OpenIDRequestState || (exports.OpenIDRequestState = OpenIDRequestState = {}));","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.isErrorResponse = isErrorResponse;\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nfunction isErrorResponse(responseData) {\n  if (\"error\" in responseData) {\n    var err = responseData;\n    return !!err.error.message;\n  }\n\n  return false;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.ModalButtonKind = void 0;\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar ModalButtonKind;\nexports.ModalButtonKind = ModalButtonKind;\n\n(function (ModalButtonKind) {\n  ModalButtonKind[\"Primary\"] = \"m.primary\";\n  ModalButtonKind[\"Secondary\"] = \"m.secondary\";\n  ModalButtonKind[\"Warning\"] = \"m.warning\";\n  ModalButtonKind[\"Danger\"] = \"m.danger\";\n  ModalButtonKind[\"Link\"] = \"m.link\";\n})(ModalButtonKind || (exports.ModalButtonKind = ModalButtonKind = {}));","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.BuiltInModalButtonID = void 0;\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar BuiltInModalButtonID;\nexports.BuiltInModalButtonID = BuiltInModalButtonID;\n\n(function (BuiltInModalButtonID) {\n  BuiltInModalButtonID[\"Close\"] = \"m.close\";\n})(BuiltInModalButtonID || (exports.BuiltInModalButtonID = BuiltInModalButtonID = {}));","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.WidgetApiToWidgetAction = exports.WidgetApiFromWidgetAction = void 0;\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar WidgetApiToWidgetAction;\nexports.WidgetApiToWidgetAction = WidgetApiToWidgetAction;\n\n(function (WidgetApiToWidgetAction) {\n  WidgetApiToWidgetAction[\"SupportedApiVersions\"] = \"supported_api_versions\";\n  WidgetApiToWidgetAction[\"Capabilities\"] = \"capabilities\";\n  WidgetApiToWidgetAction[\"NotifyCapabilities\"] = \"notify_capabilities\";\n  WidgetApiToWidgetAction[\"TakeScreenshot\"] = \"screenshot\";\n  WidgetApiToWidgetAction[\"UpdateVisibility\"] = \"visibility\";\n  WidgetApiToWidgetAction[\"OpenIDCredentials\"] = \"openid_credentials\";\n  WidgetApiToWidgetAction[\"WidgetConfig\"] = \"widget_config\";\n  WidgetApiToWidgetAction[\"CloseModalWidget\"] = \"close_modal\";\n  WidgetApiToWidgetAction[\"ButtonClicked\"] = \"button_clicked\";\n  WidgetApiToWidgetAction[\"SendEvent\"] = \"send_event\";\n  WidgetApiToWidgetAction[\"SendToDevice\"] = \"send_to_device\";\n  WidgetApiToWidgetAction[\"UpdateTurnServers\"] = \"update_turn_servers\";\n})(WidgetApiToWidgetAction || (exports.WidgetApiToWidgetAction = WidgetApiToWidgetAction = {}));\n\nvar WidgetApiFromWidgetAction;\nexports.WidgetApiFromWidgetAction = WidgetApiFromWidgetAction;\n\n(function (WidgetApiFromWidgetAction) {\n  WidgetApiFromWidgetAction[\"SupportedApiVersions\"] = \"supported_api_versions\";\n  WidgetApiFromWidgetAction[\"ContentLoaded\"] = \"content_loaded\";\n  WidgetApiFromWidgetAction[\"SendSticker\"] = \"m.sticker\";\n  WidgetApiFromWidgetAction[\"UpdateAlwaysOnScreen\"] = \"set_always_on_screen\";\n  WidgetApiFromWidgetAction[\"GetOpenIDCredentials\"] = \"get_openid\";\n  WidgetApiFromWidgetAction[\"CloseModalWidget\"] = \"close_modal\";\n  WidgetApiFromWidgetAction[\"OpenModalWidget\"] = \"open_modal\";\n  WidgetApiFromWidgetAction[\"SetModalButtonEnabled\"] = \"set_button_enabled\";\n  WidgetApiFromWidgetAction[\"SendEvent\"] = \"send_event\";\n  WidgetApiFromWidgetAction[\"SendToDevice\"] = \"send_to_device\";\n  WidgetApiFromWidgetAction[\"WatchTurnServers\"] = \"watch_turn_servers\";\n  WidgetApiFromWidgetAction[\"UnwatchTurnServers\"] = \"unwatch_turn_servers\";\n  WidgetApiFromWidgetAction[\"MSC2876ReadEvents\"] = \"org.matrix.msc2876.read_events\";\n  WidgetApiFromWidgetAction[\"MSC2931Navigate\"] = \"org.matrix.msc2931.navigate\";\n  WidgetApiFromWidgetAction[\"MSC2974RenegotiateCapabilities\"] = \"org.matrix.msc2974.request_capabilities\";\n  WidgetApiFromWidgetAction[\"MSC3869ReadRelations\"] = \"org.matrix.msc3869.read_relations\";\n  WidgetApiFromWidgetAction[\"MSC3973UserDirectorySearch\"] = \"org.matrix.msc3973.user_directory_search\";\n})(WidgetApiFromWidgetAction || (exports.WidgetApiFromWidgetAction = WidgetApiFromWidgetAction = {}));","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.WidgetApiDirection = void 0;\nexports.invertedDirection = invertedDirection;\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar WidgetApiDirection;\nexports.WidgetApiDirection = WidgetApiDirection;\n\n(function (WidgetApiDirection) {\n  WidgetApiDirection[\"ToWidget\"] = \"toWidget\";\n  WidgetApiDirection[\"FromWidget\"] = \"fromWidget\";\n})(WidgetApiDirection || (exports.WidgetApiDirection = WidgetApiDirection = {}));\n\nfunction invertedDirection(dir) {\n  if (dir === WidgetApiDirection.ToWidget) {\n    return WidgetApiDirection.FromWidget;\n  } else if (dir === WidgetApiDirection.FromWidget) {\n    return WidgetApiDirection.ToWidget;\n  } else {\n    throw new Error(\"Invalid direction\");\n  }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.WidgetKind = void 0;\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar WidgetKind;\nexports.WidgetKind = WidgetKind;\n\n(function (WidgetKind) {\n  WidgetKind[\"Room\"] = \"room\";\n  WidgetKind[\"Account\"] = \"account\";\n  WidgetKind[\"Modal\"] = \"modal\";\n})(WidgetKind || (exports.WidgetKind = WidgetKind = {}));","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.MatrixWidgetType = void 0;\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar MatrixWidgetType;\nexports.MatrixWidgetType = MatrixWidgetType;\n\n(function (MatrixWidgetType) {\n  MatrixWidgetType[\"Custom\"] = \"m.custom\";\n  MatrixWidgetType[\"JitsiMeet\"] = \"m.jitsi\";\n  MatrixWidgetType[\"Stickerpicker\"] = \"m.stickerpicker\";\n})(MatrixWidgetType || (exports.MatrixWidgetType = MatrixWidgetType = {}));","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.Widget = void 0;\n\nvar _utils = require(\"./validation/utils\");\n\nvar _ = require(\"..\");\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n/**\n * Represents the barest form of widget.\n */\nvar Widget = /*#__PURE__*/function () {\n  function Widget(definition) {\n    _classCallCheck(this, Widget);\n\n    this.definition = definition;\n    if (!this.definition) throw new Error(\"Definition is required\");\n    (0, _utils.assertPresent)(definition, \"id\");\n    (0, _utils.assertPresent)(definition, \"creatorUserId\");\n    (0, _utils.assertPresent)(definition, \"type\");\n    (0, _utils.assertPresent)(definition, \"url\");\n  }\n  /**\n   * The user ID who created the widget.\n   */\n\n\n  _createClass(Widget, [{\n    key: \"creatorUserId\",\n    get: function get() {\n      return this.definition.creatorUserId;\n    }\n    /**\n     * The type of widget.\n     */\n\n  }, {\n    key: \"type\",\n    get: function get() {\n      return this.definition.type;\n    }\n    /**\n     * The ID of the widget.\n     */\n\n  }, {\n    key: \"id\",\n    get: function get() {\n      return this.definition.id;\n    }\n    /**\n     * The name of the widget, or null if not set.\n     */\n\n  }, {\n    key: \"name\",\n    get: function get() {\n      return this.definition.name || null;\n    }\n    /**\n     * The title for the widget, or null if not set.\n     */\n\n  }, {\n    key: \"title\",\n    get: function get() {\n      return this.rawData.title || null;\n    }\n    /**\n     * The templated URL for the widget.\n     */\n\n  }, {\n    key: \"templateUrl\",\n    get: function get() {\n      return this.definition.url;\n    }\n    /**\n     * The origin for this widget.\n     */\n\n  }, {\n    key: \"origin\",\n    get: function get() {\n      return new URL(this.templateUrl).origin;\n    }\n    /**\n     * Whether or not the client should wait for the iframe to load. Defaults\n     * to true.\n     */\n\n  }, {\n    key: \"waitForIframeLoad\",\n    get: function get() {\n      if (this.definition.waitForIframeLoad === false) return false;\n      if (this.definition.waitForIframeLoad === true) return true;\n      return true; // default true\n    }\n    /**\n     * The raw data for the widget. This will always be defined, though\n     * may be empty.\n     */\n\n  }, {\n    key: \"rawData\",\n    get: function get() {\n      return this.definition.data || {};\n    }\n    /**\n     * Gets a complete widget URL for the client to render.\n     * @param {ITemplateParams} params The template parameters.\n     * @returns {string} A templated URL.\n     */\n\n  }, {\n    key: \"getCompleteUrl\",\n    value: function getCompleteUrl(params) {\n      return (0, _.runTemplate)(this.templateUrl, this.definition, params);\n    }\n  }]);\n\n  return Widget;\n}();\n\nexports.Widget = Widget;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.WidgetEventCapability = exports.EventKind = exports.EventDirection = void 0;\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it[\"return\"] != null) it[\"return\"](); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar EventKind;\nexports.EventKind = EventKind;\n\n(function (EventKind) {\n  EventKind[\"Event\"] = \"event\";\n  EventKind[\"State\"] = \"state_event\";\n  EventKind[\"ToDevice\"] = \"to_device\";\n})(EventKind || (exports.EventKind = EventKind = {}));\n\nvar EventDirection;\nexports.EventDirection = EventDirection;\n\n(function (EventDirection) {\n  EventDirection[\"Send\"] = \"send\";\n  EventDirection[\"Receive\"] = \"receive\";\n})(EventDirection || (exports.EventDirection = EventDirection = {}));\n\nvar WidgetEventCapability = /*#__PURE__*/function () {\n  function WidgetEventCapability(direction, eventType, kind, keyStr, raw) {\n    _classCallCheck(this, WidgetEventCapability);\n\n    this.direction = direction;\n    this.eventType = eventType;\n    this.kind = kind;\n    this.keyStr = keyStr;\n    this.raw = raw;\n  }\n\n  _createClass(WidgetEventCapability, [{\n    key: \"matchesAsStateEvent\",\n    value: function matchesAsStateEvent(direction, eventType, stateKey) {\n      if (this.kind !== EventKind.State) return false; // not a state event\n\n      if (this.direction !== direction) return false; // direction mismatch\n\n      if (this.eventType !== eventType) return false; // event type mismatch\n\n      if (this.keyStr === null) return true; // all state keys are allowed\n\n      if (this.keyStr === stateKey) return true; // this state key is allowed\n      // Default not allowed\n\n      return false;\n    }\n  }, {\n    key: \"matchesAsToDeviceEvent\",\n    value: function matchesAsToDeviceEvent(direction, eventType) {\n      if (this.kind !== EventKind.ToDevice) return false; // not a to-device event\n\n      if (this.direction !== direction) return false; // direction mismatch\n\n      if (this.eventType !== eventType) return false; // event type mismatch\n      // Checks passed, the event is allowed\n\n      return true;\n    }\n  }, {\n    key: \"matchesAsRoomEvent\",\n    value: function matchesAsRoomEvent(direction, eventType) {\n      var msgtype = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;\n      if (this.kind !== EventKind.Event) return false; // not a room event\n\n      if (this.direction !== direction) return false; // direction mismatch\n\n      if (this.eventType !== eventType) return false; // event type mismatch\n\n      if (this.eventType === \"m.room.message\") {\n        if (this.keyStr === null) return true; // all message types are allowed\n\n        if (this.keyStr === msgtype) return true; // this message type is allowed\n      } else {\n        return true; // already passed the check for if the event is allowed\n      } // Default not allowed\n\n\n      return false;\n    }\n  }], [{\n    key: \"forStateEvent\",\n    value: function forStateEvent(direction, eventType, stateKey) {\n      // TODO: Enable support for m.* namespace once the MSC lands.\n      // https://github.com/matrix-org/matrix-widget-api/issues/22\n      eventType = eventType.replace(/#/g, '\\\\#');\n      stateKey = stateKey !== null && stateKey !== undefined ? \"#\".concat(stateKey) : '';\n      var str = \"org.matrix.msc2762.\".concat(direction, \".state_event:\").concat(eventType).concat(stateKey); // cheat by sending it through the processor\n\n      return WidgetEventCapability.findEventCapabilities([str])[0];\n    }\n  }, {\n    key: \"forToDeviceEvent\",\n    value: function forToDeviceEvent(direction, eventType) {\n      // TODO: Enable support for m.* namespace once the MSC lands.\n      // https://github.com/matrix-org/matrix-widget-api/issues/56\n      var str = \"org.matrix.msc3819.\".concat(direction, \".to_device:\").concat(eventType); // cheat by sending it through the processor\n\n      return WidgetEventCapability.findEventCapabilities([str])[0];\n    }\n  }, {\n    key: \"forRoomEvent\",\n    value: function forRoomEvent(direction, eventType) {\n      // TODO: Enable support for m.* namespace once the MSC lands.\n      // https://github.com/matrix-org/matrix-widget-api/issues/22\n      var str = \"org.matrix.msc2762.\".concat(direction, \".event:\").concat(eventType); // cheat by sending it through the processor\n\n      return WidgetEventCapability.findEventCapabilities([str])[0];\n    }\n  }, {\n    key: \"forRoomMessageEvent\",\n    value: function forRoomMessageEvent(direction, msgtype) {\n      // TODO: Enable support for m.* namespace once the MSC lands.\n      // https://github.com/matrix-org/matrix-widget-api/issues/22\n      msgtype = msgtype === null || msgtype === undefined ? '' : msgtype;\n      var str = \"org.matrix.msc2762.\".concat(direction, \".event:m.room.message#\").concat(msgtype); // cheat by sending it through the processor\n\n      return WidgetEventCapability.findEventCapabilities([str])[0];\n    }\n    /**\n     * Parses a capabilities request to find all the event capability requests.\n     * @param {Iterable<Capability>} capabilities The capabilities requested/to parse.\n     * @returns {WidgetEventCapability[]} An array of event capability requests. May be empty, but never null.\n     */\n\n  }, {\n    key: \"findEventCapabilities\",\n    value: function findEventCapabilities(capabilities) {\n      var parsed = [];\n\n      var _iterator = _createForOfIteratorHelper(capabilities),\n          _step;\n\n      try {\n        for (_iterator.s(); !(_step = _iterator.n()).done;) {\n          var cap = _step.value;\n          var _direction = null;\n          var eventSegment = void 0;\n          var _kind = null; // TODO: Enable support for m.* namespace once the MSCs land.\n          // https://github.com/matrix-org/matrix-widget-api/issues/22\n          // https://github.com/matrix-org/matrix-widget-api/issues/56\n\n          if (cap.startsWith(\"org.matrix.msc2762.send.event:\")) {\n            _direction = EventDirection.Send;\n            _kind = EventKind.Event;\n            eventSegment = cap.substring(\"org.matrix.msc2762.send.event:\".length);\n          } else if (cap.startsWith(\"org.matrix.msc2762.send.state_event:\")) {\n            _direction = EventDirection.Send;\n            _kind = EventKind.State;\n            eventSegment = cap.substring(\"org.matrix.msc2762.send.state_event:\".length);\n          } else if (cap.startsWith(\"org.matrix.msc3819.send.to_device:\")) {\n            _direction = EventDirection.Send;\n            _kind = EventKind.ToDevice;\n            eventSegment = cap.substring(\"org.matrix.msc3819.send.to_device:\".length);\n          } else if (cap.startsWith(\"org.matrix.msc2762.receive.event:\")) {\n            _direction = EventDirection.Receive;\n            _kind = EventKind.Event;\n            eventSegment = cap.substring(\"org.matrix.msc2762.receive.event:\".length);\n          } else if (cap.startsWith(\"org.matrix.msc2762.receive.state_event:\")) {\n            _direction = EventDirection.Receive;\n            _kind = EventKind.State;\n            eventSegment = cap.substring(\"org.matrix.msc2762.receive.state_event:\".length);\n          } else if (cap.startsWith(\"org.matrix.msc3819.receive.to_device:\")) {\n            _direction = EventDirection.Receive;\n            _kind = EventKind.ToDevice;\n            eventSegment = cap.substring(\"org.matrix.msc3819.receive.to_device:\".length);\n          }\n\n          if (_direction === null || _kind === null || eventSegment === undefined) continue; // The capability uses `#` as a separator between event type and state key/msgtype,\n          // so we split on that. However, a # is also valid in either one of those so we\n          // join accordingly.\n          // Eg: `m.room.message##m.text` is \"m.room.message\" event with msgtype \"#m.text\".\n\n          var expectingKeyStr = eventSegment.startsWith(\"m.room.message#\") || _kind === EventKind.State;\n\n          var _keyStr = null;\n\n          if (eventSegment.includes('#') && expectingKeyStr) {\n            // Dev note: regex is difficult to write, so instead the rules are manually written\n            // out. This is probably just as understandable as a boring regex though, so win-win?\n            // Test cases:\n            // str                      eventSegment        keyStr\n            // -------------------------------------------------------------\n            // m.room.message#          m.room.message      <empty string>\n            // m.room.message#test      m.room.message      test\n            // m.room.message\\#         m.room.message#     test\n            // m.room.message##test     m.room.message      #test\n            // m.room.message\\##test    m.room.message#     test\n            // m.room.message\\\\##test   m.room.message\\#    test\n            // m.room.message\\\\###test  m.room.message\\#    #test\n            // First step: explode the string\n            var parts = eventSegment.split('#'); // To form the eventSegment, we'll keep finding parts of the exploded string until\n            // there's one that doesn't end with the escape character (\\). We'll then join those\n            // segments together with the exploding character. We have to remember to consume the\n            // escape character as well.\n\n            var idx = parts.findIndex(function (p) {\n              return !p.endsWith(\"\\\\\");\n            });\n            eventSegment = parts.slice(0, idx + 1).map(function (p) {\n              return p.endsWith('\\\\') ? p.substring(0, p.length - 1) : p;\n            }).join('#'); // The keyStr is whatever is left over.\n\n            _keyStr = parts.slice(idx + 1).join('#');\n          }\n\n          parsed.push(new WidgetEventCapability(_direction, eventSegment, _kind, _keyStr, cap));\n        }\n      } catch (err) {\n        _iterator.e(err);\n      } finally {\n        _iterator.f();\n      }\n\n      return parsed;\n    }\n  }]);\n\n  return WidgetEventCapability;\n}();\n\nexports.WidgetEventCapability = WidgetEventCapability;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.WidgetParser = void 0;\n\nvar _Widget = require(\"./Widget\");\n\nvar _url = require(\"./validation/url\");\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it[\"return\"] != null) it[\"return\"](); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nvar WidgetParser = /*#__PURE__*/function () {\n  function WidgetParser() {// private constructor because this is a util class\n\n    _classCallCheck(this, WidgetParser);\n  }\n  /**\n   * Parses widgets from the \"m.widgets\" account data event. This will always\n   * return an array, though may be empty if no valid widgets were found.\n   * @param {IAccountDataWidgets} content The content of the \"m.widgets\" account data.\n   * @returns {Widget[]} The widgets in account data, or an empty array.\n   */\n\n\n  _createClass(WidgetParser, null, [{\n    key: \"parseAccountData\",\n    value: function parseAccountData(content) {\n      if (!content) return [];\n      var result = [];\n\n      for (var _i = 0, _Object$keys = Object.keys(content); _i < _Object$keys.length; _i++) {\n        var _widgetId = _Object$keys[_i];\n        var roughWidget = content[_widgetId];\n        if (!roughWidget) continue;\n        if (roughWidget.type !== \"m.widget\" && roughWidget.type !== \"im.vector.modular.widgets\") continue;\n        if (!roughWidget.sender) continue;\n        var probableWidgetId = roughWidget.state_key || roughWidget.id;\n        if (probableWidgetId !== _widgetId) continue;\n        var asStateEvent = {\n          content: roughWidget.content,\n          sender: roughWidget.sender,\n          type: \"m.widget\",\n          state_key: _widgetId,\n          event_id: \"$example\",\n          room_id: \"!example\",\n          origin_server_ts: 1\n        };\n        var widget = WidgetParser.parseRoomWidget(asStateEvent);\n        if (widget) result.push(widget);\n      }\n\n      return result;\n    }\n    /**\n     * Parses all the widgets possible in the given array. This will always return\n     * an array, though may be empty if no widgets could be parsed.\n     * @param {IStateEvent[]} currentState The room state to parse.\n     * @returns {Widget[]} The widgets in the state, or an empty array.\n     */\n\n  }, {\n    key: \"parseWidgetsFromRoomState\",\n    value: function parseWidgetsFromRoomState(currentState) {\n      if (!currentState) return [];\n      var result = [];\n\n      var _iterator = _createForOfIteratorHelper(currentState),\n          _step;\n\n      try {\n        for (_iterator.s(); !(_step = _iterator.n()).done;) {\n          var state = _step.value;\n          var widget = WidgetParser.parseRoomWidget(state);\n          if (widget) result.push(widget);\n        }\n      } catch (err) {\n        _iterator.e(err);\n      } finally {\n        _iterator.f();\n      }\n\n      return result;\n    }\n    /**\n     * Parses a state event into a widget. If the state event does not represent\n     * a widget (wrong event type, invalid widget, etc) then null is returned.\n     * @param {IStateEvent} stateEvent The state event.\n     * @returns {Widget|null} The widget, or null if invalid\n     */\n\n  }, {\n    key: \"parseRoomWidget\",\n    value: function parseRoomWidget(stateEvent) {\n      if (!stateEvent) return null; // TODO: [Legacy] Remove legacy support\n\n      if (stateEvent.type !== \"m.widget\" && stateEvent.type !== \"im.vector.modular.widgets\") {\n        return null;\n      } // Dev note: Throughout this function we have null safety to ensure that\n      // if the caller did not supply something useful that we don't error. This\n      // is done against the requirements of the interface because not everyone\n      // will have an interface to validate against.\n\n\n      var content = stateEvent.content || {}; // Form our best approximation of a widget with the information we have\n\n      var estimatedWidget = {\n        id: stateEvent.state_key,\n        creatorUserId: content['creatorUserId'] || stateEvent.sender,\n        name: content['name'],\n        type: content['type'],\n        url: content['url'],\n        waitForIframeLoad: content['waitForIframeLoad'],\n        data: content['data']\n      }; // Finally, process that widget\n\n      return WidgetParser.processEstimatedWidget(estimatedWidget);\n    }\n  }, {\n    key: \"processEstimatedWidget\",\n    value: function processEstimatedWidget(widget) {\n      // Validate that the widget has the best chance of passing as a widget\n      if (!widget.id || !widget.creatorUserId || !widget.type) {\n        return null;\n      }\n\n      if (!(0, _url.isValidUrl)(widget.url)) {\n        return null;\n      } // TODO: Validate data for known widget types\n\n\n      return new _Widget.Widget(widget);\n    }\n  }]);\n\n  return WidgetParser;\n}();\n\nexports.WidgetParser = WidgetParser;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.isValidUrl = isValidUrl;\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nfunction isValidUrl(val) {\n  if (!val) return false; // easy: not valid if not present\n\n  try {\n    var parsed = new URL(val);\n\n    if (parsed.protocol !== \"http\" && parsed.protocol !== \"https\") {\n      return false;\n    }\n\n    return true;\n  } catch (e) {\n    if (e instanceof TypeError) {\n      return false;\n    }\n\n    throw e;\n  }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.assertPresent = assertPresent;\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nfunction assertPresent(obj, key) {\n  if (!obj[key]) {\n    throw new Error(\"\".concat(key, \" is required\"));\n  }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.runTemplate = runTemplate;\nexports.toString = toString;\n\n/*\n * Copyright 2020, 2021 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nfunction runTemplate(url, widget, params) {\n  // Always apply the supplied params over top of data to ensure the data can't lie about them.\n  var variables = Object.assign({}, widget.data, {\n    'matrix_room_id': params.widgetRoomId || \"\",\n    'matrix_user_id': params.currentUserId,\n    'matrix_display_name': params.userDisplayName || params.currentUserId,\n    'matrix_avatar_url': params.userHttpAvatarUrl || \"\",\n    'matrix_widget_id': widget.id,\n    // TODO: Convert to stable (https://github.com/matrix-org/matrix-doc/pull/2873)\n    'org.matrix.msc2873.client_id': params.clientId || \"\",\n    'org.matrix.msc2873.client_theme': params.clientTheme || \"\",\n    'org.matrix.msc2873.client_language': params.clientLanguage || \"\"\n  });\n  var result = url;\n\n  for (var _i = 0, _Object$keys = Object.keys(variables); _i < _Object$keys.length; _i++) {\n    var key = _Object$keys[_i];\n    // Regex escape from https://stackoverflow.com/a/6969486/7037379\n    var pattern = \"$\".concat(key).replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&'); // $& means the whole matched string\n\n    var rexp = new RegExp(pattern, 'g'); // This is technically not what we're supposed to do for a couple of reasons:\n    // 1. We are assuming that there won't later be a $key match after we replace a variable.\n    // 2. We are assuming that the variable is in a place where it can be escaped (eg: path or query string).\n\n    result = result.replace(rexp, encodeURIComponent(toString(variables[key])));\n  }\n\n  return result;\n}\n\nfunction toString(a) {\n  if (a === null || a === undefined) {\n    return \"\".concat(a);\n  }\n\n  return String(a);\n}","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.PostmessageTransport = void 0;\n\nvar _events = require(\"events\");\n\nvar _ = require(\"..\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, \"prototype\", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } else if (call !== void 0) { throw new TypeError(\"Derived constructors may only return object or undefined\"); } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**\n * Transport for the Widget API over postMessage.\n */\nvar PostmessageTransport = /*#__PURE__*/function (_EventEmitter) {\n  _inherits(PostmessageTransport, _EventEmitter);\n\n  var _super = _createSuper(PostmessageTransport);\n\n  function PostmessageTransport(sendDirection, initialWidgetId, transportWindow, inboundWindow) {\n    var _this;\n\n    _classCallCheck(this, PostmessageTransport);\n\n    _this = _super.call(this);\n    _this.sendDirection = sendDirection;\n    _this.initialWidgetId = initialWidgetId;\n    _this.transportWindow = transportWindow;\n    _this.inboundWindow = inboundWindow;\n\n    _defineProperty(_assertThisInitialized(_this), \"strictOriginCheck\", false);\n\n    _defineProperty(_assertThisInitialized(_this), \"targetOrigin\", \"*\");\n\n    _defineProperty(_assertThisInitialized(_this), \"timeoutSeconds\", 10);\n\n    _defineProperty(_assertThisInitialized(_this), \"_ready\", false);\n\n    _defineProperty(_assertThisInitialized(_this), \"_widgetId\", null);\n\n    _defineProperty(_assertThisInitialized(_this), \"outboundRequests\", new Map());\n\n    _defineProperty(_assertThisInitialized(_this), \"stopController\", new AbortController());\n\n    _this._widgetId = initialWidgetId;\n    return _this;\n  }\n\n  _createClass(PostmessageTransport, [{\n    key: \"ready\",\n    get: function get() {\n      return this._ready;\n    }\n  }, {\n    key: \"widgetId\",\n    get: function get() {\n      return this._widgetId || null;\n    }\n  }, {\n    key: \"nextRequestId\",\n    get: function get() {\n      var idBase = \"widgetapi-\".concat(Date.now());\n      var index = 0;\n      var id = idBase;\n\n      while (this.outboundRequests.has(id)) {\n        id = \"\".concat(idBase, \"-\").concat(index++);\n      } // reserve the ID\n\n\n      this.outboundRequests.set(id, null);\n      return id;\n    }\n  }, {\n    key: \"sendInternal\",\n    value: function sendInternal(message) {\n      console.log(\"[PostmessageTransport] Sending object to \".concat(this.targetOrigin, \": \"), message);\n      this.transportWindow.postMessage(message, this.targetOrigin);\n    }\n  }, {\n    key: \"reply\",\n    value: function reply(request, responseData) {\n      return this.sendInternal(_objectSpread(_objectSpread({}, request), {}, {\n        response: responseData\n      }));\n    }\n  }, {\n    key: \"send\",\n    value: function send(action, data) {\n      return this.sendComplete(action, data).then(function (r) {\n        return r.response;\n      });\n    }\n  }, {\n    key: \"sendComplete\",\n    value: function sendComplete(action, data) {\n      var _this2 = this;\n\n      if (!this.ready || !this.widgetId) {\n        return Promise.reject(new Error(\"Not ready or unknown widget ID\"));\n      }\n\n      var request = {\n        api: this.sendDirection,\n        widgetId: this.widgetId,\n        requestId: this.nextRequestId,\n        action: action,\n        data: data\n      };\n\n      if (action === _.WidgetApiToWidgetAction.UpdateVisibility) {\n        request['visible'] = data['visible'];\n      }\n\n      return new Promise(function (prResolve, prReject) {\n        var resolve = function resolve(response) {\n          cleanUp();\n          prResolve(response);\n        };\n\n        var reject = function reject(err) {\n          cleanUp();\n          prReject(err);\n        };\n\n        var timerId = setTimeout(function () {\n          return reject(new Error(\"Request timed out\"));\n        }, (_this2.timeoutSeconds || 1) * 1000);\n\n        var onStop = function onStop() {\n          return reject(new Error(\"Transport stopped\"));\n        };\n\n        _this2.stopController.signal.addEventListener(\"abort\", onStop);\n\n        var cleanUp = function cleanUp() {\n          _this2.outboundRequests[\"delete\"](request.requestId);\n\n          clearTimeout(timerId);\n\n          _this2.stopController.signal.removeEventListener(\"abort\", onStop);\n        };\n\n        _this2.outboundRequests.set(request.requestId, {\n          request: request,\n          resolve: resolve,\n          reject: reject\n        });\n\n        _this2.sendInternal(request);\n      });\n    }\n  }, {\n    key: \"start\",\n    value: function start() {\n      var _this3 = this;\n\n      this.inboundWindow.addEventListener(\"message\", function (ev) {\n        _this3.handleMessage(ev);\n      });\n      this._ready = true;\n    }\n  }, {\n    key: \"stop\",\n    value: function stop() {\n      this._ready = false;\n      this.stopController.abort();\n    }\n  }, {\n    key: \"handleMessage\",\n    value: function handleMessage(ev) {\n      if (this.stopController.signal.aborted) return;\n      if (!ev.data) return; // invalid event\n\n      if (this.strictOriginCheck && ev.origin !== window.origin) return; // bad origin\n      // treat the message as a response first, then downgrade to a request\n\n      var response = ev.data;\n      if (!response.action || !response.requestId || !response.widgetId) return; // invalid request/response\n\n      if (!response.response) {\n        // it's a request\n        var request = response;\n        if (request.api !== (0, _.invertedDirection)(this.sendDirection)) return; // wrong direction\n\n        this.handleRequest(request);\n      } else {\n        // it's a response\n        if (response.api !== this.sendDirection) return; // wrong direction\n\n        this.handleResponse(response);\n      }\n    }\n  }, {\n    key: \"handleRequest\",\n    value: function handleRequest(request) {\n      if (this.widgetId) {\n        if (this.widgetId !== request.widgetId) return; // wrong widget\n      } else {\n        this._widgetId = request.widgetId;\n      }\n\n      this.emit(\"message\", new CustomEvent(\"message\", {\n        detail: request\n      }));\n    }\n  }, {\n    key: \"handleResponse\",\n    value: function handleResponse(response) {\n      if (response.widgetId !== this.widgetId) return; // wrong widget\n\n      var req = this.outboundRequests.get(response.requestId);\n      if (!req) return; // response to an unknown request\n\n      if ((0, _.isErrorResponse)(response.response)) {\n        var _err = response.response;\n        req.reject(new Error(_err.error.message));\n      } else {\n        req.resolve(response);\n      }\n    }\n  }]);\n\n  return PostmessageTransport;\n}(_events.EventEmitter);\n\nexports.PostmessageTransport = PostmessageTransport;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.SimpleObservable = void 0;\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it[\"return\"] != null) it[\"return\"](); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/*\n * Copyright 2020 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar SimpleObservable = /*#__PURE__*/function () {\n  function SimpleObservable(initialFn) {\n    _classCallCheck(this, SimpleObservable);\n\n    _defineProperty(this, \"listeners\", []);\n\n    if (initialFn) this.listeners.push(initialFn);\n  }\n\n  _createClass(SimpleObservable, [{\n    key: \"onUpdate\",\n    value: function onUpdate(fn) {\n      this.listeners.push(fn);\n    }\n  }, {\n    key: \"update\",\n    value: function update(val) {\n      var _iterator = _createForOfIteratorHelper(this.listeners),\n          _step;\n\n      try {\n        for (_iterator.s(); !(_step = _iterator.n()).done;) {\n          var listener = _step.value;\n          listener(val);\n        }\n      } catch (err) {\n        _iterator.e(err);\n      } finally {\n        _iterator.f();\n      }\n    }\n  }, {\n    key: \"close\",\n    value: function close() {\n      this.listeners = []; // reset\n    }\n  }]);\n\n  return SimpleObservable;\n}();\n\nexports.SimpleObservable = SimpleObservable;","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n  ? R.apply\n  : function ReflectApply(target, receiver, args) {\n    return Function.prototype.apply.call(target, receiver, args);\n  }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n  ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n  ReflectOwnKeys = function ReflectOwnKeys(target) {\n    return Object.getOwnPropertyNames(target)\n      .concat(Object.getOwnPropertySymbols(target));\n  };\n} else {\n  ReflectOwnKeys = function ReflectOwnKeys(target) {\n    return Object.getOwnPropertyNames(target);\n  };\n}\n\nfunction ProcessEmitWarning(warning) {\n  if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n  return value !== value;\n}\n\nfunction EventEmitter() {\n  EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n  if (typeof listener !== 'function') {\n    throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n  }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n  enumerable: true,\n  get: function() {\n    return defaultMaxListeners;\n  },\n  set: function(arg) {\n    if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n      throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n    }\n    defaultMaxListeners = arg;\n  }\n});\n\nEventEmitter.init = function() {\n\n  if (this._events === undefined ||\n      this._events === Object.getPrototypeOf(this)._events) {\n    this._events = Object.create(null);\n    this._eventsCount = 0;\n  }\n\n  this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n  if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n    throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n  }\n  this._maxListeners = n;\n  return this;\n};\n\nfunction _getMaxListeners(that) {\n  if (that._maxListeners === undefined)\n    return EventEmitter.defaultMaxListeners;\n  return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n  return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n  var args = [];\n  for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n  var doError = (type === 'error');\n\n  var events = this._events;\n  if (events !== undefined)\n    doError = (doError && events.error === undefined);\n  else if (!doError)\n    return false;\n\n  // If there is no 'error' event listener then throw.\n  if (doError) {\n    var er;\n    if (args.length > 0)\n      er = args[0];\n    if (er instanceof Error) {\n      // Note: The comments on the `throw` lines are intentional, they show\n      // up in Node's output if this results in an unhandled exception.\n      throw er; // Unhandled 'error' event\n    }\n    // At least give some kind of context to the user\n    var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n    err.context = er;\n    throw err; // Unhandled 'error' event\n  }\n\n  var handler = events[type];\n\n  if (handler === undefined)\n    return false;\n\n  if (typeof handler === 'function') {\n    ReflectApply(handler, this, args);\n  } else {\n    var len = handler.length;\n    var listeners = arrayClone(handler, len);\n    for (var i = 0; i < len; ++i)\n      ReflectApply(listeners[i], this, args);\n  }\n\n  return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n  var m;\n  var events;\n  var existing;\n\n  checkListener(listener);\n\n  events = target._events;\n  if (events === undefined) {\n    events = target._events = Object.create(null);\n    target._eventsCount = 0;\n  } else {\n    // To avoid recursion in the case that type === \"newListener\"! Before\n    // adding it to the listeners, first emit \"newListener\".\n    if (events.newListener !== undefined) {\n      target.emit('newListener', type,\n                  listener.listener ? listener.listener : listener);\n\n      // Re-assign `events` because a newListener handler could have caused the\n      // this._events to be assigned to a new object\n      events = target._events;\n    }\n    existing = events[type];\n  }\n\n  if (existing === undefined) {\n    // Optimize the case of one listener. Don't need the extra array object.\n    existing = events[type] = listener;\n    ++target._eventsCount;\n  } else {\n    if (typeof existing === 'function') {\n      // Adding the second element, need to change to array.\n      existing = events[type] =\n        prepend ? [listener, existing] : [existing, listener];\n      // If we've already got an array, just append.\n    } else if (prepend) {\n      existing.unshift(listener);\n    } else {\n      existing.push(listener);\n    }\n\n    // Check for listener leak\n    m = _getMaxListeners(target);\n    if (m > 0 && existing.length > m && !existing.warned) {\n      existing.warned = true;\n      // No error code for this since it is a Warning\n      // eslint-disable-next-line no-restricted-syntax\n      var w = new Error('Possible EventEmitter memory leak detected. ' +\n                          existing.length + ' ' + String(type) + ' listeners ' +\n                          'added. Use emitter.setMaxListeners() to ' +\n                          'increase limit');\n      w.name = 'MaxListenersExceededWarning';\n      w.emitter = target;\n      w.type = type;\n      w.count = existing.length;\n      ProcessEmitWarning(w);\n    }\n  }\n\n  return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n  return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n    function prependListener(type, listener) {\n      return _addListener(this, type, listener, true);\n    };\n\nfunction onceWrapper() {\n  if (!this.fired) {\n    this.target.removeListener(this.type, this.wrapFn);\n    this.fired = true;\n    if (arguments.length === 0)\n      return this.listener.call(this.target);\n    return this.listener.apply(this.target, arguments);\n  }\n}\n\nfunction _onceWrap(target, type, listener) {\n  var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n  var wrapped = onceWrapper.bind(state);\n  wrapped.listener = listener;\n  state.wrapFn = wrapped;\n  return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n  checkListener(listener);\n  this.on(type, _onceWrap(this, type, listener));\n  return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n    function prependOnceListener(type, listener) {\n      checkListener(listener);\n      this.prependListener(type, _onceWrap(this, type, listener));\n      return this;\n    };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n    function removeListener(type, listener) {\n      var list, events, position, i, originalListener;\n\n      checkListener(listener);\n\n      events = this._events;\n      if (events === undefined)\n        return this;\n\n      list = events[type];\n      if (list === undefined)\n        return this;\n\n      if (list === listener || list.listener === listener) {\n        if (--this._eventsCount === 0)\n          this._events = Object.create(null);\n        else {\n          delete events[type];\n          if (events.removeListener)\n            this.emit('removeListener', type, list.listener || listener);\n        }\n      } else if (typeof list !== 'function') {\n        position = -1;\n\n        for (i = list.length - 1; i >= 0; i--) {\n          if (list[i] === listener || list[i].listener === listener) {\n            originalListener = list[i].listener;\n            position = i;\n            break;\n          }\n        }\n\n        if (position < 0)\n          return this;\n\n        if (position === 0)\n          list.shift();\n        else {\n          spliceOne(list, position);\n        }\n\n        if (list.length === 1)\n          events[type] = list[0];\n\n        if (events.removeListener !== undefined)\n          this.emit('removeListener', type, originalListener || listener);\n      }\n\n      return this;\n    };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n    function removeAllListeners(type) {\n      var listeners, events, i;\n\n      events = this._events;\n      if (events === undefined)\n        return this;\n\n      // not listening for removeListener, no need to emit\n      if (events.removeListener === undefined) {\n        if (arguments.length === 0) {\n          this._events = Object.create(null);\n          this._eventsCount = 0;\n        } else if (events[type] !== undefined) {\n          if (--this._eventsCount === 0)\n            this._events = Object.create(null);\n          else\n            delete events[type];\n        }\n        return this;\n      }\n\n      // emit removeListener for all listeners on all events\n      if (arguments.length === 0) {\n        var keys = Object.keys(events);\n        var key;\n        for (i = 0; i < keys.length; ++i) {\n          key = keys[i];\n          if (key === 'removeListener') continue;\n          this.removeAllListeners(key);\n        }\n        this.removeAllListeners('removeListener');\n        this._events = Object.create(null);\n        this._eventsCount = 0;\n        return this;\n      }\n\n      listeners = events[type];\n\n      if (typeof listeners === 'function') {\n        this.removeListener(type, listeners);\n      } else if (listeners !== undefined) {\n        // LIFO order\n        for (i = listeners.length - 1; i >= 0; i--) {\n          this.removeListener(type, listeners[i]);\n        }\n      }\n\n      return this;\n    };\n\nfunction _listeners(target, type, unwrap) {\n  var events = target._events;\n\n  if (events === undefined)\n    return [];\n\n  var evlistener = events[type];\n  if (evlistener === undefined)\n    return [];\n\n  if (typeof evlistener === 'function')\n    return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n  return unwrap ?\n    unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n  return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n  return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n  if (typeof emitter.listenerCount === 'function') {\n    return emitter.listenerCount(type);\n  } else {\n    return listenerCount.call(emitter, type);\n  }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n  var events = this._events;\n\n  if (events !== undefined) {\n    var evlistener = events[type];\n\n    if (typeof evlistener === 'function') {\n      return 1;\n    } else if (evlistener !== undefined) {\n      return evlistener.length;\n    }\n  }\n\n  return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n  return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n  var copy = new Array(n);\n  for (var i = 0; i < n; ++i)\n    copy[i] = arr[i];\n  return copy;\n}\n\nfunction spliceOne(list, index) {\n  for (; index + 1 < list.length; index++)\n    list[index] = list[index + 1];\n  list.pop();\n}\n\nfunction unwrapListeners(arr) {\n  var ret = new Array(arr.length);\n  for (var i = 0; i < ret.length; ++i) {\n    ret[i] = arr[i].listener || arr[i];\n  }\n  return ret;\n}\n\nfunction once(emitter, name) {\n  return new Promise(function (resolve, reject) {\n    function errorListener(err) {\n      emitter.removeListener(name, resolver);\n      reject(err);\n    }\n\n    function resolver() {\n      if (typeof emitter.removeListener === 'function') {\n        emitter.removeListener('error', errorListener);\n      }\n      resolve([].slice.call(arguments));\n    };\n\n    eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });\n    if (name !== 'error') {\n      addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });\n    }\n  });\n}\n\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n  if (typeof emitter.on === 'function') {\n    eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n  }\n}\n\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n  if (typeof emitter.on === 'function') {\n    if (flags.once) {\n      emitter.once(name, listener);\n    } else {\n      emitter.on(name, listener);\n    }\n  } else if (typeof emitter.addEventListener === 'function') {\n    // EventTarget does not have `error` event semantics like Node\n    // EventEmitters, we do not listen for `error` events here.\n    emitter.addEventListener(name, function wrapListener(arg) {\n      // IE does not have builtin `{ once: true }` support so we\n      // have to do it manually.\n      if (flags.once) {\n        emitter.removeEventListener(name, wrapListener);\n      }\n      listener(arg);\n    });\n  } else {\n    throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n  }\n}\n"]} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/dist/api.min.js b/includes/external/matrix/node_modules/matrix-widget-api/dist/api.min.js deleted file mode 100644 index 6f89502..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/dist/api.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(e){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=e();else if("function"==typeof define&&define.amd)define([],e);else{("undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this).mxwidgets=e()}}((function(){var e,t=function(e){var t;return function(r){return t||e(t={exports:{},parent:r},t.exports),t.exports}},r=t((function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=s({});Object.keys(r).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===r[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return r[e]}}))}));var c=a({});Object.keys(c).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===c[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return c[e]}}))})),Object.keys(K).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===K[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return K[e]}}))})),Object.keys(ee).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===ee[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return ee[e]}}))}));var l=u({});Object.keys(l).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===l[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return l[e]}}))})),Object.keys(te).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===te[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return te[e]}}))})),Object.keys(re).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===re[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return re[e]}}))})),Object.keys(ne).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===ne[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return ne[e]}}))})),Object.keys(ie).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===ie[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return ie[e]}}))})),Object.keys(I).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===I[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return I[e]}}))})),Object.keys(oe).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===oe[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return oe[e]}}))})),Object.keys(ae).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===ae[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return ae[e]}}))})),Object.keys(se).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===se[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return se[e]}}))})),Object.keys(P).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===P[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return P[e]}}))})),Object.keys(E).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===E[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return E[e]}}))})),Object.keys(C).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===C[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return C[e]}}))})),Object.keys(Y).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===Y[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return Y[e]}}))})),Object.keys(ue).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===ue[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return ue[e]}}))})),Object.keys(ce).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===ce[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return ce[e]}}))})),Object.keys(le).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===le[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return le[e]}}))})),Object.keys(de).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===de[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return de[e]}}))})),Object.keys(fe).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===fe[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return fe[e]}}))})),Object.keys(pe).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===pe[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return pe[e]}}))})),Object.keys(ve).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===ve[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return ve[e]}}))})),Object.keys(T).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===T[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return T[e]}}))})),Object.keys(he).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===he[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return he[e]}}))})),Object.keys(me).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===me[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return me[e]}}))})),Object.keys(be).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===be[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return be[e]}}))})),Object.keys(D).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===D[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return D[e]}}))})),Object.keys(we).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===we[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return we[e]}}))})),Object.keys(_e).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===_e[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return _e[e]}}))})),Object.keys(Oe).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===Oe[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return Oe[e]}}))})),Object.keys(ke).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===ke[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return ke[e]}}))})),Object.keys(Ee).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===Ee[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return Ee[e]}}))})),Object.keys(Se).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===Se[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return Se[e]}}))})),Object.keys(je).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===je[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return je[e]}}))})),Object.keys(Ce).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===Ce[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return Ce[e]}}))})),Object.keys(xe).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===xe[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return xe[e]}}))})),Object.keys(F).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===F[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return F[e]}}))})),Object.keys(Ae).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===Ae[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return Ae[e]}}))})),Object.keys(We).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===We[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return We[e]}}))}));var d=o({});Object.keys(d).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===d[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return d[e]}}))}));var f=i({});Object.keys(f).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===f[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return f[e]}}))})),Object.keys(Pe).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===Pe[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return Pe[e]}}))})),Object.keys(J).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===J[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return J[e]}}))}));var p=n({});Object.keys(p).forEach((function(e){"default"!==e&&"__esModule"!==e&&(e in t&&t[e]===p[e]||Object.defineProperty(t,e,{enumerable:!0,get:function(){return p[e]}}))}))})),n=t((function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.WidgetDriver=void 0;var n=r({});function i(e,t){for(var r=0;re.length)&&(t=e.length);for(var r=0,n=new Array(t);r=e.length?{done:!0}:{done:!1,value:e[i++]}},e:function(e){throw e},f:o}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var a,s=!0,u=!1;return{s:function(){r=r.call(e)},n:function(){var e=r.next();return s=e.done,e},e:function(e){u=!0,a=e},f:function(){try{s||null==r.return||r.return()}finally{if(u)throw a}}}}(t);try{for(o.s();!(r=o.n()).done;){var a=r.value,s=e.parseRoomWidget(a);s&&i.push(s)}}catch(u){o.e(u)}finally{o.f()}return i}},{key:"parseRoomWidget",value:function(t){if(!t)return null;if("m.widget"!==t.type&&"im.vector.modular.widgets"!==t.type)return null;var r=t.content||{},n={id:t.state_key,creatorUserId:r.creatorUserId||t.sender,name:r.name,type:r.type,url:r.url,waitForIframeLoad:r.waitForIframeLoad,data:r.data};return e.processEstimatedWidget(n)}},{key:"processEstimatedWidget",value:function(e){return e.id&&e.creatorUserId&&e.type&&(0,Ae.isValidUrl)(e.url)?new r.Widget(e):null}}],null&&i(t.prototype,null),o&&i(t,o),Object.defineProperty(t,"prototype",{writable:!1}),e}();t.WidgetParser=a})),o=t((function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.Widget=void 0;var n=r({});function i(e,t){for(var r=0;r=0;--i){var o=this.tryEntries[i],a=o.completion;if("root"===o.tryLoc)return r("end");if(o.tryLoc<=this.prev){var s=n.call(o,"catchLoc"),u=n.call(o,"finallyLoc");if(s&&u){if(this.prev=0;--r){var i=this.tryEntries[r];if(i.tryLoc<=this.prev&&n.call(i,"finallyLoc")&&this.prev=0;--t){var r=this.tryEntries[t];if(r.finallyLoc===e)return this.complete(r.completion,r.afterLoc),E(r),f}},catch:function(e){for(var t=this.tryEntries.length-1;t>=0;--t){var r=this.tryEntries[t];if(r.tryLoc===e){var n=r.completion;if("throw"===n.type){var i=n.arg;E(r)}return i}}throw new Error("illegal catch attempt")},delegateYield:function(e,t,r){return this.delegate={iterator:j(e),resultName:t,nextLoc:r},"next"===this.method&&(this.arg=void 0),f}},e}function o(e,t,r,n,i,o,a){try{var s=e[o](a),u=s.value}catch(c){return void r(c)}s.done?t(u):Promise.resolve(u).then(n,i)}function a(e){return function(){var t=this,r=arguments;return new Promise((function(n,i){var a=e.apply(t,r);function s(e){o(a,n,i,s,u,"next",e)}function u(e){o(a,n,i,s,u,"throw",e)}s(void 0)}))}}function s(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=new Array(t);r1&&void 0!==arguments[1]?arguments[1]:null;return this.allowedEvents.some((function(r){return r.matchesAsRoomEvent(F.EventDirection.Send,e,t)}))}},{key:"canSendStateEvent",value:function(e,t){return this.allowedEvents.some((function(r){return r.matchesAsStateEvent(F.EventDirection.Send,e,t)}))}},{key:"canSendToDeviceEvent",value:function(e){return this.allowedEvents.some((function(t){return t.matchesAsToDeviceEvent(F.EventDirection.Send,e)}))}},{key:"canReceiveRoomEvent",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;return this.allowedEvents.some((function(r){return r.matchesAsRoomEvent(F.EventDirection.Receive,e,t)}))}},{key:"canReceiveStateEvent",value:function(e,t){return this.allowedEvents.some((function(r){return r.matchesAsStateEvent(F.EventDirection.Receive,e,t)}))}},{key:"canReceiveToDeviceEvent",value:function(e){return this.allowedEvents.some((function(t){return t.matchesAsToDeviceEvent(F.EventDirection.Receive,e)}))}},{key:"stop",value:function(){this.isStopped=!0,this.transport.stop()}},{key:"beginCapabilities",value:function(){var e,t=this;this.emit("preparing"),this.transport.send(P.WidgetApiToWidgetAction.Capabilities,{}).then((function(r){return e=r.capabilities,t.driver.validateCapabilities(new Set(r.capabilities))})).then((function(r){console.log("Widget ".concat(t.widget.id," is allowed capabilities:"),Array.from(r)),t.allowedCapabilities=r,t.allowedEvents=F.WidgetEventCapability.findEventCapabilities(r),t.notifyCapabilities(e),t.emit("ready")}))}},{key:"notifyCapabilities",value:function(e){var t=this;this.transport.send(P.WidgetApiToWidgetAction.NotifyCapabilities,{requested:e,approved:Array.from(this.allowedCapabilities)}).catch((function(e){console.warn("non-fatal error notifying widget of approved capabilities:",e)})).then((function(){t.emit("capabilitiesNotified")}))}},{key:"onIframeLoad",value:function(e){this.widget.waitForIframeLoad?this.beginCapabilities():this.contentLoadedActionSent=!1}},{key:"handleContentLoadedAction",value:function(e){if(this.contentLoadedActionSent)throw new Error("Improper sequence: ContentLoaded Action can only be send once after the widget loaded and should only be used if waitForIframeLoad is false (default=true)");this.widget.waitForIframeLoad?this.transport.reply(e,{error:{message:"Improper sequence: not expecting ContentLoaded event if waitForIframLoad is true (default=true)"}}):(this.transport.reply(e,{}),this.beginCapabilities()),this.contentLoadedActionSent=!0}},{key:"replyVersions",value:function(e){this.transport.reply(e,{supported_versions:C.CurrentApiVersions})}},{key:"handleCapabilitiesRenegotiate",value:function(e){var t,r=this;this.transport.reply(e,{});var n=(null===(t=e.data)||void 0===t?void 0:t.capabilities)||[],i=new Set(n.filter((function(e){return!r.hasCapability(e)})));if(0===i.size)return this.notifyCapabilities([]);this.driver.validateCapabilities(i).then((function(e){return e.forEach((function(e){return r.allowedCapabilities.add(e)})),F.WidgetEventCapability.findEventCapabilities(e).forEach((function(e){return r.allowedEvents.push(e)})),r.notifyCapabilities(Array.from(i))}))}},{key:"handleNavigate",value:function(e){var t,r,n=this;if(!this.hasCapability(Y.MatrixCapabilities.MSC2931Navigate))return this.transport.reply(e,{error:{message:"Missing capability"}});if(null===(t=e.data)||void 0===t||!t.uri||null===(r=e.data)||void 0===r||!r.uri.toString().startsWith("https://matrix.to/#"))return this.transport.reply(e,{error:{message:"Invalid matrix.to URI"}});var i=function(t){return console.error("[ClientWidgetApi] Failed to handle navigation: ",t),n.transport.reply(e,{error:{message:"Error handling navigation"}})};try{this.driver.navigate(e.data.uri.toString()).catch((function(e){return i(e)})).then((function(){return n.transport.reply(e,{})}))}catch(o){return i(o)}}},{key:"handleOIDC",value:function(e){var t=this,r=1,n=function(n,i){return i=i||{},r>1?t.transport.send(P.WidgetApiToWidgetAction.OpenIDCredentials,d({state:n,original_request_id:e.requestId},i)):t.transport.reply(e,d({state:n},i))},i=function(i){return console.error("[ClientWidgetApi] Failed to handle OIDC: ",i),r>1?n(T.OpenIDRequestState.Blocked):t.transport.reply(e,{error:{message:i}})},o=new J.SimpleObservable((function(e){return e.state===T.OpenIDRequestState.PendingUserConfirmation&&r>1?(o.close(),i("client provided out-of-phase response to OIDC flow")):e.state===T.OpenIDRequestState.PendingUserConfirmation?(n(e.state),void r++):e.state!==T.OpenIDRequestState.Allowed||e.token?(e.state===T.OpenIDRequestState.Blocked&&(e.token=void 0),o.close(),n(e.state,e.token)):i("client provided invalid OIDC token for an allowed request")}));this.driver.askOpenID(o)}},{key:"handleReadEvents",value:function(e){var t=this;if(!e.data.type)return this.transport.reply(e,{error:{message:"Invalid request - missing event type"}});if(void 0!==e.data.limit&&(!e.data.limit||e.data.limit<0))return this.transport.reply(e,{error:{message:"Invalid request - limit out of range"}});var r=null;if(e.data.room_ids){r=e.data.room_ids,Array.isArray(r)||(r=[r]);var n,i=function(e,t){var r="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!r){if(Array.isArray(e)||(r=function(e,t){if(e){if("string"==typeof e)return s(e,void 0);var r=Object.prototype.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?s(e,void 0):void 0}}(e))||t&&e&&"number"==typeof e.length){r&&(e=r);var n=0,i=function(){};return{s:i,n:function(){return n>=e.length?{done:!0}:{done:!1,value:e[n++]}},e:function(e){throw e},f:i}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var o,a=!0,u=!1;return{s:function(){r=r.call(e)},n:function(){var e=r.next();return a=e.done,e},e:function(e){u=!0,o=e},f:function(){try{a||null==r.return||r.return()}finally{if(u)throw o}}}}(r);try{for(i.s();!(n=i.n()).done;){var o=n.value;if(!this.canUseRoomTimeline(o))return this.transport.reply(e,{error:{message:"Unable to access room timeline: ".concat(o)}})}}catch(l){i.e(l)}finally{i.f()}}var a=e.data.limit||0,u=Promise.resolve([]);if(void 0!==e.data.state_key){var c=!0===e.data.state_key?void 0:e.data.state_key.toString();if(!this.canReceiveStateEvent(e.data.type,null!=c?c:null))return this.transport.reply(e,{error:{message:"Cannot read state events of this type"}});u=this.driver.readStateEvents(e.data.type,c,a,r)}else{if(!this.canReceiveRoomEvent(e.data.type,e.data.msgtype))return this.transport.reply(e,{error:{message:"Cannot read room events of this type"}});u=this.driver.readRoomEvents(e.data.type,e.data.msgtype,a,r)}return u.then((function(r){return t.transport.reply(e,{events:r})}))}},{key:"handleSendEvent",value:function(e){var t,r=this;if(!e.data.type)return this.transport.reply(e,{error:{message:"Invalid request - missing event type"}});if(e.data.room_id&&!this.canUseRoomTimeline(e.data.room_id))return this.transport.reply(e,{error:{message:"Unable to access room timeline: ".concat(e.data.room_id)}});if(null!==e.data.state_key&&void 0!==e.data.state_key){if(!this.canSendStateEvent(e.data.type,e.data.state_key))return this.transport.reply(e,{error:{message:"Cannot send state events of this type"}});t=this.driver.sendEvent(e.data.type,e.data.content||{},e.data.state_key,e.data.room_id)}else{var n=e.data.content||{},i=n.msgtype;if(!this.canSendRoomEvent(e.data.type,i))return this.transport.reply(e,{error:{message:"Cannot send room events of this type"}});t=this.driver.sendEvent(e.data.type,n,null,e.data.room_id)}t.then((function(t){return r.transport.reply(e,{room_id:t.roomId,event_id:t.eventId})})).catch((function(t){return console.error("error sending event: ",t),r.transport.reply(e,{error:{message:"Error sending event"}})}))}},{key:"handleSendToDevice",value:(j=a(i().mark((function e(t){return i().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(t.data.type){e.next=5;break}return e.next=3,this.transport.reply(t,{error:{message:"Invalid request - missing event type"}});case 3:e.next=32;break;case 5:if(t.data.messages){e.next=10;break}return e.next=8,this.transport.reply(t,{error:{message:"Invalid request - missing event contents"}});case 8:e.next=32;break;case 10:if("boolean"==typeof t.data.encrypted){e.next=15;break}return e.next=13,this.transport.reply(t,{error:{message:"Invalid request - missing encryption flag"}});case 13:e.next=32;break;case 15:if(this.canSendToDeviceEvent(t.data.type)){e.next=20;break}return e.next=18,this.transport.reply(t,{error:{message:"Cannot send to-device events of this type"}});case 18:e.next=32;break;case 20:return e.prev=20,e.next=23,this.driver.sendToDevice(t.data.type,t.data.encrypted,t.data.messages);case 23:return e.next=25,this.transport.reply(t,{});case 25:e.next=32;break;case 27:return e.prev=27,e.t0=e.catch(20),console.error("error sending to-device event",e.t0),e.next=32,this.transport.reply(t,{error:{message:"Error sending event"}});case 32:case"end":return e.stop()}}),e,this,[[20,27]])}))),function(e){return j.apply(this,arguments)})},{key:"pollTurnServers",value:(S=a(i().mark((function e(t,r){var n,o,a,s,u,c;return i().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.prev=0,e.next=3,this.transport.send(P.WidgetApiToWidgetAction.UpdateTurnServers,r);case 3:n=!1,o=!1,e.prev=5,s=m(t);case 7:return e.next=9,s.next();case 9:if(!(n=!(u=e.sent).done)){e.next=16;break}return c=u.value,e.next=13,this.transport.send(P.WidgetApiToWidgetAction.UpdateTurnServers,c);case 13:n=!1,e.next=7;break;case 16:e.next=22;break;case 18:e.prev=18,e.t0=e.catch(5),o=!0,a=e.t0;case 22:if(e.prev=22,e.prev=23,!n||null==s.return){e.next=27;break}return e.next=27,s.return();case 27:if(e.prev=27,!o){e.next=30;break}throw a;case 30:return e.finish(27);case 31:return e.finish(22);case 32:e.next=37;break;case 34:e.prev=34,e.t1=e.catch(0),console.error("error polling for TURN servers",e.t1);case 37:case"end":return e.stop()}}),e,this,[[0,34],[5,18,22,32],[23,,27,31]])}))),function(e,t){return S.apply(this,arguments)})},{key:"handleWatchTurnServers",value:(k=a(i().mark((function e(t){var r,n,o,a;return i().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(this.hasCapability(Y.MatrixCapabilities.MSC3846TurnServers)){e.next=5;break}return e.next=3,this.transport.reply(t,{error:{message:"Missing capability"}});case 3:e.next=30;break;case 5:if(!this.turnServers){e.next=10;break}return e.next=8,this.transport.reply(t,{});case 8:e.next=30;break;case 10:return e.prev=10,r=this.driver.getTurnServers(),e.next=14,r.next();case 14:if(n=e.sent,o=n.done,a=n.value,!o){e.next=19;break}throw new Error("Client refuses to provide any TURN servers");case 19:return e.next=21,this.transport.reply(t,{});case 21:this.pollTurnServers(r,a),this.turnServers=r,e.next=30;break;case 25:return e.prev=25,e.t0=e.catch(10),console.error("error getting first TURN server results",e.t0),e.next=30,this.transport.reply(t,{error:{message:"TURN servers not available"}});case 30:case"end":return e.stop()}}),e,this,[[10,25]])}))),function(e){return k.apply(this,arguments)})},{key:"handleUnwatchTurnServers",value:(O=a(i().mark((function e(t){return i().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(this.hasCapability(Y.MatrixCapabilities.MSC3846TurnServers)){e.next=5;break}return e.next=3,this.transport.reply(t,{error:{message:"Missing capability"}});case 3:e.next=15;break;case 5:if(this.turnServers){e.next=10;break}return e.next=8,this.transport.reply(t,{});case 8:e.next=15;break;case 10:return e.next=12,this.turnServers.return(void 0);case 12:return this.turnServers=null,e.next=15,this.transport.reply(t,{});case 15:case"end":return e.stop()}}),e,this)}))),function(e){return O.apply(this,arguments)})},{key:"handleReadRelations",value:(_=a(i().mark((function e(t){var r,n,o=this;return i().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(t.data.event_id){e.next=2;break}return e.abrupt("return",this.transport.reply(t,{error:{message:"Invalid request - missing event ID"}}));case 2:if(!(void 0!==t.data.limit&&t.data.limit<0)){e.next=4;break}return e.abrupt("return",this.transport.reply(t,{error:{message:"Invalid request - limit out of range"}}));case 4:if(void 0===t.data.room_id||this.canUseRoomTimeline(t.data.room_id)){e.next=6;break}return e.abrupt("return",this.transport.reply(t,{error:{message:"Unable to access room timeline: ".concat(t.data.room_id)}}));case 6:return e.prev=6,e.next=9,this.driver.readEventRelations(t.data.event_id,t.data.room_id,t.data.rel_type,t.data.event_type,t.data.from,t.data.to,t.data.limit,t.data.direction);case 9:return r=e.sent,n=r.chunk.filter((function(e){return void 0!==e.state_key?o.canReceiveStateEvent(e.type,e.state_key):o.canReceiveRoomEvent(e.type,e.content.msgtype)})),e.abrupt("return",this.transport.reply(t,{chunk:n,prev_batch:r.prevBatch,next_batch:r.nextBatch}));case 14:return e.prev=14,e.t0=e.catch(6),console.error("error getting the relations",e.t0),e.next=19,this.transport.reply(t,{error:{message:"Unexpected error while reading relations"}});case 19:case"end":return e.stop()}}),e,this,[[6,14]])}))),function(e){return _.apply(this,arguments)})},{key:"handleUserDirectorySearch",value:(w=a(i().mark((function e(t){var r;return i().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(this.hasCapability(Y.MatrixCapabilities.MSC3973UserDirectorySearch)){e.next=2;break}return e.abrupt("return",this.transport.reply(t,{error:{message:"Missing capability"}}));case 2:if("string"==typeof t.data.search_term){e.next=4;break}return e.abrupt("return",this.transport.reply(t,{error:{message:"Invalid request - missing search term"}}));case 4:if(!(void 0!==t.data.limit&&t.data.limit<0)){e.next=6;break}return e.abrupt("return",this.transport.reply(t,{error:{message:"Invalid request - limit out of range"}}));case 6:return e.prev=6,e.next=9,this.driver.searchUserDirectory(t.data.search_term,t.data.limit);case 9:return r=e.sent,e.abrupt("return",this.transport.reply(t,{limited:r.limited,results:r.results.map((function(e){return{user_id:e.userId,display_name:e.displayName,avatar_url:e.avatarUrl}}))}));case 13:return e.prev=13,e.t0=e.catch(6),console.error("error searching in the user directory",e.t0),e.next=18,this.transport.reply(t,{error:{message:"Unexpected error while searching in the user directory"}});case 18:case"end":return e.stop()}}),e,this,[[6,13]])}))),function(e){return w.apply(this,arguments)})},{key:"handleMessage",value:function(e){if(!this.isStopped){var t=new CustomEvent("action:".concat(e.detail.action),{detail:e.detail,cancelable:!0});if(this.emit("action:".concat(e.detail.action),t),!t.defaultPrevented)switch(e.detail.action){case P.WidgetApiFromWidgetAction.ContentLoaded:return this.handleContentLoadedAction(e.detail);case P.WidgetApiFromWidgetAction.SupportedApiVersions:return this.replyVersions(e.detail);case P.WidgetApiFromWidgetAction.SendEvent:return this.handleSendEvent(e.detail);case P.WidgetApiFromWidgetAction.SendToDevice:return this.handleSendToDevice(e.detail);case P.WidgetApiFromWidgetAction.GetOpenIDCredentials:return this.handleOIDC(e.detail);case P.WidgetApiFromWidgetAction.MSC2931Navigate:return this.handleNavigate(e.detail);case P.WidgetApiFromWidgetAction.MSC2974RenegotiateCapabilities:return this.handleCapabilitiesRenegotiate(e.detail);case P.WidgetApiFromWidgetAction.MSC2876ReadEvents:return this.handleReadEvents(e.detail);case P.WidgetApiFromWidgetAction.WatchTurnServers:return this.handleWatchTurnServers(e.detail);case P.WidgetApiFromWidgetAction.UnwatchTurnServers:return this.handleUnwatchTurnServers(e.detail);case P.WidgetApiFromWidgetAction.MSC3869ReadRelations:return this.handleReadRelations(e.detail);case P.WidgetApiFromWidgetAction.MSC3973UserDirectorySearch:return this.handleUserDirectorySearch(e.detail);default:return this.transport.reply(e.detail,{error:{message:"Unknown or unsupported action: "+e.detail.action}})}}}},{key:"takeScreenshot",value:function(){return this.transport.send(P.WidgetApiToWidgetAction.TakeScreenshot,{})}},{key:"updateVisibility",value:function(e){return this.transport.send(P.WidgetApiToWidgetAction.UpdateVisibility,{visible:e})}},{key:"sendWidgetConfig",value:function(e){return this.transport.send(P.WidgetApiToWidgetAction.WidgetConfig,e).then()}},{key:"notifyModalWidgetButtonClicked",value:function(e){return this.transport.send(P.WidgetApiToWidgetAction.ButtonClicked,{id:e}).then()}},{key:"notifyModalWidgetClose",value:function(e){return this.transport.send(P.WidgetApiToWidgetAction.CloseModalWidget,e).then()}},{key:"feedEvent",value:(b=a(i().mark((function e(t,r){var n;return i().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(t.room_id===r||this.canUseRoomTimeline(t.room_id)){e.next=2;break}return e.abrupt("return");case 2:if(void 0===t.state_key||null===t.state_key){e.next=7;break}if(this.canReceiveStateEvent(t.type,t.state_key)){e.next=5;break}return e.abrupt("return");case 5:e.next=9;break;case 7:if(this.canReceiveRoomEvent(t.type,null===(n=t.content)||void 0===n?void 0:n.msgtype)){e.next=9;break}return e.abrupt("return");case 9:return e.next=11,this.transport.send(P.WidgetApiToWidgetAction.SendEvent,t);case 11:case"end":return e.stop()}}),e,this)}))),function(e,t){return b.apply(this,arguments)})},{key:"feedToDevice",value:(g=a(i().mark((function e(t,r){return i().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(!this.canReceiveToDeviceEvent(t.type)){e.next=3;break}return e.next=3,this.transport.send(P.WidgetApiToWidgetAction.SendToDevice,d(d({},t),{},{encrypted:r}));case 3:case"end":return e.stop()}}),e,this)}))),function(e,t){return g.apply(this,arguments)})}])&&f(t.prototype,o),Object.defineProperty(t,"prototype",{writable:!1}),A}();t.ClientWidgetApi=b})),s=t((function(e,t){"use strict";function r(e){return(r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}Object.defineProperty(t,"__esModule",{value:!0}),t.WidgetApi=void 0;var n=u({});function i(){i=function(){return e};var e={},t=Object.prototype,n=t.hasOwnProperty,o="function"==typeof Symbol?Symbol:{},a=o.iterator||"@@iterator",s=o.asyncIterator||"@@asyncIterator",u=o.toStringTag||"@@toStringTag";function c(e,t,r){return Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}),e[t]}try{c({},"")}catch(x){c=function(e,t,r){return e[t]=r}}function l(e,t,r,n){var i=t&&t.prototype instanceof p?t:p,o=Object.create(i.prototype),a=new S(n||[]);return o._invoke=function(e,t,r){var n="suspendedStart";return function(i,o){if("executing"===n)throw new Error("Generator is already running");if("completed"===n){if("throw"===i)throw o;return{value:void 0,done:!0}}for(r.method=i,r.arg=o;;){var a=r.delegate;if(a){var s=O(a,r);if(s){if(s===f)continue;return s}}if("next"===r.method)r.sent=r._sent=r.arg;else if("throw"===r.method){if("suspendedStart"===n)throw n="completed",r.arg;r.dispatchException(r.arg)}else"return"===r.method&&r.abrupt("return",r.arg);n="executing";var u=d(e,t,r);if("normal"===u.type){if(n=r.done?"completed":"suspendedYield",u.arg===f)continue;return{value:u.arg,done:r.done}}"throw"===u.type&&(n="completed",r.method="throw",r.arg=u.arg)}}}(e,r,a),o}function d(e,t,r){try{return{type:"normal",arg:e.call(t,r)}}catch(x){return{type:"throw",arg:x}}}e.wrap=l;var f={};function p(){}function v(){}function h(){}var y={};c(y,a,(function(){return this}));var m=Object.getPrototypeOf,g=m&&m(m(j([])));g&&g!==t&&n.call(g,a)&&(y=g);var b=h.prototype=p.prototype=Object.create(y);function w(e){["next","throw","return"].forEach((function(t){c(e,t,(function(e){return this._invoke(t,e)}))}))}function _(e,t){var i;this._invoke=function(o,a){function s(){return new t((function(i,s){!function i(o,a,s,u){var c=d(e[o],e,a);if("throw"!==c.type){var l=c.arg,f=l.value;return f&&"object"==r(f)&&n.call(f,"__await")?t.resolve(f.__await).then((function(e){i("next",e,s,u)}),(function(e){i("throw",e,s,u)})):t.resolve(f).then((function(e){l.value=e,s(l)}),(function(e){return i("throw",e,s,u)}))}u(c.arg)}(o,a,i,s)}))}return i=i?i.then(s,s):s()}}function O(e,t){var r=e.iterator[t.method];if(void 0===r){if(t.delegate=null,"throw"===t.method){if(e.iterator.return&&(t.method="return",t.arg=void 0,O(e,t),"throw"===t.method))return f;t.method="throw",t.arg=new TypeError("The iterator does not provide a 'throw' method")}return f}var n=d(r,e.iterator,t.arg);if("throw"===n.type)return t.method="throw",t.arg=n.arg,t.delegate=null,f;var i=n.arg;return i?i.done?(t[e.resultName]=i.value,t.next=e.nextLoc,"return"!==t.method&&(t.method="next",t.arg=void 0),t.delegate=null,f):i:(t.method="throw",t.arg=new TypeError("iterator result is not an object"),t.delegate=null,f)}function k(e){var t={tryLoc:e[0]};1 in e&&(t.catchLoc=e[1]),2 in e&&(t.finallyLoc=e[2],t.afterLoc=e[3]),this.tryEntries.push(t)}function E(e){var t=e.completion||{};t.type="normal",delete t.arg,e.completion=t}function S(e){this.tryEntries=[{tryLoc:"root"}],e.forEach(k,this),this.reset(!0)}function j(e){if(e){var t=e[a];if(t)return t.call(e);if("function"==typeof e.next)return e;if(!isNaN(e.length)){var r=-1,i=function t(){for(;++r=0;--i){var o=this.tryEntries[i],a=o.completion;if("root"===o.tryLoc)return r("end");if(o.tryLoc<=this.prev){var s=n.call(o,"catchLoc"),u=n.call(o,"finallyLoc");if(s&&u){if(this.prev=0;--r){var i=this.tryEntries[r];if(i.tryLoc<=this.prev&&n.call(i,"finallyLoc")&&this.prev=0;--t){var r=this.tryEntries[t];if(r.finallyLoc===e)return this.complete(r.completion,r.afterLoc),E(r),f}},catch:function(e){for(var t=this.tryEntries.length-1;t>=0;--t){var r=this.tryEntries[t];if(r.tryLoc===e){var n=r.completion;if("throw"===n.type){var i=n.arg;E(r)}return i}}throw new Error("illegal catch attempt")},delegateYield:function(e,t,r){return this.delegate={iterator:j(e),resultName:t,nextLoc:r},"next"===this.method&&(this.arg=void 0),f}},e}function o(e,t,r,n,i,o,a){try{var s=e[o](a),u=s.value}catch(c){return void r(c)}s.done?t(u):Promise.resolve(u).then(n,i)}function a(e){return function(){var t=this,r=arguments;return new Promise((function(n,i){var a=e.apply(t,r);function s(e){o(a,n,i,s,u,"next",e)}function u(e){o(a,n,i,s,u,"throw",e)}s(void 0)}))}}function s(e,t){for(var r=0;r0&&void 0!==arguments[0]?arguments[0]:null,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;if(function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,w),(e=b.call(this)).clientOrigin=r,p(d(e),"transport",void 0),p(d(e),"capabilitiesFinished",!1),p(d(e),"supportsMSC2974Renegotiate",!1),p(d(e),"requestedCapabilities",[]),p(d(e),"approvedCapabilities",void 0),p(d(e),"cachedClientVersions",void 0),p(d(e),"turnServerWatchers",0),!window.parent)throw new Error("No parent window. This widget doesn't appear to be embedded properly.");return e.transport=new n.PostmessageTransport(E.WidgetApiDirection.FromWidget,t,window.parent,window),e.transport.targetOrigin=r,e.transport.on("message",e.handleMessage.bind(d(e))),e}return t=w,(o=[{key:"hasCapability",value:function(e){return Array.isArray(this.approvedCapabilities)?this.approvedCapabilities.includes(e):this.requestedCapabilities.includes(e)}},{key:"requestCapability",value:function(e){if(this.capabilitiesFinished&&!this.supportsMSC2974Renegotiate)throw new Error("Capabilities have already been negotiated");this.requestedCapabilities.push(e)}},{key:"requestCapabilities",value:function(e){var t=this;e.forEach((function(e){return t.requestCapability(e)}))}},{key:"requestCapabilityForRoomTimeline",value:function(e){this.requestCapability("org.matrix.msc2762.timeline:".concat(e))}},{key:"requestCapabilityToSendState",value:function(e,t){this.requestCapability(F.WidgetEventCapability.forStateEvent(F.EventDirection.Send,e,t).raw)}},{key:"requestCapabilityToReceiveState",value:function(e,t){this.requestCapability(F.WidgetEventCapability.forStateEvent(F.EventDirection.Receive,e,t).raw)}},{key:"requestCapabilityToSendToDevice",value:function(e){this.requestCapability(F.WidgetEventCapability.forToDeviceEvent(F.EventDirection.Send,e).raw)}},{key:"requestCapabilityToReceiveToDevice",value:function(e){this.requestCapability(F.WidgetEventCapability.forToDeviceEvent(F.EventDirection.Receive,e).raw)}},{key:"requestCapabilityToSendEvent",value:function(e){this.requestCapability(F.WidgetEventCapability.forRoomEvent(F.EventDirection.Send,e).raw)}},{key:"requestCapabilityToReceiveEvent",value:function(e){this.requestCapability(F.WidgetEventCapability.forRoomEvent(F.EventDirection.Receive,e).raw)}},{key:"requestCapabilityToSendMessage",value:function(e){this.requestCapability(F.WidgetEventCapability.forRoomMessageEvent(F.EventDirection.Send,e).raw)}},{key:"requestCapabilityToReceiveMessage",value:function(e){this.requestCapability(F.WidgetEventCapability.forRoomMessageEvent(F.EventDirection.Receive,e).raw)}},{key:"requestOpenIDConnectToken",value:function(){var e=this;return new Promise((function(t,r){e.transport.sendComplete(P.WidgetApiFromWidgetAction.GetOpenIDCredentials,{}).then((function(n){var i=n.response;i.state===T.OpenIDRequestState.Allowed?t(i):i.state===T.OpenIDRequestState.Blocked?r(new Error("User declined to verify their identity")):i.state===T.OpenIDRequestState.PendingUserConfirmation?e.on("action:".concat(P.WidgetApiToWidgetAction.OpenIDCredentials),(function o(a){a.preventDefault();var s=a.detail;s.data.original_request_id===n.requestId&&(s.data.state===T.OpenIDRequestState.Allowed?(t(s.data),e.transport.reply(s,{})):s.data.state===T.OpenIDRequestState.Blocked?(r(new Error("User declined to verify their identity")),e.transport.reply(s,{})):(r(new Error("Invalid state on reply: "+i.state)),e.transport.reply(s,{error:{message:"Invalid state"}})),e.off("action:".concat(P.WidgetApiToWidgetAction.OpenIDCredentials),o))})):r(new Error("Invalid state: "+i.state))})).catch(r)}))}},{key:"updateRequestedCapabilities",value:function(){return this.transport.send(P.WidgetApiFromWidgetAction.MSC2974RenegotiateCapabilities,{capabilities:this.requestedCapabilities}).then()}},{key:"sendContentLoaded",value:function(){return this.transport.send(P.WidgetApiFromWidgetAction.ContentLoaded,{}).then()}},{key:"sendSticker",value:function(e){return this.transport.send(P.WidgetApiFromWidgetAction.SendSticker,e).then()}},{key:"setAlwaysOnScreen",value:function(e){return this.transport.send(P.WidgetApiFromWidgetAction.UpdateAlwaysOnScreen,{value:e}).then((function(e){return e.success}))}},{key:"openModalWidget",value:function(e,t){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:[],n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:I.MatrixWidgetType.Custom;return this.transport.send(P.WidgetApiFromWidgetAction.OpenModalWidget,{type:i,url:e,name:t,buttons:r,data:n}).then()}},{key:"closeModalWidget",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return this.transport.send(P.WidgetApiFromWidgetAction.CloseModalWidget,e).then()}},{key:"sendRoomEvent",value:function(e,t,r){return this.transport.send(P.WidgetApiFromWidgetAction.SendEvent,{type:e,content:t,room_id:r})}},{key:"sendStateEvent",value:function(e,t,r,n){return this.transport.send(P.WidgetApiFromWidgetAction.SendEvent,{type:e,content:r,state_key:t,room_id:n})}},{key:"sendToDevice",value:function(e,t,r){return this.transport.send(P.WidgetApiFromWidgetAction.SendToDevice,{type:e,encrypted:t,messages:r})}},{key:"readRoomEvents",value:function(e,t,r,n){var i={type:e,msgtype:r};return void 0!==t&&(i.limit=t),n&&(n.includes(K.Symbols.AnyRoom)?i.room_ids=K.Symbols.AnyRoom:i.room_ids=n),this.transport.send(P.WidgetApiFromWidgetAction.MSC2876ReadEvents,i).then((function(e){return e.events}))}},{key:"readEventRelations",value:(g=a(i().mark((function e(t,r,n,o,a,s,u,c){var l;return i().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,this.getClientVersions();case 2:if(e.sent.includes(C.UnstableApiVersion.MSC3869)){e.next=5;break}throw new Error("The read_relations action is not supported by the client.");case 5:return l={event_id:t,rel_type:n,event_type:o,room_id:r,to:u,from:s,limit:a,direction:c},e.abrupt("return",this.transport.send(P.WidgetApiFromWidgetAction.MSC3869ReadRelations,l));case 7:case"end":return e.stop()}}),e,this)}))),function(e,t,r,n,i,o,a,s){return g.apply(this,arguments)})},{key:"readStateEvents",value:function(e,t,r,n){var i={type:e,state_key:void 0===r||r};return void 0!==t&&(i.limit=t),n&&(n.includes(K.Symbols.AnyRoom)?i.room_ids=K.Symbols.AnyRoom:i.room_ids=n),this.transport.send(P.WidgetApiFromWidgetAction.MSC2876ReadEvents,i).then((function(e){return e.events}))}},{key:"setModalButtonEnabled",value:function(e,t){if(e===D.BuiltInModalButtonID.Close)throw new Error("The close button cannot be disabled");return this.transport.send(P.WidgetApiFromWidgetAction.SetModalButtonEnabled,{button:e,enabled:t}).then()}},{key:"navigateTo",value:function(e){if(!e||!e.startsWith("https://matrix.to/#"))throw new Error("Invalid matrix.to URI");return this.transport.send(P.WidgetApiFromWidgetAction.MSC2931Navigate,{uri:e}).then()}},{key:"getTurnServers",value:function(){var e,t=this;return(e=i().mark((function e(){var r,n;return i().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(n=function(){var e=a(i().mark((function e(n){return i().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return n.preventDefault(),r(n.detail.data),e.next=4,t.transport.reply(n.detail,{});case 4:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),t.on("action:".concat(P.WidgetApiToWidgetAction.UpdateTurnServers),n),0!==t.turnServerWatchers){e.next=12;break}return e.prev=3,e.next=6,v(t.transport.send(P.WidgetApiFromWidgetAction.WatchTurnServers,{}));case 6:e.next=12;break;case 8:throw e.prev=8,e.t0=e.catch(3),t.off("action:".concat(P.WidgetApiToWidgetAction.UpdateTurnServers),n),e.t0;case 12:t.turnServerWatchers++,e.prev=13;case 14:return e.next=17,v(new Promise((function(e){return r=e})));case 17:return e.next=19,e.sent;case 19:e.next=14;break;case 21:if(e.prev=21,t.off("action:".concat(P.WidgetApiToWidgetAction.UpdateTurnServers),n),t.turnServerWatchers--,0!==t.turnServerWatchers){e.next=27;break}return e.next=27,v(t.transport.send(P.WidgetApiFromWidgetAction.UnwatchTurnServers,{}));case 27:return e.finish(21);case 28:case"end":return e.stop()}}),e,null,[[3,8],[13,,21,28]])})),function(){return new h(e.apply(this,arguments))})()}},{key:"searchUserDirectory",value:(m=a(i().mark((function e(t,r){var n;return i().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,this.getClientVersions();case 2:if(e.sent.includes(C.UnstableApiVersion.MSC3973)){e.next=5;break}throw new Error("The user_directory_search action is not supported by the client.");case 5:return n={search_term:t,limit:r},e.abrupt("return",this.transport.send(P.WidgetApiFromWidgetAction.MSC3973UserDirectorySearch,n));case 7:case"end":return e.stop()}}),e,this)}))),function(e,t){return m.apply(this,arguments)})},{key:"start",value:function(){var e=this;this.transport.start(),this.getClientVersions().then((function(t){t.includes(C.UnstableApiVersion.MSC2974)&&(e.supportsMSC2974Renegotiate=!0)}))}},{key:"handleMessage",value:function(e){var t=new CustomEvent("action:".concat(e.detail.action),{detail:e.detail,cancelable:!0});if(this.emit("action:".concat(e.detail.action),t),!t.defaultPrevented)switch(e.detail.action){case P.WidgetApiToWidgetAction.SupportedApiVersions:return this.replyVersions(e.detail);case P.WidgetApiToWidgetAction.Capabilities:return this.handleCapabilities(e.detail);case P.WidgetApiToWidgetAction.UpdateVisibility:case P.WidgetApiToWidgetAction.NotifyCapabilities:return this.transport.reply(e.detail,{});default:return this.transport.reply(e.detail,{error:{message:"Unknown or unsupported action: "+e.detail.action}})}}},{key:"replyVersions",value:function(e){this.transport.reply(e,{supported_versions:C.CurrentApiVersions})}},{key:"getClientVersions",value:function(){var e=this;return Array.isArray(this.cachedClientVersions)?Promise.resolve(this.cachedClientVersions):this.transport.send(P.WidgetApiFromWidgetAction.SupportedApiVersions,{}).then((function(t){return e.cachedClientVersions=t.supported_versions,t.supported_versions})).catch((function(e){return console.warn("non-fatal error getting supported client versions: ",e),[]}))}},{key:"handleCapabilities",value:function(e){var t=this;return this.capabilitiesFinished?this.transport.reply(e,{error:{message:"Capability negotiation already completed"}}):this.getClientVersions().then((function(r){return r.includes(C.UnstableApiVersion.MSC2871)?t.once("action:".concat(P.WidgetApiToWidgetAction.NotifyCapabilities),(function(e){t.approvedCapabilities=e.detail.data.approved,t.emit("ready")})):t.emit("ready"),t.capabilitiesFinished=!0,t.transport.reply(e,{capabilities:t.requestedCapabilities})}))}}])&&s(t.prototype,o),Object.defineProperty(t,"prototype",{writable:!1}),w}();t.WidgetApi=m})),u=t((function(e,t){"use strict";function n(e){return(n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}Object.defineProperty(t,"__esModule",{value:!0}),t.PostmessageTransport=void 0;var i=r({});function o(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function a(e){for(var t=1;t0&&a.length>i&&!a.warned){a.warned=!0;var u=new Error("Possible EventEmitter memory leak detected. "+a.length+" "+String(t)+" listeners added. Use emitter.setMaxListeners() to increase limit");u.name="MaxListenersExceededWarning",u.emitter=e,u.type=t,u.count=a.length,s=u,console&&console.warn&&console.warn(s)}return e}function g(e,t,r){var n={fired:!1,wrapFn:void 0,target:e,type:t,listener:r},i=function(){if(!this.fired)return this.target.removeListener(this.type,this.wrapFn),this.fired=!0,0===arguments.length?this.listener.call(this.target):this.listener.apply(this.target,arguments)}.bind(n);return i.listener=r,n.wrapFn=i,i}function b(e,t,r){var n=e._events;if(void 0===n)return[];var i=n[t];return void 0===i?[]:"function"==typeof i?r?[i.listener||i]:[i]:r?function(e){for(var t=new Array(e.length),r=0;r0&&(o=t[0]),o instanceof Error)throw o;var a=new Error("Unhandled error."+(o?" ("+o.message+")":""));throw a.context=o,a}var s=i[e];if(void 0===s)return!1;if("function"==typeof s)d(s,this,t);else{var u=s.length,c=_(s,u);for(r=0;r=0;o--)if(r[o]===t||r[o].listener===t){a=r[o].listener,i=o;break}if(i<0)return this;0===i?r.shift():function(e,t){for(;t+1=0;n--)this.removeListener(e,t[n]);return this},p.prototype.listeners=function(e){return b(this,e,!0)},p.prototype.rawListeners=function(e){return b(this,e,!1)},p.listenerCount=function(e,t){return"function"==typeof e.listenerCount?e.listenerCount(t):w.call(e,t)},p.prototype.listenerCount=w,p.prototype.eventNames=function(){return this._eventsCount>0?e(this._events):[]};var k,E={};Object.defineProperty(E,"__esModule",{value:!0}),E.WidgetApiDirection=void 0,E.invertedDirection=function(e){if(e===k.ToWidget)return k.FromWidget;if(e===k.FromWidget)return k.ToWidget;throw new Error("Invalid direction")},E.WidgetApiDirection=k,function(e){e.ToWidget="toWidget",e.FromWidget="fromWidget"}(k||(E.WidgetApiDirection=k={}));var S,j,C={};Object.defineProperty(C,"__esModule",{value:!0}),C.UnstableApiVersion=C.MatrixApiVersion=C.CurrentApiVersions=void 0,C.MatrixApiVersion=S,function(e){e.Prerelease1="0.0.1",e.Prerelease2="0.0.2"}(S||(C.MatrixApiVersion=S={})),C.UnstableApiVersion=j,function(e){e.MSC2762="org.matrix.msc2762",e.MSC2871="org.matrix.msc2871",e.MSC2931="org.matrix.msc2931",e.MSC2974="org.matrix.msc2974",e.MSC2876="org.matrix.msc2876",e.MSC3819="org.matrix.msc3819",e.MSC3846="town.robin.msc3846",e.MSC3869="org.matrix.msc3869",e.MSC3973="org.matrix.msc3973"}(j||(C.UnstableApiVersion=j={}));var x=[S.Prerelease1,S.Prerelease2,j.MSC2762,j.MSC2871,j.MSC2931,j.MSC2974,j.MSC2876,j.MSC3819,j.MSC3846,j.MSC3869,j.MSC3973];C.CurrentApiVersions=x;var A,W,P={};Object.defineProperty(P,"__esModule",{value:!0}),P.WidgetApiToWidgetAction=P.WidgetApiFromWidgetAction=void 0,P.WidgetApiToWidgetAction=A,function(e){e.SupportedApiVersions="supported_api_versions",e.Capabilities="capabilities",e.NotifyCapabilities="notify_capabilities",e.TakeScreenshot="screenshot",e.UpdateVisibility="visibility",e.OpenIDCredentials="openid_credentials",e.WidgetConfig="widget_config",e.CloseModalWidget="close_modal",e.ButtonClicked="button_clicked",e.SendEvent="send_event",e.SendToDevice="send_to_device",e.UpdateTurnServers="update_turn_servers"}(A||(P.WidgetApiToWidgetAction=A={})),P.WidgetApiFromWidgetAction=W,function(e){e.SupportedApiVersions="supported_api_versions",e.ContentLoaded="content_loaded",e.SendSticker="m.sticker",e.UpdateAlwaysOnScreen="set_always_on_screen",e.GetOpenIDCredentials="get_openid",e.CloseModalWidget="close_modal",e.OpenModalWidget="open_modal",e.SetModalButtonEnabled="set_button_enabled",e.SendEvent="send_event",e.SendToDevice="send_to_device",e.WatchTurnServers="watch_turn_servers",e.UnwatchTurnServers="unwatch_turn_servers",e.MSC2876ReadEvents="org.matrix.msc2876.read_events",e.MSC2931Navigate="org.matrix.msc2931.navigate",e.MSC2974RenegotiateCapabilities="org.matrix.msc2974.request_capabilities",e.MSC3869ReadRelations="org.matrix.msc3869.read_relations",e.MSC3973UserDirectorySearch="org.matrix.msc3973.user_directory_search"}(W||(P.WidgetApiFromWidgetAction=W={}));var M,T={};Object.defineProperty(T,"__esModule",{value:!0}),T.OpenIDRequestState=void 0,T.OpenIDRequestState=M,function(e){e.Allowed="allowed",e.Blocked="blocked",e.PendingUserConfirmation="request"}(M||(T.OpenIDRequestState=M={}));var R,I={};Object.defineProperty(I,"__esModule",{value:!0}),I.MatrixWidgetType=void 0,I.MatrixWidgetType=R,function(e){e.Custom="m.custom",e.JitsiMeet="m.jitsi",e.Stickerpicker="m.stickerpicker"}(R||(I.MatrixWidgetType=R={}));var L,D={};Object.defineProperty(D,"__esModule",{value:!0}),D.BuiltInModalButtonID=void 0,D.BuiltInModalButtonID=L,function(e){e.Close="m.close"}(L||(D.BuiltInModalButtonID=L={}));var U,q,F={};function N(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=new Array(t);r=e.length?{done:!0}:{done:!1,value:e[n++]}},e:function(e){throw e},f:i}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var o,a=!0,s=!1;return{s:function(){r=r.call(e)},n:function(){var e=r.next();return a=e.done,e},e:function(e){s=!0,o=e},f:function(){try{a||null==r.return||r.return()}finally{if(s)throw o}}}}(t);try{for(i.s();!(r=i.n()).done;){var o=r.value,a=null,s=void 0,u=null;if(o.startsWith("org.matrix.msc2762.send.event:")?(a=q.Send,u=U.Event,s=o.substring("org.matrix.msc2762.send.event:".length)):o.startsWith("org.matrix.msc2762.send.state_event:")?(a=q.Send,u=U.State,s=o.substring("org.matrix.msc2762.send.state_event:".length)):o.startsWith("org.matrix.msc3819.send.to_device:")?(a=q.Send,u=U.ToDevice,s=o.substring("org.matrix.msc3819.send.to_device:".length)):o.startsWith("org.matrix.msc2762.receive.event:")?(a=q.Receive,u=U.Event,s=o.substring("org.matrix.msc2762.receive.event:".length)):o.startsWith("org.matrix.msc2762.receive.state_event:")?(a=q.Receive,u=U.State,s=o.substring("org.matrix.msc2762.receive.state_event:".length)):o.startsWith("org.matrix.msc3819.receive.to_device:")&&(a=q.Receive,u=U.ToDevice,s=o.substring("org.matrix.msc3819.receive.to_device:".length)),null!==a&&null!==u&&void 0!==s){var c=s.startsWith("m.room.message#")||u===U.State,l=null;if(s.includes("#")&&c){var d=s.split("#"),f=d.findIndex((function(e){return!e.endsWith("\\")}));s=d.slice(0,f+1).map((function(e){return e.endsWith("\\")?e.substring(0,e.length-1):e})).join("#"),l=d.slice(f+1).join("#")}n.push(new e(a,s,u,l,o))}}}catch(p){i.e(p)}finally{i.f()}return n}}],(r=[{key:"matchesAsStateEvent",value:function(e,t,r){return this.kind===U.State&&this.direction===e&&this.eventType===t&&(null===this.keyStr||this.keyStr===r)}},{key:"matchesAsToDeviceEvent",value:function(e,t){return this.kind===U.ToDevice&&this.direction===e&&this.eventType===t}},{key:"matchesAsRoomEvent",value:function(e,t){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null;return this.kind===U.Event&&this.direction===e&&this.eventType===t&&("m.room.message"!==this.eventType||null===this.keyStr||this.keyStr===r)}}])&&V(t.prototype,r),n&&V(t,n),Object.defineProperty(t,"prototype",{writable:!1}),e}();F.WidgetEventCapability=B;var G,K={};Object.defineProperty(K,"__esModule",{value:!0}),K.Symbols=void 0,K.Symbols=G,function(e){e.AnyRoom="*"}(G||(K.Symbols=G={}));var $,Y={};Object.defineProperty(Y,"__esModule",{value:!0}),Y.VideoConferenceCapabilities=Y.StickerpickerCapabilities=Y.MatrixCapabilities=void 0,Y.getTimelineRoomIDFromCapability=function(e){return e.substring(e.indexOf(":")+1)},Y.isTimelineCapability=function(e){return null==e?void 0:e.startsWith("org.matrix.msc2762.timeline:")},Y.isTimelineCapabilityFor=function(e,t){return e==="org.matrix.msc2762.timeline:".concat(t)},Y.MatrixCapabilities=$,function(e){e.Screenshots="m.capability.screenshot",e.StickerSending="m.sticker",e.AlwaysOnScreen="m.always_on_screen",e.RequiresClient="io.element.requires_client",e.MSC2931Navigate="org.matrix.msc2931.navigate",e.MSC3846TurnServers="town.robin.msc3846.turn_servers",e.MSC3973UserDirectorySearch="org.matrix.msc3973.user_directory_search"}($||(Y.MatrixCapabilities=$={}));var z=[$.StickerSending];Y.StickerpickerCapabilities=z;var H=[$.AlwaysOnScreen];Y.VideoConferenceCapabilities=H;var J={};function Q(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=new Array(t);r=e.length?{done:!0}:{done:!1,value:e[n++]}},e:function(e){throw e},f:i}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var o,a=!0,s=!1;return{s:function(){r=r.call(e)},n:function(){var e=r.next();return a=e.done,e},e:function(e){s=!0,o=e},f:function(){try{a||null==r.return||r.return()}finally{if(s)throw o}}}}(this.listeners);try{for(r.s();!(t=r.n()).done;)(0,t.value)(e)}catch(n){r.e(n)}finally{r.f()}}},{key:"close",value:function(){this.listeners=[]}}])&&X(t.prototype,r),Object.defineProperty(t,"prototype",{writable:!1}),e}();J.SimpleObservable=Z;var ee={};Object.defineProperty(ee,"__esModule",{value:!0});var te={};Object.defineProperty(te,"__esModule",{value:!0});var re={};Object.defineProperty(re,"__esModule",{value:!0});var ne={};Object.defineProperty(ne,"__esModule",{value:!0});var ie={};Object.defineProperty(ie,"__esModule",{value:!0});var oe={};Object.defineProperty(oe,"__esModule",{value:!0}),oe.isErrorResponse=function(e){return"error"in e&&!!e.error.message};var ae={};Object.defineProperty(ae,"__esModule",{value:!0});var se={};Object.defineProperty(se,"__esModule",{value:!0});var ue={};Object.defineProperty(ue,"__esModule",{value:!0});var ce={};Object.defineProperty(ce,"__esModule",{value:!0});var le={};Object.defineProperty(le,"__esModule",{value:!0});var de={};Object.defineProperty(de,"__esModule",{value:!0});var fe={};Object.defineProperty(fe,"__esModule",{value:!0});var pe={};Object.defineProperty(pe,"__esModule",{value:!0});var ve={};Object.defineProperty(ve,"__esModule",{value:!0});var he={};Object.defineProperty(he,"__esModule",{value:!0});var ye,me={};Object.defineProperty(me,"__esModule",{value:!0}),me.WidgetKind=void 0,me.WidgetKind=ye,function(e){e.Room="room",e.Account="account",e.Modal="modal"}(ye||(me.WidgetKind=ye={}));var ge,be={};Object.defineProperty(be,"__esModule",{value:!0}),be.ModalButtonKind=void 0,be.ModalButtonKind=ge,function(e){e.Primary="m.primary",e.Secondary="m.secondary",e.Warning="m.warning",e.Danger="m.danger",e.Link="m.link"}(ge||(be.ModalButtonKind=ge={}));var we={};Object.defineProperty(we,"__esModule",{value:!0});var _e={};Object.defineProperty(_e,"__esModule",{value:!0});var Oe={};Object.defineProperty(Oe,"__esModule",{value:!0});var ke={};Object.defineProperty(ke,"__esModule",{value:!0});var Ee={};Object.defineProperty(Ee,"__esModule",{value:!0});var Se={};Object.defineProperty(Se,"__esModule",{value:!0});var je={};Object.defineProperty(je,"__esModule",{value:!0});var Ce={};Object.defineProperty(Ce,"__esModule",{value:!0});var xe={};Object.defineProperty(xe,"__esModule",{value:!0});var Ae={};Object.defineProperty(Ae,"__esModule",{value:!0}),Ae.isValidUrl=function(e){if(!e)return!1;try{var t=new URL(e);return"http"===t.protocol||"https"===t.protocol}catch(r){if(r instanceof TypeError)return!1;throw r}};var We={};Object.defineProperty(We,"__esModule",{value:!0}),We.assertPresent=function(e,t){if(!e[t])throw new Error("".concat(t," is required"))};var Pe={};function Me(e){return null==e?"".concat(e):String(e)}return Object.defineProperty(Pe,"__esModule",{value:!0}),Pe.runTemplate=function(e,t,r){for(var n=Object.assign({},t.data,{matrix_room_id:r.widgetRoomId||"",matrix_user_id:r.currentUserId,matrix_display_name:r.userDisplayName||r.currentUserId,matrix_avatar_url:r.userHttpAvatarUrl||"",matrix_widget_id:t.id,"org.matrix.msc2873.client_id":r.clientId||"","org.matrix.msc2873.client_theme":r.clientTheme||"","org.matrix.msc2873.client_language":r.clientLanguage||""}),i=e,o=0,a=Object.keys(n);o; - /** - * Alerts the widget to whether or not it is currently visible. - * @param {boolean} isVisible Whether the widget is visible or not. - * @returns {Promise} Resolves when the widget acknowledges the update. - */ - updateVisibility(isVisible: boolean): Promise; - sendWidgetConfig(data: IModalWidgetOpenRequestData): Promise; - notifyModalWidgetButtonClicked(id: IModalWidgetOpenRequestDataButton["id"]): Promise; - notifyModalWidgetClose(data: IModalWidgetReturnData): Promise; - /** - * Feeds an event to the widget. If the widget is not able to accept the event due to - * permissions, this will no-op and return calmly. If the widget failed to handle the - * event, this will raise an error. - * @param {IRoomEvent} rawEvent The event to (try to) send to the widget. - * @param {string} currentViewedRoomId The room ID the user is currently interacting with. - * Not the room ID of the event. - * @returns {Promise} Resolves when complete, rejects if there was an error sending. - */ - feedEvent(rawEvent: IRoomEvent, currentViewedRoomId: string): Promise; - /** - * Feeds a to-device event to the widget. If the widget is not able to accept the - * event due to permissions, this will no-op and return calmly. If the widget failed - * to handle the event, this will raise an error. - * @param {IRoomEvent} rawEvent The event to (try to) send to the widget. - * @param {boolean} encrypted Whether the event contents were encrypted. - * @returns {Promise} Resolves when complete, rejects if there was an error sending. - */ - feedToDevice(rawEvent: IRoomEvent, encrypted: boolean): Promise; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/ClientWidgetApi.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/ClientWidgetApi.js deleted file mode 100644 index 8b0da4f..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/ClientWidgetApi.js +++ /dev/null @@ -1,1343 +0,0 @@ -"use strict"; - -function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ClientWidgetApi = void 0; - -var _events = require("events"); - -var _PostmessageTransport = require("./transport/PostmessageTransport"); - -var _WidgetApiDirection = require("./interfaces/WidgetApiDirection"); - -var _WidgetApiAction = require("./interfaces/WidgetApiAction"); - -var _Capabilities = require("./interfaces/Capabilities"); - -var _ApiVersion = require("./interfaces/ApiVersion"); - -var _WidgetEventCapability = require("./models/WidgetEventCapability"); - -var _GetOpenIDAction = require("./interfaces/GetOpenIDAction"); - -var _SimpleObservable = require("./util/SimpleObservable"); - -var _Symbols = require("./Symbols"); - -function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, $Symbol = "function" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || "@@iterator", asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator", toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, ""); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return generator._invoke = function (innerFn, self, context) { var state = "suspendedStart"; return function (method, arg) { if ("executing" === state) throw new Error("Generator is already running"); if ("completed" === state) { if ("throw" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) { if ("suspendedStart" === state) throw state = "completed", context.arg; context.dispatchException(context.arg); } else "return" === context.method && context.abrupt("return", context.arg); state = "executing"; var record = tryCatch(innerFn, self, context); if ("normal" === record.type) { if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } "throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg); } }; }(innerFn, self, context), generator; } function tryCatch(fn, obj, arg) { try { return { type: "normal", arg: fn.call(obj, arg) }; } catch (err) { return { type: "throw", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { ["next", "throw", "return"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if ("throw" !== record.type) { var result = record.arg, value = result.value; return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke("next", value, resolve, reject); }, function (err) { invoke("throw", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke("throw", error, resolve, reject); }); } reject(record.arg); } var previousPromise; this._invoke = function (method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); }; } function maybeInvokeDelegate(delegate, context) { var method = delegate.iterator[context.method]; if (undefined === method) { if (context.delegate = null, "throw" === context.method) { if (delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method)) return ContinueSentinel; context.method = "throw", context.arg = new TypeError("The iterator does not provide a 'throw' method"); } return ContinueSentinel; } var record = tryCatch(method, delegate.iterator, context.arg); if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = "normal", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: "root" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if ("function" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) { if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; } return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, define(Gp, "constructor", GeneratorFunctionPrototype), define(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) { var ctor = "function" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, "toString", function () { return "[object Generator]"; }), exports.keys = function (object) { var keys = []; for (var key in object) { keys.push(key); } return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) { "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); } }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if ("throw" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, "catch": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; } - -function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } - -function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } - -function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; } - -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } - -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } - -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } - -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); } - -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } - -function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } - -function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); } - -function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } - -function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } - -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } - -function _asyncIterator(iterable) { var method, async, sync, retry = 2; for ("undefined" != typeof Symbol && (async = Symbol.asyncIterator, sync = Symbol.iterator); retry--;) { if (async && null != (method = iterable[async])) return method.call(iterable); if (sync && null != (method = iterable[sync])) return new AsyncFromSyncIterator(method.call(iterable)); async = "@@asyncIterator", sync = "@@iterator"; } throw new TypeError("Object is not async iterable"); } - -function AsyncFromSyncIterator(s) { function AsyncFromSyncIteratorContinuation(r) { if (Object(r) !== r) return Promise.reject(new TypeError(r + " is not an object.")); var done = r.done; return Promise.resolve(r.value).then(function (value) { return { value: value, done: done }; }); } return AsyncFromSyncIterator = function AsyncFromSyncIterator(s) { this.s = s, this.n = s.next; }, AsyncFromSyncIterator.prototype = { s: null, n: null, next: function next() { return AsyncFromSyncIteratorContinuation(this.n.apply(this.s, arguments)); }, "return": function _return(value) { var ret = this.s["return"]; return void 0 === ret ? Promise.resolve({ value: value, done: !0 }) : AsyncFromSyncIteratorContinuation(ret.apply(this.s, arguments)); }, "throw": function _throw(value) { var thr = this.s["return"]; return void 0 === thr ? Promise.reject(value) : AsyncFromSyncIteratorContinuation(thr.apply(this.s, arguments)); } }, new AsyncFromSyncIterator(s); } - -/** - * API handler for the client side of widgets. This raises events - * for each action received as `action:${action}` (eg: "action:screenshot"). - * Default handling can be prevented by using preventDefault() on the - * raised event. The default handling varies for each action: ones - * which the SDK can handle safely are acknowledged appropriately and - * ones which are unhandled (custom or require the client to do something) - * are rejected with an error. - * - * Events which are preventDefault()ed must reply using the transport. - * The events raised will have a default of an IWidgetApiRequest - * interface. - * - * When the ClientWidgetApi is ready to start sending requests, it will - * raise a "ready" CustomEvent. After the ready event fires, actions can - * be sent and the transport will be ready. - * - * When the widget has indicated it has loaded, this class raises a - * "preparing" CustomEvent. The preparing event does not indicate that - * the widget is ready to receive communications - that is signified by - * the ready event exclusively. - * - * This class only handles one widget at a time. - */ -var ClientWidgetApi = /*#__PURE__*/function (_EventEmitter) { - _inherits(ClientWidgetApi, _EventEmitter); - - var _super = _createSuper(ClientWidgetApi); - - // contentLoadedActionSent is used to check that only one ContentLoaded request is send. - - /** - * Creates a new client widget API. This will instantiate the transport - * and start everything. When the iframe is loaded under the widget's - * conditions, a "ready" event will be raised. - * @param {Widget} widget The widget to communicate with. - * @param {HTMLIFrameElement} iframe The iframe the widget is in. - * @param {WidgetDriver} driver The driver for this widget/client. - */ - function ClientWidgetApi(widget, iframe, driver) { - var _this; - - _classCallCheck(this, ClientWidgetApi); - - _this = _super.call(this); - _this.widget = widget; - _this.iframe = iframe; - _this.driver = driver; - - _defineProperty(_assertThisInitialized(_this), "transport", void 0); - - _defineProperty(_assertThisInitialized(_this), "contentLoadedActionSent", false); - - _defineProperty(_assertThisInitialized(_this), "allowedCapabilities", new Set()); - - _defineProperty(_assertThisInitialized(_this), "allowedEvents", []); - - _defineProperty(_assertThisInitialized(_this), "isStopped", false); - - _defineProperty(_assertThisInitialized(_this), "turnServers", null); - - if (!(iframe !== null && iframe !== void 0 && iframe.contentWindow)) { - throw new Error("No iframe supplied"); - } - - if (!widget) { - throw new Error("Invalid widget"); - } - - if (!driver) { - throw new Error("Invalid driver"); - } - - _this.transport = new _PostmessageTransport.PostmessageTransport(_WidgetApiDirection.WidgetApiDirection.ToWidget, widget.id, iframe.contentWindow, window); - _this.transport.targetOrigin = widget.origin; - - _this.transport.on("message", _this.handleMessage.bind(_assertThisInitialized(_this))); - - iframe.addEventListener("load", _this.onIframeLoad.bind(_assertThisInitialized(_this))); - - _this.transport.start(); - - return _this; - } - - _createClass(ClientWidgetApi, [{ - key: "hasCapability", - value: function hasCapability(capability) { - return this.allowedCapabilities.has(capability); - } - }, { - key: "canUseRoomTimeline", - value: function canUseRoomTimeline(roomId) { - return this.hasCapability("org.matrix.msc2762.timeline:".concat(_Symbols.Symbols.AnyRoom)) || this.hasCapability("org.matrix.msc2762.timeline:".concat(roomId)); - } - }, { - key: "canSendRoomEvent", - value: function canSendRoomEvent(eventType) { - var msgtype = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; - return this.allowedEvents.some(function (e) { - return e.matchesAsRoomEvent(_WidgetEventCapability.EventDirection.Send, eventType, msgtype); - }); - } - }, { - key: "canSendStateEvent", - value: function canSendStateEvent(eventType, stateKey) { - return this.allowedEvents.some(function (e) { - return e.matchesAsStateEvent(_WidgetEventCapability.EventDirection.Send, eventType, stateKey); - }); - } - }, { - key: "canSendToDeviceEvent", - value: function canSendToDeviceEvent(eventType) { - return this.allowedEvents.some(function (e) { - return e.matchesAsToDeviceEvent(_WidgetEventCapability.EventDirection.Send, eventType); - }); - } - }, { - key: "canReceiveRoomEvent", - value: function canReceiveRoomEvent(eventType) { - var msgtype = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; - return this.allowedEvents.some(function (e) { - return e.matchesAsRoomEvent(_WidgetEventCapability.EventDirection.Receive, eventType, msgtype); - }); - } - }, { - key: "canReceiveStateEvent", - value: function canReceiveStateEvent(eventType, stateKey) { - return this.allowedEvents.some(function (e) { - return e.matchesAsStateEvent(_WidgetEventCapability.EventDirection.Receive, eventType, stateKey); - }); - } - }, { - key: "canReceiveToDeviceEvent", - value: function canReceiveToDeviceEvent(eventType) { - return this.allowedEvents.some(function (e) { - return e.matchesAsToDeviceEvent(_WidgetEventCapability.EventDirection.Receive, eventType); - }); - } - }, { - key: "stop", - value: function stop() { - this.isStopped = true; - this.transport.stop(); - } - }, { - key: "beginCapabilities", - value: function beginCapabilities() { - var _this2 = this; - - // widget has loaded - tell all the listeners that - this.emit("preparing"); - var requestedCaps; - this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.Capabilities, {}).then(function (caps) { - requestedCaps = caps.capabilities; - return _this2.driver.validateCapabilities(new Set(caps.capabilities)); - }).then(function (allowedCaps) { - console.log("Widget ".concat(_this2.widget.id, " is allowed capabilities:"), Array.from(allowedCaps)); - _this2.allowedCapabilities = allowedCaps; - _this2.allowedEvents = _WidgetEventCapability.WidgetEventCapability.findEventCapabilities(allowedCaps); - - _this2.notifyCapabilities(requestedCaps); - - _this2.emit("ready"); - }); - } - }, { - key: "notifyCapabilities", - value: function notifyCapabilities(requested) { - var _this3 = this; - - this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.NotifyCapabilities, { - requested: requested, - approved: Array.from(this.allowedCapabilities) - })["catch"](function (e) { - console.warn("non-fatal error notifying widget of approved capabilities:", e); - }).then(function () { - _this3.emit("capabilitiesNotified"); - }); - } - }, { - key: "onIframeLoad", - value: function onIframeLoad(ev) { - if (this.widget.waitForIframeLoad) { - // If the widget is set to waitForIframeLoad the capabilities immediatly get setup after load. - // The client does not wait for the ContentLoaded action. - this.beginCapabilities(); - } else { - // Reaching this means, that the Iframe got reloaded/loaded and - // the clientApi is awaiting the FIRST ContentLoaded action. - this.contentLoadedActionSent = false; - } - } - }, { - key: "handleContentLoadedAction", - value: function handleContentLoadedAction(action) { - if (this.contentLoadedActionSent) { - throw new Error("Improper sequence: ContentLoaded Action can only be send once after the widget loaded " + "and should only be used if waitForIframeLoad is false (default=true)"); - } - - if (this.widget.waitForIframeLoad) { - this.transport.reply(action, { - error: { - message: "Improper sequence: not expecting ContentLoaded event if " + "waitForIframLoad is true (default=true)" - } - }); - } else { - this.transport.reply(action, {}); - this.beginCapabilities(); - } - - this.contentLoadedActionSent = true; - } - }, { - key: "replyVersions", - value: function replyVersions(request) { - this.transport.reply(request, { - supported_versions: _ApiVersion.CurrentApiVersions - }); - } - }, { - key: "handleCapabilitiesRenegotiate", - value: function handleCapabilitiesRenegotiate(request) { - var _request$data, - _this4 = this; - - // acknowledge first - this.transport.reply(request, {}); - var requested = ((_request$data = request.data) === null || _request$data === void 0 ? void 0 : _request$data.capabilities) || []; - var newlyRequested = new Set(requested.filter(function (r) { - return !_this4.hasCapability(r); - })); - - if (newlyRequested.size === 0) { - // Nothing to do - notify capabilities - return this.notifyCapabilities([]); - } - - this.driver.validateCapabilities(newlyRequested).then(function (allowed) { - allowed.forEach(function (c) { - return _this4.allowedCapabilities.add(c); - }); - - var allowedEvents = _WidgetEventCapability.WidgetEventCapability.findEventCapabilities(allowed); - - allowedEvents.forEach(function (c) { - return _this4.allowedEvents.push(c); - }); - return _this4.notifyCapabilities(Array.from(newlyRequested)); - }); - } - }, { - key: "handleNavigate", - value: function handleNavigate(request) { - var _request$data2, - _request$data3, - _this5 = this; - - if (!this.hasCapability(_Capabilities.MatrixCapabilities.MSC2931Navigate)) { - return this.transport.reply(request, { - error: { - message: "Missing capability" - } - }); - } - - if (!((_request$data2 = request.data) !== null && _request$data2 !== void 0 && _request$data2.uri) || !((_request$data3 = request.data) !== null && _request$data3 !== void 0 && _request$data3.uri.toString().startsWith("https://matrix.to/#"))) { - return this.transport.reply(request, { - error: { - message: "Invalid matrix.to URI" - } - }); - } - - var onErr = function onErr(e) { - console.error("[ClientWidgetApi] Failed to handle navigation: ", e); - return _this5.transport.reply(request, { - error: { - message: "Error handling navigation" - } - }); - }; - - try { - this.driver.navigate(request.data.uri.toString())["catch"](function (e) { - return onErr(e); - }).then(function () { - return _this5.transport.reply(request, {}); - }); - } catch (e) { - return onErr(e); - } - } - }, { - key: "handleOIDC", - value: function handleOIDC(request) { - var _this6 = this; - - var phase = 1; // 1 = initial request, 2 = after user manual confirmation - - var replyState = function replyState(state, credential) { - credential = credential || {}; - - if (phase > 1) { - return _this6.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.OpenIDCredentials, _objectSpread({ - state: state, - original_request_id: request.requestId - }, credential)); - } else { - return _this6.transport.reply(request, _objectSpread({ - state: state - }, credential)); - } - }; - - var replyError = function replyError(msg) { - console.error("[ClientWidgetApi] Failed to handle OIDC: ", msg); - - if (phase > 1) { - // We don't have a way to indicate that a random error happened in this flow, so - // just block the attempt. - return replyState(_GetOpenIDAction.OpenIDRequestState.Blocked); - } else { - return _this6.transport.reply(request, { - error: { - message: msg - } - }); - } - }; - - var observer = new _SimpleObservable.SimpleObservable(function (update) { - if (update.state === _GetOpenIDAction.OpenIDRequestState.PendingUserConfirmation && phase > 1) { - observer.close(); - return replyError("client provided out-of-phase response to OIDC flow"); - } - - if (update.state === _GetOpenIDAction.OpenIDRequestState.PendingUserConfirmation) { - replyState(update.state); - phase++; - return; - } - - if (update.state === _GetOpenIDAction.OpenIDRequestState.Allowed && !update.token) { - return replyError("client provided invalid OIDC token for an allowed request"); - } - - if (update.state === _GetOpenIDAction.OpenIDRequestState.Blocked) { - update.token = undefined; // just in case the client did something weird - } - - observer.close(); - return replyState(update.state, update.token); - }); - this.driver.askOpenID(observer); - } - }, { - key: "handleReadEvents", - value: function handleReadEvents(request) { - var _this7 = this; - - if (!request.data.type) { - return this.transport.reply(request, { - error: { - message: "Invalid request - missing event type" - } - }); - } - - if (request.data.limit !== undefined && (!request.data.limit || request.data.limit < 0)) { - return this.transport.reply(request, { - error: { - message: "Invalid request - limit out of range" - } - }); - } - - var askRoomIds = null; // null denotes current room only - - if (request.data.room_ids) { - askRoomIds = request.data.room_ids; - - if (!Array.isArray(askRoomIds)) { - askRoomIds = [askRoomIds]; - } - - var _iterator2 = _createForOfIteratorHelper(askRoomIds), - _step2; - - try { - for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) { - var roomId = _step2.value; - - if (!this.canUseRoomTimeline(roomId)) { - return this.transport.reply(request, { - error: { - message: "Unable to access room timeline: ".concat(roomId) - } - }); - } - } - } catch (err) { - _iterator2.e(err); - } finally { - _iterator2.f(); - } - } - - var limit = request.data.limit || 0; - var events = Promise.resolve([]); - - if (request.data.state_key !== undefined) { - var stateKey = request.data.state_key === true ? undefined : request.data.state_key.toString(); - - if (!this.canReceiveStateEvent(request.data.type, stateKey !== null && stateKey !== void 0 ? stateKey : null)) { - return this.transport.reply(request, { - error: { - message: "Cannot read state events of this type" - } - }); - } - - events = this.driver.readStateEvents(request.data.type, stateKey, limit, askRoomIds); - } else { - if (!this.canReceiveRoomEvent(request.data.type, request.data.msgtype)) { - return this.transport.reply(request, { - error: { - message: "Cannot read room events of this type" - } - }); - } - - events = this.driver.readRoomEvents(request.data.type, request.data.msgtype, limit, askRoomIds); - } - - return events.then(function (evs) { - return _this7.transport.reply(request, { - events: evs - }); - }); - } - }, { - key: "handleSendEvent", - value: function handleSendEvent(request) { - var _this8 = this; - - if (!request.data.type) { - return this.transport.reply(request, { - error: { - message: "Invalid request - missing event type" - } - }); - } - - if (!!request.data.room_id && !this.canUseRoomTimeline(request.data.room_id)) { - return this.transport.reply(request, { - error: { - message: "Unable to access room timeline: ".concat(request.data.room_id) - } - }); - } - - var isState = request.data.state_key !== null && request.data.state_key !== undefined; - var sendEventPromise; - - if (isState) { - if (!this.canSendStateEvent(request.data.type, request.data.state_key)) { - return this.transport.reply(request, { - error: { - message: "Cannot send state events of this type" - } - }); - } - - sendEventPromise = this.driver.sendEvent(request.data.type, request.data.content || {}, request.data.state_key, request.data.room_id); - } else { - var content = request.data.content || {}; - var msgtype = content['msgtype']; - - if (!this.canSendRoomEvent(request.data.type, msgtype)) { - return this.transport.reply(request, { - error: { - message: "Cannot send room events of this type" - } - }); - } - - sendEventPromise = this.driver.sendEvent(request.data.type, content, null, // not sending a state event - request.data.room_id); - } - - sendEventPromise.then(function (sentEvent) { - return _this8.transport.reply(request, { - room_id: sentEvent.roomId, - event_id: sentEvent.eventId - }); - })["catch"](function (e) { - console.error("error sending event: ", e); - return _this8.transport.reply(request, { - error: { - message: "Error sending event" - } - }); - }); - } - }, { - key: "handleSendToDevice", - value: function () { - var _handleSendToDevice = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(request) { - return _regeneratorRuntime().wrap(function _callee$(_context) { - while (1) { - switch (_context.prev = _context.next) { - case 0: - if (request.data.type) { - _context.next = 5; - break; - } - - _context.next = 3; - return this.transport.reply(request, { - error: { - message: "Invalid request - missing event type" - } - }); - - case 3: - _context.next = 32; - break; - - case 5: - if (request.data.messages) { - _context.next = 10; - break; - } - - _context.next = 8; - return this.transport.reply(request, { - error: { - message: "Invalid request - missing event contents" - } - }); - - case 8: - _context.next = 32; - break; - - case 10: - if (!(typeof request.data.encrypted !== "boolean")) { - _context.next = 15; - break; - } - - _context.next = 13; - return this.transport.reply(request, { - error: { - message: "Invalid request - missing encryption flag" - } - }); - - case 13: - _context.next = 32; - break; - - case 15: - if (this.canSendToDeviceEvent(request.data.type)) { - _context.next = 20; - break; - } - - _context.next = 18; - return this.transport.reply(request, { - error: { - message: "Cannot send to-device events of this type" - } - }); - - case 18: - _context.next = 32; - break; - - case 20: - _context.prev = 20; - _context.next = 23; - return this.driver.sendToDevice(request.data.type, request.data.encrypted, request.data.messages); - - case 23: - _context.next = 25; - return this.transport.reply(request, {}); - - case 25: - _context.next = 32; - break; - - case 27: - _context.prev = 27; - _context.t0 = _context["catch"](20); - console.error("error sending to-device event", _context.t0); - _context.next = 32; - return this.transport.reply(request, { - error: { - message: "Error sending event" - } - }); - - case 32: - case "end": - return _context.stop(); - } - } - }, _callee, this, [[20, 27]]); - })); - - function handleSendToDevice(_x) { - return _handleSendToDevice.apply(this, arguments); - } - - return handleSendToDevice; - }() - }, { - key: "pollTurnServers", - value: function () { - var _pollTurnServers = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(turnServers, initialServer) { - var _iteratorAbruptCompletion, _didIteratorError, _iteratorError, _iterator, _step, server; - - return _regeneratorRuntime().wrap(function _callee2$(_context2) { - while (1) { - switch (_context2.prev = _context2.next) { - case 0: - _context2.prev = 0; - _context2.next = 3; - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers, initialServer // it's compatible, but missing the index signature - ); - - case 3: - // Pick the generator up where we left off - _iteratorAbruptCompletion = false; - _didIteratorError = false; - _context2.prev = 5; - _iterator = _asyncIterator(turnServers); - - case 7: - _context2.next = 9; - return _iterator.next(); - - case 9: - if (!(_iteratorAbruptCompletion = !(_step = _context2.sent).done)) { - _context2.next = 16; - break; - } - - server = _step.value; - _context2.next = 13; - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers, server // it's compatible, but missing the index signature - ); - - case 13: - _iteratorAbruptCompletion = false; - _context2.next = 7; - break; - - case 16: - _context2.next = 22; - break; - - case 18: - _context2.prev = 18; - _context2.t0 = _context2["catch"](5); - _didIteratorError = true; - _iteratorError = _context2.t0; - - case 22: - _context2.prev = 22; - _context2.prev = 23; - - if (!(_iteratorAbruptCompletion && _iterator["return"] != null)) { - _context2.next = 27; - break; - } - - _context2.next = 27; - return _iterator["return"](); - - case 27: - _context2.prev = 27; - - if (!_didIteratorError) { - _context2.next = 30; - break; - } - - throw _iteratorError; - - case 30: - return _context2.finish(27); - - case 31: - return _context2.finish(22); - - case 32: - _context2.next = 37; - break; - - case 34: - _context2.prev = 34; - _context2.t1 = _context2["catch"](0); - console.error("error polling for TURN servers", _context2.t1); - - case 37: - case "end": - return _context2.stop(); - } - } - }, _callee2, this, [[0, 34], [5, 18, 22, 32], [23,, 27, 31]]); - })); - - function pollTurnServers(_x2, _x3) { - return _pollTurnServers.apply(this, arguments); - } - - return pollTurnServers; - }() - }, { - key: "handleWatchTurnServers", - value: function () { - var _handleWatchTurnServers = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3(request) { - var turnServers, _yield$turnServers$ne, done, value; - - return _regeneratorRuntime().wrap(function _callee3$(_context3) { - while (1) { - switch (_context3.prev = _context3.next) { - case 0: - if (this.hasCapability(_Capabilities.MatrixCapabilities.MSC3846TurnServers)) { - _context3.next = 5; - break; - } - - _context3.next = 3; - return this.transport.reply(request, { - error: { - message: "Missing capability" - } - }); - - case 3: - _context3.next = 30; - break; - - case 5: - if (!this.turnServers) { - _context3.next = 10; - break; - } - - _context3.next = 8; - return this.transport.reply(request, {}); - - case 8: - _context3.next = 30; - break; - - case 10: - _context3.prev = 10; - turnServers = this.driver.getTurnServers(); // Peek at the first result, so we can at least verify that the - // client isn't banned from getting TURN servers entirely - - _context3.next = 14; - return turnServers.next(); - - case 14: - _yield$turnServers$ne = _context3.sent; - done = _yield$turnServers$ne.done; - value = _yield$turnServers$ne.value; - - if (!done) { - _context3.next = 19; - break; - } - - throw new Error("Client refuses to provide any TURN servers"); - - case 19: - _context3.next = 21; - return this.transport.reply(request, {}); - - case 21: - // Start the poll loop, sending the widget the initial result - this.pollTurnServers(turnServers, value); - this.turnServers = turnServers; - _context3.next = 30; - break; - - case 25: - _context3.prev = 25; - _context3.t0 = _context3["catch"](10); - console.error("error getting first TURN server results", _context3.t0); - _context3.next = 30; - return this.transport.reply(request, { - error: { - message: "TURN servers not available" - } - }); - - case 30: - case "end": - return _context3.stop(); - } - } - }, _callee3, this, [[10, 25]]); - })); - - function handleWatchTurnServers(_x4) { - return _handleWatchTurnServers.apply(this, arguments); - } - - return handleWatchTurnServers; - }() - }, { - key: "handleUnwatchTurnServers", - value: function () { - var _handleUnwatchTurnServers = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee4(request) { - return _regeneratorRuntime().wrap(function _callee4$(_context4) { - while (1) { - switch (_context4.prev = _context4.next) { - case 0: - if (this.hasCapability(_Capabilities.MatrixCapabilities.MSC3846TurnServers)) { - _context4.next = 5; - break; - } - - _context4.next = 3; - return this.transport.reply(request, { - error: { - message: "Missing capability" - } - }); - - case 3: - _context4.next = 15; - break; - - case 5: - if (this.turnServers) { - _context4.next = 10; - break; - } - - _context4.next = 8; - return this.transport.reply(request, {}); - - case 8: - _context4.next = 15; - break; - - case 10: - _context4.next = 12; - return this.turnServers["return"](undefined); - - case 12: - this.turnServers = null; - _context4.next = 15; - return this.transport.reply(request, {}); - - case 15: - case "end": - return _context4.stop(); - } - } - }, _callee4, this); - })); - - function handleUnwatchTurnServers(_x5) { - return _handleUnwatchTurnServers.apply(this, arguments); - } - - return handleUnwatchTurnServers; - }() - }, { - key: "handleReadRelations", - value: function () { - var _handleReadRelations = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee5(request) { - var _this9 = this; - - var result, chunk; - return _regeneratorRuntime().wrap(function _callee5$(_context5) { - while (1) { - switch (_context5.prev = _context5.next) { - case 0: - if (request.data.event_id) { - _context5.next = 2; - break; - } - - return _context5.abrupt("return", this.transport.reply(request, { - error: { - message: "Invalid request - missing event ID" - } - })); - - case 2: - if (!(request.data.limit !== undefined && request.data.limit < 0)) { - _context5.next = 4; - break; - } - - return _context5.abrupt("return", this.transport.reply(request, { - error: { - message: "Invalid request - limit out of range" - } - })); - - case 4: - if (!(request.data.room_id !== undefined && !this.canUseRoomTimeline(request.data.room_id))) { - _context5.next = 6; - break; - } - - return _context5.abrupt("return", this.transport.reply(request, { - error: { - message: "Unable to access room timeline: ".concat(request.data.room_id) - } - })); - - case 6: - _context5.prev = 6; - _context5.next = 9; - return this.driver.readEventRelations(request.data.event_id, request.data.room_id, request.data.rel_type, request.data.event_type, request.data.from, request.data.to, request.data.limit, request.data.direction); - - case 9: - result = _context5.sent; - // only return events that the user has the permission to receive - chunk = result.chunk.filter(function (e) { - if (e.state_key !== undefined) { - return _this9.canReceiveStateEvent(e.type, e.state_key); - } else { - return _this9.canReceiveRoomEvent(e.type, e.content['msgtype']); - } - }); - return _context5.abrupt("return", this.transport.reply(request, { - chunk: chunk, - prev_batch: result.prevBatch, - next_batch: result.nextBatch - })); - - case 14: - _context5.prev = 14; - _context5.t0 = _context5["catch"](6); - console.error("error getting the relations", _context5.t0); - _context5.next = 19; - return this.transport.reply(request, { - error: { - message: "Unexpected error while reading relations" - } - }); - - case 19: - case "end": - return _context5.stop(); - } - } - }, _callee5, this, [[6, 14]]); - })); - - function handleReadRelations(_x6) { - return _handleReadRelations.apply(this, arguments); - } - - return handleReadRelations; - }() - }, { - key: "handleUserDirectorySearch", - value: function () { - var _handleUserDirectorySearch = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee6(request) { - var result; - return _regeneratorRuntime().wrap(function _callee6$(_context6) { - while (1) { - switch (_context6.prev = _context6.next) { - case 0: - if (this.hasCapability(_Capabilities.MatrixCapabilities.MSC3973UserDirectorySearch)) { - _context6.next = 2; - break; - } - - return _context6.abrupt("return", this.transport.reply(request, { - error: { - message: "Missing capability" - } - })); - - case 2: - if (!(typeof request.data.search_term !== 'string')) { - _context6.next = 4; - break; - } - - return _context6.abrupt("return", this.transport.reply(request, { - error: { - message: "Invalid request - missing search term" - } - })); - - case 4: - if (!(request.data.limit !== undefined && request.data.limit < 0)) { - _context6.next = 6; - break; - } - - return _context6.abrupt("return", this.transport.reply(request, { - error: { - message: "Invalid request - limit out of range" - } - })); - - case 6: - _context6.prev = 6; - _context6.next = 9; - return this.driver.searchUserDirectory(request.data.search_term, request.data.limit); - - case 9: - result = _context6.sent; - return _context6.abrupt("return", this.transport.reply(request, { - limited: result.limited, - results: result.results.map(function (r) { - return { - user_id: r.userId, - display_name: r.displayName, - avatar_url: r.avatarUrl - }; - }) - })); - - case 13: - _context6.prev = 13; - _context6.t0 = _context6["catch"](6); - console.error("error searching in the user directory", _context6.t0); - _context6.next = 18; - return this.transport.reply(request, { - error: { - message: "Unexpected error while searching in the user directory" - } - }); - - case 18: - case "end": - return _context6.stop(); - } - } - }, _callee6, this, [[6, 13]]); - })); - - function handleUserDirectorySearch(_x7) { - return _handleUserDirectorySearch.apply(this, arguments); - } - - return handleUserDirectorySearch; - }() - }, { - key: "handleMessage", - value: function handleMessage(ev) { - if (this.isStopped) return; - var actionEv = new CustomEvent("action:".concat(ev.detail.action), { - detail: ev.detail, - cancelable: true - }); - this.emit("action:".concat(ev.detail.action), actionEv); - - if (!actionEv.defaultPrevented) { - switch (ev.detail.action) { - case _WidgetApiAction.WidgetApiFromWidgetAction.ContentLoaded: - return this.handleContentLoadedAction(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.SupportedApiVersions: - return this.replyVersions(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.SendEvent: - return this.handleSendEvent(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.SendToDevice: - return this.handleSendToDevice(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.GetOpenIDCredentials: - return this.handleOIDC(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.MSC2931Navigate: - return this.handleNavigate(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.MSC2974RenegotiateCapabilities: - return this.handleCapabilitiesRenegotiate(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.MSC2876ReadEvents: - return this.handleReadEvents(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.WatchTurnServers: - return this.handleWatchTurnServers(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.UnwatchTurnServers: - return this.handleUnwatchTurnServers(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.MSC3869ReadRelations: - return this.handleReadRelations(ev.detail); - - case _WidgetApiAction.WidgetApiFromWidgetAction.MSC3973UserDirectorySearch: - return this.handleUserDirectorySearch(ev.detail); - - default: - return this.transport.reply(ev.detail, { - error: { - message: "Unknown or unsupported action: " + ev.detail.action - } - }); - } - } - } - /** - * Takes a screenshot of the widget. - * @returns Resolves to the widget's screenshot. - * @throws Throws if there is a problem. - */ - - }, { - key: "takeScreenshot", - value: function takeScreenshot() { - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.TakeScreenshot, {}); - } - /** - * Alerts the widget to whether or not it is currently visible. - * @param {boolean} isVisible Whether the widget is visible or not. - * @returns {Promise} Resolves when the widget acknowledges the update. - */ - - }, { - key: "updateVisibility", - value: function updateVisibility(isVisible) { - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.UpdateVisibility, { - visible: isVisible - }); - } - }, { - key: "sendWidgetConfig", - value: function sendWidgetConfig(data) { - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.WidgetConfig, data).then(); - } - }, { - key: "notifyModalWidgetButtonClicked", - value: function notifyModalWidgetButtonClicked(id) { - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.ButtonClicked, { - id: id - }).then(); - } - }, { - key: "notifyModalWidgetClose", - value: function notifyModalWidgetClose(data) { - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.CloseModalWidget, data).then(); - } - /** - * Feeds an event to the widget. If the widget is not able to accept the event due to - * permissions, this will no-op and return calmly. If the widget failed to handle the - * event, this will raise an error. - * @param {IRoomEvent} rawEvent The event to (try to) send to the widget. - * @param {string} currentViewedRoomId The room ID the user is currently interacting with. - * Not the room ID of the event. - * @returns {Promise} Resolves when complete, rejects if there was an error sending. - */ - - }, { - key: "feedEvent", - value: function () { - var _feedEvent = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee7(rawEvent, currentViewedRoomId) { - var _rawEvent$content; - - return _regeneratorRuntime().wrap(function _callee7$(_context7) { - while (1) { - switch (_context7.prev = _context7.next) { - case 0: - if (!(rawEvent.room_id !== currentViewedRoomId && !this.canUseRoomTimeline(rawEvent.room_id))) { - _context7.next = 2; - break; - } - - return _context7.abrupt("return"); - - case 2: - if (!(rawEvent.state_key !== undefined && rawEvent.state_key !== null)) { - _context7.next = 7; - break; - } - - if (this.canReceiveStateEvent(rawEvent.type, rawEvent.state_key)) { - _context7.next = 5; - break; - } - - return _context7.abrupt("return"); - - case 5: - _context7.next = 9; - break; - - case 7: - if (this.canReceiveRoomEvent(rawEvent.type, (_rawEvent$content = rawEvent.content) === null || _rawEvent$content === void 0 ? void 0 : _rawEvent$content["msgtype"])) { - _context7.next = 9; - break; - } - - return _context7.abrupt("return"); - - case 9: - _context7.next = 11; - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.SendEvent, rawEvent // it's compatible, but missing the index signature - ); - - case 11: - case "end": - return _context7.stop(); - } - } - }, _callee7, this); - })); - - function feedEvent(_x8, _x9) { - return _feedEvent.apply(this, arguments); - } - - return feedEvent; - }() - /** - * Feeds a to-device event to the widget. If the widget is not able to accept the - * event due to permissions, this will no-op and return calmly. If the widget failed - * to handle the event, this will raise an error. - * @param {IRoomEvent} rawEvent The event to (try to) send to the widget. - * @param {boolean} encrypted Whether the event contents were encrypted. - * @returns {Promise} Resolves when complete, rejects if there was an error sending. - */ - - }, { - key: "feedToDevice", - value: function () { - var _feedToDevice = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee8(rawEvent, encrypted) { - return _regeneratorRuntime().wrap(function _callee8$(_context8) { - while (1) { - switch (_context8.prev = _context8.next) { - case 0: - if (!this.canReceiveToDeviceEvent(rawEvent.type)) { - _context8.next = 3; - break; - } - - _context8.next = 3; - return this.transport.send(_WidgetApiAction.WidgetApiToWidgetAction.SendToDevice, // it's compatible, but missing the index signature - _objectSpread(_objectSpread({}, rawEvent), {}, { - encrypted: encrypted - })); - - case 3: - case "end": - return _context8.stop(); - } - } - }, _callee8, this); - })); - - function feedToDevice(_x10, _x11) { - return _feedToDevice.apply(this, arguments); - } - - return feedToDevice; - }() - }]); - - return ClientWidgetApi; -}(_events.EventEmitter); - -exports.ClientWidgetApi = ClientWidgetApi; \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/Symbols.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/Symbols.d.ts deleted file mode 100644 index ce657a4..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/Symbols.d.ts +++ /dev/null @@ -1,3 +0,0 @@ -export declare enum Symbols { - AnyRoom = "*" -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/Symbols.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/Symbols.js deleted file mode 100644 index 13813f5..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/Symbols.js +++ /dev/null @@ -1,28 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.Symbols = void 0; - -/* - * Copyright 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var Symbols; -exports.Symbols = Symbols; - -(function (Symbols) { - Symbols["AnyRoom"] = "*"; -})(Symbols || (exports.Symbols = Symbols = {})); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/WidgetApi.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/WidgetApi.d.ts deleted file mode 100644 index f153c9c..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/WidgetApi.d.ts +++ /dev/null @@ -1,265 +0,0 @@ -import { EventEmitter } from "events"; -import { Capability } from "./interfaces/Capabilities"; -import { ApiVersion } from "./interfaces/ApiVersion"; -import { ITransport } from "./transport/ITransport"; -import { IStickerActionRequestData } from "./interfaces/StickerAction"; -import { IOpenIDCredentials } from "./interfaces/GetOpenIDAction"; -import { WidgetType } from "./interfaces/WidgetType"; -import { IModalWidgetCreateData, IModalWidgetOpenRequestDataButton, IModalWidgetReturnData, ModalButtonID } from "./interfaces/ModalWidgetActions"; -import { ISendEventFromWidgetResponseData } from "./interfaces/SendEventAction"; -import { ISendToDeviceFromWidgetResponseData } from "./interfaces/SendToDeviceAction"; -import { IRoomEvent } from "./interfaces/IRoomEvent"; -import { ITurnServer } from "./interfaces/TurnServerActions"; -import { Symbols } from "./Symbols"; -import { IReadRelationsFromWidgetResponseData } from "./interfaces/ReadRelationsAction"; -import { IUserDirectorySearchFromWidgetResponseData } from "./interfaces/UserDirectorySearchAction"; -/** - * API handler for widgets. This raises events for each action - * received as `action:${action}` (eg: "action:screenshot"). - * Default handling can be prevented by using preventDefault() - * on the raised event. The default handling varies for each - * action: ones which the SDK can handle safely are acknowledged - * appropriately and ones which are unhandled (custom or require - * the widget to do something) are rejected with an error. - * - * Events which are preventDefault()ed must reply using the - * transport. The events raised will have a detail of an - * IWidgetApiRequest interface. - * - * When the WidgetApi is ready to start sending requests, it will - * raise a "ready" CustomEvent. After the ready event fires, actions - * can be sent and the transport will be ready. - */ -export declare class WidgetApi extends EventEmitter { - private clientOrigin; - readonly transport: ITransport; - private capabilitiesFinished; - private supportsMSC2974Renegotiate; - private requestedCapabilities; - private approvedCapabilities?; - private cachedClientVersions?; - private turnServerWatchers; - /** - * Creates a new API handler for the given widget. - * @param {string} widgetId The widget ID to listen for. If not supplied then - * the API will use the widget ID from the first valid request it receives. - * @param {string} clientOrigin The origin of the client, or null if not known. - */ - constructor(widgetId?: string | null, clientOrigin?: string | null); - /** - * Determines if the widget was granted a particular capability. Note that on - * clients where the capabilities are not fed back to the widget this function - * will rely on requested capabilities instead. - * @param {Capability} capability The capability to check for approval of. - * @returns {boolean} True if the widget has approval for the given capability. - */ - hasCapability(capability: Capability): boolean; - /** - * Request a capability from the client. It is not guaranteed to be allowed, - * but will be asked for. - * @param {Capability} capability The capability to request. - * @throws Throws if the capabilities negotiation has already started and the - * widget is unable to request additional capabilities. - */ - requestCapability(capability: Capability): void; - /** - * Request capabilities from the client. They are not guaranteed to be allowed, - * but will be asked for if the negotiation has not already happened. - * @param {Capability[]} capabilities The capabilities to request. - * @throws Throws if the capabilities negotiation has already started. - */ - requestCapabilities(capabilities: Capability[]): void; - /** - * Requests the capability to interact with rooms other than the user's currently - * viewed room. Applies to event receiving and sending. - * @param {string | Symbols.AnyRoom} roomId The room ID, or `Symbols.AnyRoom` to - * denote all known rooms. - */ - requestCapabilityForRoomTimeline(roomId: string | Symbols.AnyRoom): void; - /** - * Requests the capability to send a given state event with optional explicit - * state key. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} eventType The state event type to ask for. - * @param {string} stateKey If specified, the specific state key to request. - * Otherwise all state keys will be requested. - */ - requestCapabilityToSendState(eventType: string, stateKey?: string): void; - /** - * Requests the capability to receive a given state event with optional explicit - * state key. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} eventType The state event type to ask for. - * @param {string} stateKey If specified, the specific state key to request. - * Otherwise all state keys will be requested. - */ - requestCapabilityToReceiveState(eventType: string, stateKey?: string): void; - /** - * Requests the capability to send a given to-device event. It is not - * guaranteed to be allowed, but will be asked for if the negotiation has - * not already happened. - * @param {string} eventType The room event type to ask for. - */ - requestCapabilityToSendToDevice(eventType: string): void; - /** - * Requests the capability to receive a given to-device event. It is not - * guaranteed to be allowed, but will be asked for if the negotiation has - * not already happened. - * @param {string} eventType The room event type to ask for. - */ - requestCapabilityToReceiveToDevice(eventType: string): void; - /** - * Requests the capability to send a given room event. It is not guaranteed to be - * allowed, but will be asked for if the negotiation has not already happened. - * @param {string} eventType The room event type to ask for. - */ - requestCapabilityToSendEvent(eventType: string): void; - /** - * Requests the capability to receive a given room event. It is not guaranteed to be - * allowed, but will be asked for if the negotiation has not already happened. - * @param {string} eventType The room event type to ask for. - */ - requestCapabilityToReceiveEvent(eventType: string): void; - /** - * Requests the capability to send a given message event with optional explicit - * `msgtype`. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} msgtype If specified, the specific msgtype to request. - * Otherwise all message types will be requested. - */ - requestCapabilityToSendMessage(msgtype?: string): void; - /** - * Requests the capability to receive a given message event with optional explicit - * `msgtype`. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} msgtype If specified, the specific msgtype to request. - * Otherwise all message types will be requested. - */ - requestCapabilityToReceiveMessage(msgtype?: string): void; - /** - * Requests an OpenID Connect token from the client for the currently logged in - * user. This token can be validated server-side with the federation API. Note - * that the widget is responsible for validating the token and caching any results - * it needs. - * @returns {Promise} Resolves to a token for verification. - * @throws Throws if the user rejected the request or the request failed. - */ - requestOpenIDConnectToken(): Promise; - /** - * Asks the client for additional capabilities. Capabilities can be queued for this - * request with the requestCapability() functions. - * @returns {Promise} Resolves when complete. Note that the promise resolves when - * the capabilities request has gone through, not when the capabilities are approved/denied. - * Use the WidgetApiToWidgetAction.NotifyCapabilities action to detect changes. - */ - updateRequestedCapabilities(): Promise; - /** - * Tell the client that the content has been loaded. - * @returns {Promise} Resolves when the client acknowledges the request. - */ - sendContentLoaded(): Promise; - /** - * Sends a sticker to the client. - * @param {IStickerActionRequestData} sticker The sticker to send. - * @returns {Promise} Resolves when the client acknowledges the request. - */ - sendSticker(sticker: IStickerActionRequestData): Promise; - /** - * Asks the client to set the always-on-screen status for this widget. - * @param {boolean} value The new state to request. - * @returns {Promise} Resolve with true if the client was able to fulfill - * the request, resolves to false otherwise. Rejects if an error occurred. - */ - setAlwaysOnScreen(value: boolean): Promise; - /** - * Opens a modal widget. - * @param {string} url The URL to the modal widget. - * @param {string} name The name of the widget. - * @param {IModalWidgetOpenRequestDataButton[]} buttons The buttons to have on the widget. - * @param {IModalWidgetCreateData} data Data to supply to the modal widget. - * @param {WidgetType} type The type of modal widget. - * @returns {Promise} Resolves when the modal widget has been opened. - */ - openModalWidget(url: string, name: string, buttons?: IModalWidgetOpenRequestDataButton[], data?: IModalWidgetCreateData, type?: WidgetType): Promise; - /** - * Closes the modal widget. The widget's session will be terminated shortly after. - * @param {IModalWidgetReturnData} data Optional data to close the modal widget with. - * @returns {Promise} Resolves when complete. - */ - closeModalWidget(data?: IModalWidgetReturnData): Promise; - sendRoomEvent(eventType: string, content: unknown, roomId?: string): Promise; - sendStateEvent(eventType: string, stateKey: string, content: unknown, roomId?: string): Promise; - /** - * Sends a to-device event. - * @param {string} eventType The type of events being sent. - * @param {boolean} encrypted Whether to encrypt the message contents. - * @param {Object} contentMap A map from user IDs to device IDs to message contents. - * @returns {Promise} Resolves when complete. - */ - sendToDevice(eventType: string, encrypted: boolean, contentMap: { - [userId: string]: { - [deviceId: string]: object; - }; - }): Promise; - readRoomEvents(eventType: string, limit?: number, msgtype?: string, roomIds?: (string | Symbols.AnyRoom)[]): Promise; - /** - * Reads all related events given a known eventId. - * @param eventId The id of the parent event to be read. - * @param roomId The room to look within. When undefined, the user's currently - * viewed room. - * @param relationType The relationship type of child events to search for. - * When undefined, all relations are returned. - * @param eventType The event type of child events to search for. When undefined, - * all related events are returned. - * @param limit The maximum number of events to retrieve per room. If not - * supplied, the server will apply a default limit. - * @param from The pagination token to start returning results from, as - * received from a previous call. If not supplied, results start at the most - * recent topological event known to the server. - * @param to The pagination token to stop returning results at. If not - * supplied, results continue up to limit or until there are no more events. - * @param direction The direction to search for according to MSC3715. - * @returns Resolves to the room relations. - */ - readEventRelations(eventId: string, roomId?: string, relationType?: string, eventType?: string, limit?: number, from?: string, to?: string, direction?: 'f' | 'b'): Promise; - readStateEvents(eventType: string, limit?: number, stateKey?: string, roomIds?: (string | Symbols.AnyRoom)[]): Promise; - /** - * Sets a button as disabled or enabled on the modal widget. Buttons are enabled by default. - * @param {ModalButtonID} buttonId The button ID to enable/disable. - * @param {boolean} isEnabled Whether or not the button is enabled. - * @returns {Promise} Resolves when complete. - * @throws Throws if the button cannot be disabled, or the client refuses to disable the button. - */ - setModalButtonEnabled(buttonId: ModalButtonID, isEnabled: boolean): Promise; - /** - * Attempts to navigate the client to the given URI. This can only be called with Matrix URIs - * (currently only matrix.to, but in future a Matrix URI scheme will be defined). - * @param {string} uri The URI to navigate to. - * @returns {Promise} Resolves when complete. - * @throws Throws if the URI is invalid or cannot be processed. - * @deprecated This currently relies on an unstable MSC (MSC2931). - */ - navigateTo(uri: string): Promise; - /** - * Starts watching for TURN servers, yielding an initial set of credentials as soon as possible, - * and thereafter yielding new credentials whenever the previous ones expire. - * @yields {ITurnServer} The TURN server URIs and credentials currently available to the widget. - */ - getTurnServers(): AsyncGenerator; - /** - * Search for users in the user directory. - * @param searchTerm The term to search for. - * @param limit The maximum number of results to return. If not supplied, the - * @returns Resolves to the search results. - */ - searchUserDirectory(searchTerm: string, limit?: number): Promise; - /** - * Starts the communication channel. This should be done early to ensure - * that messages are not missed. Communication can only be stopped by the client. - */ - start(): void; - private handleMessage; - private replyVersions; - getClientVersions(): Promise; - private handleCapabilities; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/WidgetApi.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/WidgetApi.js deleted file mode 100644 index 8896d9c..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/WidgetApi.js +++ /dev/null @@ -1,922 +0,0 @@ -"use strict"; - -function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetApi = void 0; - -var _events = require("events"); - -var _WidgetApiDirection = require("./interfaces/WidgetApiDirection"); - -var _ApiVersion = require("./interfaces/ApiVersion"); - -var _PostmessageTransport = require("./transport/PostmessageTransport"); - -var _WidgetApiAction = require("./interfaces/WidgetApiAction"); - -var _GetOpenIDAction = require("./interfaces/GetOpenIDAction"); - -var _WidgetType = require("./interfaces/WidgetType"); - -var _ModalWidgetActions = require("./interfaces/ModalWidgetActions"); - -var _WidgetEventCapability = require("./models/WidgetEventCapability"); - -var _Symbols = require("./Symbols"); - -function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, $Symbol = "function" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || "@@iterator", asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator", toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, ""); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return generator._invoke = function (innerFn, self, context) { var state = "suspendedStart"; return function (method, arg) { if ("executing" === state) throw new Error("Generator is already running"); if ("completed" === state) { if ("throw" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) { if ("suspendedStart" === state) throw state = "completed", context.arg; context.dispatchException(context.arg); } else "return" === context.method && context.abrupt("return", context.arg); state = "executing"; var record = tryCatch(innerFn, self, context); if ("normal" === record.type) { if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } "throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg); } }; }(innerFn, self, context), generator; } function tryCatch(fn, obj, arg) { try { return { type: "normal", arg: fn.call(obj, arg) }; } catch (err) { return { type: "throw", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { ["next", "throw", "return"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if ("throw" !== record.type) { var result = record.arg, value = result.value; return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke("next", value, resolve, reject); }, function (err) { invoke("throw", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke("throw", error, resolve, reject); }); } reject(record.arg); } var previousPromise; this._invoke = function (method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); }; } function maybeInvokeDelegate(delegate, context) { var method = delegate.iterator[context.method]; if (undefined === method) { if (context.delegate = null, "throw" === context.method) { if (delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method)) return ContinueSentinel; context.method = "throw", context.arg = new TypeError("The iterator does not provide a 'throw' method"); } return ContinueSentinel; } var record = tryCatch(method, delegate.iterator, context.arg); if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = "normal", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: "root" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if ("function" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) { if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; } return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, define(Gp, "constructor", GeneratorFunctionPrototype), define(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) { var ctor = "function" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, "toString", function () { return "[object Generator]"; }), exports.keys = function (object) { var keys = []; for (var key in object) { keys.push(key); } return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) { "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); } }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if ("throw" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, "catch": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; } - -function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } - -function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); } - -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } - -function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } - -function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); } - -function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } - -function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } - -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } - -function _awaitAsyncGenerator(value) { return new _AwaitValue(value); } - -function _wrapAsyncGenerator(fn) { return function () { return new _AsyncGenerator(fn.apply(this, arguments)); }; } - -function _AsyncGenerator(gen) { var front, back; function send(key, arg) { return new Promise(function (resolve, reject) { var request = { key: key, arg: arg, resolve: resolve, reject: reject, next: null }; if (back) { back = back.next = request; } else { front = back = request; resume(key, arg); } }); } function resume(key, arg) { try { var result = gen[key](arg); var value = result.value; var wrappedAwait = value instanceof _AwaitValue; Promise.resolve(wrappedAwait ? value.wrapped : value).then(function (arg) { if (wrappedAwait) { resume(key === "return" ? "return" : "next", arg); return; } settle(result.done ? "return" : "normal", arg); }, function (err) { resume("throw", err); }); } catch (err) { settle("throw", err); } } function settle(type, value) { switch (type) { case "return": front.resolve({ value: value, done: true }); break; case "throw": front.reject(value); break; default: front.resolve({ value: value, done: false }); break; } front = front.next; if (front) { resume(front.key, front.arg); } else { back = null; } } this._invoke = send; if (typeof gen["return"] !== "function") { this["return"] = undefined; } } - -_AsyncGenerator.prototype[typeof Symbol === "function" && Symbol.asyncIterator || "@@asyncIterator"] = function () { return this; }; - -_AsyncGenerator.prototype.next = function (arg) { return this._invoke("next", arg); }; - -_AsyncGenerator.prototype["throw"] = function (arg) { return this._invoke("throw", arg); }; - -_AsyncGenerator.prototype["return"] = function (arg) { return this._invoke("return", arg); }; - -function _AwaitValue(value) { this.wrapped = value; } - -/** - * API handler for widgets. This raises events for each action - * received as `action:${action}` (eg: "action:screenshot"). - * Default handling can be prevented by using preventDefault() - * on the raised event. The default handling varies for each - * action: ones which the SDK can handle safely are acknowledged - * appropriately and ones which are unhandled (custom or require - * the widget to do something) are rejected with an error. - * - * Events which are preventDefault()ed must reply using the - * transport. The events raised will have a detail of an - * IWidgetApiRequest interface. - * - * When the WidgetApi is ready to start sending requests, it will - * raise a "ready" CustomEvent. After the ready event fires, actions - * can be sent and the transport will be ready. - */ -var WidgetApi = /*#__PURE__*/function (_EventEmitter) { - _inherits(WidgetApi, _EventEmitter); - - var _super = _createSuper(WidgetApi); - - /** - * Creates a new API handler for the given widget. - * @param {string} widgetId The widget ID to listen for. If not supplied then - * the API will use the widget ID from the first valid request it receives. - * @param {string} clientOrigin The origin of the client, or null if not known. - */ - function WidgetApi() { - var _this2; - - var widgetId = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; - var clientOrigin = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; - - _classCallCheck(this, WidgetApi); - - _this2 = _super.call(this); - _this2.clientOrigin = clientOrigin; - - _defineProperty(_assertThisInitialized(_this2), "transport", void 0); - - _defineProperty(_assertThisInitialized(_this2), "capabilitiesFinished", false); - - _defineProperty(_assertThisInitialized(_this2), "supportsMSC2974Renegotiate", false); - - _defineProperty(_assertThisInitialized(_this2), "requestedCapabilities", []); - - _defineProperty(_assertThisInitialized(_this2), "approvedCapabilities", void 0); - - _defineProperty(_assertThisInitialized(_this2), "cachedClientVersions", void 0); - - _defineProperty(_assertThisInitialized(_this2), "turnServerWatchers", 0); - - if (!window.parent) { - throw new Error("No parent window. This widget doesn't appear to be embedded properly."); - } - - _this2.transport = new _PostmessageTransport.PostmessageTransport(_WidgetApiDirection.WidgetApiDirection.FromWidget, widgetId, window.parent, window); - _this2.transport.targetOrigin = clientOrigin; - - _this2.transport.on("message", _this2.handleMessage.bind(_assertThisInitialized(_this2))); - - return _this2; - } - /** - * Determines if the widget was granted a particular capability. Note that on - * clients where the capabilities are not fed back to the widget this function - * will rely on requested capabilities instead. - * @param {Capability} capability The capability to check for approval of. - * @returns {boolean} True if the widget has approval for the given capability. - */ - - - _createClass(WidgetApi, [{ - key: "hasCapability", - value: function hasCapability(capability) { - if (Array.isArray(this.approvedCapabilities)) { - return this.approvedCapabilities.includes(capability); - } - - return this.requestedCapabilities.includes(capability); - } - /** - * Request a capability from the client. It is not guaranteed to be allowed, - * but will be asked for. - * @param {Capability} capability The capability to request. - * @throws Throws if the capabilities negotiation has already started and the - * widget is unable to request additional capabilities. - */ - - }, { - key: "requestCapability", - value: function requestCapability(capability) { - if (this.capabilitiesFinished && !this.supportsMSC2974Renegotiate) { - throw new Error("Capabilities have already been negotiated"); - } - - this.requestedCapabilities.push(capability); - } - /** - * Request capabilities from the client. They are not guaranteed to be allowed, - * but will be asked for if the negotiation has not already happened. - * @param {Capability[]} capabilities The capabilities to request. - * @throws Throws if the capabilities negotiation has already started. - */ - - }, { - key: "requestCapabilities", - value: function requestCapabilities(capabilities) { - var _this3 = this; - - capabilities.forEach(function (cap) { - return _this3.requestCapability(cap); - }); - } - /** - * Requests the capability to interact with rooms other than the user's currently - * viewed room. Applies to event receiving and sending. - * @param {string | Symbols.AnyRoom} roomId The room ID, or `Symbols.AnyRoom` to - * denote all known rooms. - */ - - }, { - key: "requestCapabilityForRoomTimeline", - value: function requestCapabilityForRoomTimeline(roomId) { - this.requestCapability("org.matrix.msc2762.timeline:".concat(roomId)); - } - /** - * Requests the capability to send a given state event with optional explicit - * state key. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} eventType The state event type to ask for. - * @param {string} stateKey If specified, the specific state key to request. - * Otherwise all state keys will be requested. - */ - - }, { - key: "requestCapabilityToSendState", - value: function requestCapabilityToSendState(eventType, stateKey) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forStateEvent(_WidgetEventCapability.EventDirection.Send, eventType, stateKey).raw); - } - /** - * Requests the capability to receive a given state event with optional explicit - * state key. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} eventType The state event type to ask for. - * @param {string} stateKey If specified, the specific state key to request. - * Otherwise all state keys will be requested. - */ - - }, { - key: "requestCapabilityToReceiveState", - value: function requestCapabilityToReceiveState(eventType, stateKey) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forStateEvent(_WidgetEventCapability.EventDirection.Receive, eventType, stateKey).raw); - } - /** - * Requests the capability to send a given to-device event. It is not - * guaranteed to be allowed, but will be asked for if the negotiation has - * not already happened. - * @param {string} eventType The room event type to ask for. - */ - - }, { - key: "requestCapabilityToSendToDevice", - value: function requestCapabilityToSendToDevice(eventType) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forToDeviceEvent(_WidgetEventCapability.EventDirection.Send, eventType).raw); - } - /** - * Requests the capability to receive a given to-device event. It is not - * guaranteed to be allowed, but will be asked for if the negotiation has - * not already happened. - * @param {string} eventType The room event type to ask for. - */ - - }, { - key: "requestCapabilityToReceiveToDevice", - value: function requestCapabilityToReceiveToDevice(eventType) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forToDeviceEvent(_WidgetEventCapability.EventDirection.Receive, eventType).raw); - } - /** - * Requests the capability to send a given room event. It is not guaranteed to be - * allowed, but will be asked for if the negotiation has not already happened. - * @param {string} eventType The room event type to ask for. - */ - - }, { - key: "requestCapabilityToSendEvent", - value: function requestCapabilityToSendEvent(eventType) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forRoomEvent(_WidgetEventCapability.EventDirection.Send, eventType).raw); - } - /** - * Requests the capability to receive a given room event. It is not guaranteed to be - * allowed, but will be asked for if the negotiation has not already happened. - * @param {string} eventType The room event type to ask for. - */ - - }, { - key: "requestCapabilityToReceiveEvent", - value: function requestCapabilityToReceiveEvent(eventType) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forRoomEvent(_WidgetEventCapability.EventDirection.Receive, eventType).raw); - } - /** - * Requests the capability to send a given message event with optional explicit - * `msgtype`. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} msgtype If specified, the specific msgtype to request. - * Otherwise all message types will be requested. - */ - - }, { - key: "requestCapabilityToSendMessage", - value: function requestCapabilityToSendMessage(msgtype) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forRoomMessageEvent(_WidgetEventCapability.EventDirection.Send, msgtype).raw); - } - /** - * Requests the capability to receive a given message event with optional explicit - * `msgtype`. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} msgtype If specified, the specific msgtype to request. - * Otherwise all message types will be requested. - */ - - }, { - key: "requestCapabilityToReceiveMessage", - value: function requestCapabilityToReceiveMessage(msgtype) { - this.requestCapability(_WidgetEventCapability.WidgetEventCapability.forRoomMessageEvent(_WidgetEventCapability.EventDirection.Receive, msgtype).raw); - } - /** - * Requests an OpenID Connect token from the client for the currently logged in - * user. This token can be validated server-side with the federation API. Note - * that the widget is responsible for validating the token and caching any results - * it needs. - * @returns {Promise} Resolves to a token for verification. - * @throws Throws if the user rejected the request or the request failed. - */ - - }, { - key: "requestOpenIDConnectToken", - value: function requestOpenIDConnectToken() { - var _this4 = this; - - return new Promise(function (resolve, reject) { - _this4.transport.sendComplete(_WidgetApiAction.WidgetApiFromWidgetAction.GetOpenIDCredentials, {}).then(function (response) { - var rdata = response.response; - - if (rdata.state === _GetOpenIDAction.OpenIDRequestState.Allowed) { - resolve(rdata); - } else if (rdata.state === _GetOpenIDAction.OpenIDRequestState.Blocked) { - reject(new Error("User declined to verify their identity")); - } else if (rdata.state === _GetOpenIDAction.OpenIDRequestState.PendingUserConfirmation) { - var handlerFn = function handlerFn(ev) { - ev.preventDefault(); - var request = ev.detail; - if (request.data.original_request_id !== response.requestId) return; - - if (request.data.state === _GetOpenIDAction.OpenIDRequestState.Allowed) { - resolve(request.data); - - _this4.transport.reply(request, {}); // ack - - } else if (request.data.state === _GetOpenIDAction.OpenIDRequestState.Blocked) { - reject(new Error("User declined to verify their identity")); - - _this4.transport.reply(request, {}); // ack - - } else { - reject(new Error("Invalid state on reply: " + rdata.state)); - - _this4.transport.reply(request, { - error: { - message: "Invalid state" - } - }); - } - - _this4.off("action:".concat(_WidgetApiAction.WidgetApiToWidgetAction.OpenIDCredentials), handlerFn); - }; - - _this4.on("action:".concat(_WidgetApiAction.WidgetApiToWidgetAction.OpenIDCredentials), handlerFn); - } else { - reject(new Error("Invalid state: " + rdata.state)); - } - })["catch"](reject); - }); - } - /** - * Asks the client for additional capabilities. Capabilities can be queued for this - * request with the requestCapability() functions. - * @returns {Promise} Resolves when complete. Note that the promise resolves when - * the capabilities request has gone through, not when the capabilities are approved/denied. - * Use the WidgetApiToWidgetAction.NotifyCapabilities action to detect changes. - */ - - }, { - key: "updateRequestedCapabilities", - value: function updateRequestedCapabilities() { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC2974RenegotiateCapabilities, { - capabilities: this.requestedCapabilities - }).then(); - } - /** - * Tell the client that the content has been loaded. - * @returns {Promise} Resolves when the client acknowledges the request. - */ - - }, { - key: "sendContentLoaded", - value: function sendContentLoaded() { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.ContentLoaded, {}).then(); - } - /** - * Sends a sticker to the client. - * @param {IStickerActionRequestData} sticker The sticker to send. - * @returns {Promise} Resolves when the client acknowledges the request. - */ - - }, { - key: "sendSticker", - value: function sendSticker(sticker) { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SendSticker, sticker).then(); - } - /** - * Asks the client to set the always-on-screen status for this widget. - * @param {boolean} value The new state to request. - * @returns {Promise} Resolve with true if the client was able to fulfill - * the request, resolves to false otherwise. Rejects if an error occurred. - */ - - }, { - key: "setAlwaysOnScreen", - value: function setAlwaysOnScreen(value) { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.UpdateAlwaysOnScreen, { - value: value - }).then(function (res) { - return res.success; - }); - } - /** - * Opens a modal widget. - * @param {string} url The URL to the modal widget. - * @param {string} name The name of the widget. - * @param {IModalWidgetOpenRequestDataButton[]} buttons The buttons to have on the widget. - * @param {IModalWidgetCreateData} data Data to supply to the modal widget. - * @param {WidgetType} type The type of modal widget. - * @returns {Promise} Resolves when the modal widget has been opened. - */ - - }, { - key: "openModalWidget", - value: function openModalWidget(url, name) { - var buttons = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : []; - var data = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {}; - var type = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : _WidgetType.MatrixWidgetType.Custom; - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.OpenModalWidget, { - type: type, - url: url, - name: name, - buttons: buttons, - data: data - }).then(); - } - /** - * Closes the modal widget. The widget's session will be terminated shortly after. - * @param {IModalWidgetReturnData} data Optional data to close the modal widget with. - * @returns {Promise} Resolves when complete. - */ - - }, { - key: "closeModalWidget", - value: function closeModalWidget() { - var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.CloseModalWidget, data).then(); - } - }, { - key: "sendRoomEvent", - value: function sendRoomEvent(eventType, content, roomId) { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SendEvent, { - type: eventType, - content: content, - room_id: roomId - }); - } - }, { - key: "sendStateEvent", - value: function sendStateEvent(eventType, stateKey, content, roomId) { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SendEvent, { - type: eventType, - content: content, - state_key: stateKey, - room_id: roomId - }); - } - /** - * Sends a to-device event. - * @param {string} eventType The type of events being sent. - * @param {boolean} encrypted Whether to encrypt the message contents. - * @param {Object} contentMap A map from user IDs to device IDs to message contents. - * @returns {Promise} Resolves when complete. - */ - - }, { - key: "sendToDevice", - value: function sendToDevice(eventType, encrypted, contentMap) { - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SendToDevice, { - type: eventType, - encrypted: encrypted, - messages: contentMap - }); - } - }, { - key: "readRoomEvents", - value: function readRoomEvents(eventType, limit, msgtype, roomIds) { - var data = { - type: eventType, - msgtype: msgtype - }; - - if (limit !== undefined) { - data.limit = limit; - } - - if (roomIds) { - if (roomIds.includes(_Symbols.Symbols.AnyRoom)) { - data.room_ids = _Symbols.Symbols.AnyRoom; - } else { - data.room_ids = roomIds; - } - } - - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC2876ReadEvents, data).then(function (r) { - return r.events; - }); - } - /** - * Reads all related events given a known eventId. - * @param eventId The id of the parent event to be read. - * @param roomId The room to look within. When undefined, the user's currently - * viewed room. - * @param relationType The relationship type of child events to search for. - * When undefined, all relations are returned. - * @param eventType The event type of child events to search for. When undefined, - * all related events are returned. - * @param limit The maximum number of events to retrieve per room. If not - * supplied, the server will apply a default limit. - * @param from The pagination token to start returning results from, as - * received from a previous call. If not supplied, results start at the most - * recent topological event known to the server. - * @param to The pagination token to stop returning results at. If not - * supplied, results continue up to limit or until there are no more events. - * @param direction The direction to search for according to MSC3715. - * @returns Resolves to the room relations. - */ - - }, { - key: "readEventRelations", - value: function () { - var _readEventRelations = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(eventId, roomId, relationType, eventType, limit, from, to, direction) { - var versions, data; - return _regeneratorRuntime().wrap(function _callee$(_context) { - while (1) { - switch (_context.prev = _context.next) { - case 0: - _context.next = 2; - return this.getClientVersions(); - - case 2: - versions = _context.sent; - - if (versions.includes(_ApiVersion.UnstableApiVersion.MSC3869)) { - _context.next = 5; - break; - } - - throw new Error("The read_relations action is not supported by the client."); - - case 5: - data = { - event_id: eventId, - rel_type: relationType, - event_type: eventType, - room_id: roomId, - to: to, - from: from, - limit: limit, - direction: direction - }; - return _context.abrupt("return", this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC3869ReadRelations, data)); - - case 7: - case "end": - return _context.stop(); - } - } - }, _callee, this); - })); - - function readEventRelations(_x, _x2, _x3, _x4, _x5, _x6, _x7, _x8) { - return _readEventRelations.apply(this, arguments); - } - - return readEventRelations; - }() - }, { - key: "readStateEvents", - value: function readStateEvents(eventType, limit, stateKey, roomIds) { - var data = { - type: eventType, - state_key: stateKey === undefined ? true : stateKey - }; - - if (limit !== undefined) { - data.limit = limit; - } - - if (roomIds) { - if (roomIds.includes(_Symbols.Symbols.AnyRoom)) { - data.room_ids = _Symbols.Symbols.AnyRoom; - } else { - data.room_ids = roomIds; - } - } - - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC2876ReadEvents, data).then(function (r) { - return r.events; - }); - } - /** - * Sets a button as disabled or enabled on the modal widget. Buttons are enabled by default. - * @param {ModalButtonID} buttonId The button ID to enable/disable. - * @param {boolean} isEnabled Whether or not the button is enabled. - * @returns {Promise} Resolves when complete. - * @throws Throws if the button cannot be disabled, or the client refuses to disable the button. - */ - - }, { - key: "setModalButtonEnabled", - value: function setModalButtonEnabled(buttonId, isEnabled) { - if (buttonId === _ModalWidgetActions.BuiltInModalButtonID.Close) { - throw new Error("The close button cannot be disabled"); - } - - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SetModalButtonEnabled, { - button: buttonId, - enabled: isEnabled - }).then(); - } - /** - * Attempts to navigate the client to the given URI. This can only be called with Matrix URIs - * (currently only matrix.to, but in future a Matrix URI scheme will be defined). - * @param {string} uri The URI to navigate to. - * @returns {Promise} Resolves when complete. - * @throws Throws if the URI is invalid or cannot be processed. - * @deprecated This currently relies on an unstable MSC (MSC2931). - */ - - }, { - key: "navigateTo", - value: function navigateTo(uri) { - if (!uri || !uri.startsWith("https://matrix.to/#")) { - throw new Error("Invalid matrix.to URI"); - } - - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC2931Navigate, { - uri: uri - }).then(); - } - /** - * Starts watching for TURN servers, yielding an initial set of credentials as soon as possible, - * and thereafter yielding new credentials whenever the previous ones expire. - * @yields {ITurnServer} The TURN server URIs and credentials currently available to the widget. - */ - - }, { - key: "getTurnServers", - value: function getTurnServers() { - var _this = this; - - return _wrapAsyncGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3() { - var setTurnServer, onUpdateTurnServers; - return _regeneratorRuntime().wrap(function _callee3$(_context3) { - while (1) { - switch (_context3.prev = _context3.next) { - case 0: - onUpdateTurnServers = /*#__PURE__*/function () { - var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(ev) { - return _regeneratorRuntime().wrap(function _callee2$(_context2) { - while (1) { - switch (_context2.prev = _context2.next) { - case 0: - ev.preventDefault(); - setTurnServer(ev.detail.data); - _context2.next = 4; - return _this.transport.reply(ev.detail, {}); - - case 4: - case "end": - return _context2.stop(); - } - } - }, _callee2); - })); - - return function onUpdateTurnServers(_x9) { - return _ref.apply(this, arguments); - }; - }(); // Start listening for updates before we even start watching, to catch - // TURN data that is sent immediately - - - _this.on("action:".concat(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers), onUpdateTurnServers); // Only send the 'watch' action if we aren't already watching - - - if (!(_this.turnServerWatchers === 0)) { - _context3.next = 12; - break; - } - - _context3.prev = 3; - _context3.next = 6; - return _awaitAsyncGenerator(_this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.WatchTurnServers, {})); - - case 6: - _context3.next = 12; - break; - - case 8: - _context3.prev = 8; - _context3.t0 = _context3["catch"](3); - - _this.off("action:".concat(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers), onUpdateTurnServers); - - throw _context3.t0; - - case 12: - _this.turnServerWatchers++; - _context3.prev = 13; - - case 14: - if (!true) { - _context3.next = 21; - break; - } - - _context3.next = 17; - return _awaitAsyncGenerator(new Promise(function (resolve) { - return setTurnServer = resolve; - })); - - case 17: - _context3.next = 19; - return _context3.sent; - - case 19: - _context3.next = 14; - break; - - case 21: - _context3.prev = 21; - - // The loop was broken by the caller - clean up - _this.off("action:".concat(_WidgetApiAction.WidgetApiToWidgetAction.UpdateTurnServers), onUpdateTurnServers); // Since sending the 'unwatch' action will end updates for all other - // consumers, only send it if we're the only consumer remaining - - - _this.turnServerWatchers--; - - if (!(_this.turnServerWatchers === 0)) { - _context3.next = 27; - break; - } - - _context3.next = 27; - return _awaitAsyncGenerator(_this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.UnwatchTurnServers, {})); - - case 27: - return _context3.finish(21); - - case 28: - case "end": - return _context3.stop(); - } - } - }, _callee3, null, [[3, 8], [13,, 21, 28]]); - }))(); - } - /** - * Search for users in the user directory. - * @param searchTerm The term to search for. - * @param limit The maximum number of results to return. If not supplied, the - * @returns Resolves to the search results. - */ - - }, { - key: "searchUserDirectory", - value: function () { - var _searchUserDirectory = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee4(searchTerm, limit) { - var versions, data; - return _regeneratorRuntime().wrap(function _callee4$(_context4) { - while (1) { - switch (_context4.prev = _context4.next) { - case 0: - _context4.next = 2; - return this.getClientVersions(); - - case 2: - versions = _context4.sent; - - if (versions.includes(_ApiVersion.UnstableApiVersion.MSC3973)) { - _context4.next = 5; - break; - } - - throw new Error("The user_directory_search action is not supported by the client."); - - case 5: - data = { - search_term: searchTerm, - limit: limit - }; - return _context4.abrupt("return", this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.MSC3973UserDirectorySearch, data)); - - case 7: - case "end": - return _context4.stop(); - } - } - }, _callee4, this); - })); - - function searchUserDirectory(_x10, _x11) { - return _searchUserDirectory.apply(this, arguments); - } - - return searchUserDirectory; - }() - /** - * Starts the communication channel. This should be done early to ensure - * that messages are not missed. Communication can only be stopped by the client. - */ - - }, { - key: "start", - value: function start() { - var _this5 = this; - - this.transport.start(); - this.getClientVersions().then(function (v) { - if (v.includes(_ApiVersion.UnstableApiVersion.MSC2974)) { - _this5.supportsMSC2974Renegotiate = true; - } - }); - } - }, { - key: "handleMessage", - value: function handleMessage(ev) { - var actionEv = new CustomEvent("action:".concat(ev.detail.action), { - detail: ev.detail, - cancelable: true - }); - this.emit("action:".concat(ev.detail.action), actionEv); - - if (!actionEv.defaultPrevented) { - switch (ev.detail.action) { - case _WidgetApiAction.WidgetApiToWidgetAction.SupportedApiVersions: - return this.replyVersions(ev.detail); - - case _WidgetApiAction.WidgetApiToWidgetAction.Capabilities: - return this.handleCapabilities(ev.detail); - - case _WidgetApiAction.WidgetApiToWidgetAction.UpdateVisibility: - return this.transport.reply(ev.detail, {}); - // ack to avoid error spam - - case _WidgetApiAction.WidgetApiToWidgetAction.NotifyCapabilities: - return this.transport.reply(ev.detail, {}); - // ack to avoid error spam - - default: - return this.transport.reply(ev.detail, { - error: { - message: "Unknown or unsupported action: " + ev.detail.action - } - }); - } - } - } - }, { - key: "replyVersions", - value: function replyVersions(request) { - this.transport.reply(request, { - supported_versions: _ApiVersion.CurrentApiVersions - }); - } - }, { - key: "getClientVersions", - value: function getClientVersions() { - var _this6 = this; - - if (Array.isArray(this.cachedClientVersions)) { - return Promise.resolve(this.cachedClientVersions); - } - - return this.transport.send(_WidgetApiAction.WidgetApiFromWidgetAction.SupportedApiVersions, {}).then(function (r) { - _this6.cachedClientVersions = r.supported_versions; - return r.supported_versions; - })["catch"](function (e) { - console.warn("non-fatal error getting supported client versions: ", e); - return []; - }); - } - }, { - key: "handleCapabilities", - value: function handleCapabilities(request) { - var _this7 = this; - - if (this.capabilitiesFinished) { - return this.transport.reply(request, { - error: { - message: "Capability negotiation already completed" - } - }); - } // See if we can expect a capabilities notification or not - - - return this.getClientVersions().then(function (v) { - if (v.includes(_ApiVersion.UnstableApiVersion.MSC2871)) { - _this7.once("action:".concat(_WidgetApiAction.WidgetApiToWidgetAction.NotifyCapabilities), function (ev) { - _this7.approvedCapabilities = ev.detail.data.approved; - - _this7.emit("ready"); - }); - } else { - // if we can't expect notification, we're as done as we can be - _this7.emit("ready"); - } // in either case, reply to that capabilities request - - - _this7.capabilitiesFinished = true; - return _this7.transport.reply(request, { - capabilities: _this7.requestedCapabilities - }); - }); - } - }]); - - return WidgetApi; -}(_events.EventEmitter); - -exports.WidgetApi = WidgetApi; \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/driver/WidgetDriver.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/driver/WidgetDriver.d.ts deleted file mode 100644 index 7ab0cb3..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/driver/WidgetDriver.d.ts +++ /dev/null @@ -1,170 +0,0 @@ -import { Capability, IOpenIDCredentials, OpenIDRequestState, SimpleObservable, IRoomEvent, ITurnServer } from ".."; -export interface ISendEventDetails { - roomId: string; - eventId: string; -} -export interface IOpenIDUpdate { - state: OpenIDRequestState; - token?: IOpenIDCredentials; -} -export interface IReadEventRelationsResult { - chunk: IRoomEvent[]; - nextBatch?: string; - prevBatch?: string; -} -export interface ISearchUserDirectoryResult { - limited: boolean; - results: Array<{ - userId: string; - displayName?: string; - avatarUrl?: string; - }>; -} -/** - * Represents the functions and behaviour the widget-api is unable to - * do, such as prompting the user for information or interacting with - * the UI. Clients are expected to implement this class and override - * any functions they need/want to support. - * - * This class assumes the client will have a context of a Widget - * instance already. - */ -export declare abstract class WidgetDriver { - /** - * Verifies the widget's requested capabilities, returning the ones - * it is approved to use. Mutating the requested capabilities will - * have no effect. - * - * This SHOULD result in the user being prompted to approve/deny - * capabilities. - * - * By default this rejects all capabilities (returns an empty set). - * @param {Set} requested The set of requested capabilities. - * @returns {Promise>} Resolves to the allowed capabilities. - */ - validateCapabilities(requested: Set): Promise>; - /** - * Sends an event into a room. If `roomId` is falsy, the client should send the event - * into the room the user is currently looking at. The widget API will have already - * verified that the widget is capable of sending the event to that room. - * @param {string} eventType The event type to be sent. - * @param {*} content The content for the event. - * @param {string|null} stateKey The state key if this is a state event, otherwise null. - * May be an empty string. - * @param {string|null} roomId The room ID to send the event to. If falsy, the room the - * user is currently looking at. - * @returns {Promise} Resolves when the event has been sent with - * details of that event. - * @throws Rejected when the event could not be sent. - */ - sendEvent(eventType: string, content: unknown, stateKey?: string | null, roomId?: string | null): Promise; - /** - * Sends a to-device event. The widget API will have already verified that the widget - * is capable of sending the event. - * @param {string} eventType The event type to be sent. - * @param {boolean} encrypted Whether to encrypt the message contents. - * @param {Object} contentMap A map from user ID and device ID to event content. - * @returns {Promise} Resolves when the event has been sent. - * @throws Rejected when the event could not be sent. - */ - sendToDevice(eventType: string, encrypted: boolean, contentMap: { - [userId: string]: { - [deviceId: string]: object; - }; - }): Promise; - /** - * Reads all events of the given type, and optionally `msgtype` (if applicable/defined), - * the user has access to. The widget API will have already verified that the widget is - * capable of receiving the events. Less events than the limit are allowed to be returned, - * but not more. If `roomIds` is supplied, it may contain `Symbols.AnyRoom` to denote that - * `limit` in each of the client's known rooms should be returned. When `null`, only the - * room the user is currently looking at should be considered. - * @param eventType The event type to be read. - * @param msgtype The msgtype of the events to be read, if applicable/defined. - * @param limit The maximum number of events to retrieve per room. Will be zero to denote "as many - * as possible". - * @param roomIds When null, the user's currently viewed room. Otherwise, the list of room IDs - * to look within, possibly containing Symbols.AnyRoom to denote all known rooms. - * @returns {Promise} Resolves to the room events, or an empty array. - */ - readRoomEvents(eventType: string, msgtype: string | undefined, limit: number, roomIds?: string[] | null): Promise; - /** - * Reads all events of the given type, and optionally state key (if applicable/defined), - * the user has access to. The widget API will have already verified that the widget is - * capable of receiving the events. Less events than the limit are allowed to be returned, - * but not more. If `roomIds` is supplied, it may contain `Symbols.AnyRoom` to denote that - * `limit` in each of the client's known rooms should be returned. When `null`, only the - * room the user is currently looking at should be considered. - * @param eventType The event type to be read. - * @param stateKey The state key of the events to be read, if applicable/defined. - * @param limit The maximum number of events to retrieve. Will be zero to denote "as many - * as possible". - * @param roomIds When null, the user's currently viewed room. Otherwise, the list of room IDs - * to look within, possibly containing Symbols.AnyRoom to denote all known rooms. - * @returns {Promise} Resolves to the state events, or an empty array. - */ - readStateEvents(eventType: string, stateKey: string | undefined, limit: number, roomIds?: string[] | null): Promise; - /** - * Reads all events that are related to a given event. The widget API will - * have already verified that the widget is capable of receiving the event, - * or will make sure to reject access to events which are returned from this - * function, but are not capable of receiving. If `relationType` or `eventType` - * are set, the returned events should already be filtered. Less events than - * the limit are allowed to be returned, but not more. - * @param eventId The id of the parent event to be read. - * @param roomId The room to look within. When undefined, the user's - * currently viewed room. - * @param relationType The relationship type of child events to search for. - * When undefined, all relations are returned. - * @param eventType The event type of child events to search for. When undefined, - * all related events are returned. - * @param from The pagination token to start returning results from, as - * received from a previous call. If not supplied, results start at the most - * recent topological event known to the server. - * @param to The pagination token to stop returning results at. If not - * supplied, results continue up to limit or until there are no more events. - * @param limit The maximum number of events to retrieve per room. If not - * supplied, the server will apply a default limit. - * @param direction The direction to search for according to MSC3715 - * @returns Resolves to the room relations. - */ - readEventRelations(eventId: string, roomId?: string, relationType?: string, eventType?: string, from?: string, to?: string, limit?: number, direction?: 'f' | 'b'): Promise; - /** - * Asks the user for permission to validate their identity through OpenID Connect. The - * interface for this function is an observable which accepts the state machine of the - * OIDC exchange flow. For example, if the client/user blocks the request then it would - * feed back a `{state: Blocked}` into the observable. Similarly, if the user already - * approved the widget then a `{state: Allowed}` would be fed into the observable alongside - * the token itself. If the client is asking for permission, it should feed in a - * `{state: PendingUserConfirmation}` followed by the relevant Allowed or Blocked state. - * - * The widget API will reject the widget's request with an error if this contract is not - * met properly. By default, the widget driver will block all OIDC requests. - * @param {SimpleObservable} observer The observable to feed updates into. - */ - askOpenID(observer: SimpleObservable): void; - /** - * Navigates the client with a matrix.to URI. In future this function will also be provided - * with the Matrix URIs once matrix.to is replaced. The given URI will have already been - * lightly checked to ensure it looks like a valid URI, though the implementation is recommended - * to do further checks on the URI. - * @param {string} uri The URI to navigate to. - * @returns {Promise} Resolves when complete. - * @throws Throws if there's a problem with the navigation, such as invalid format. - */ - navigate(uri: string): Promise; - /** - * Polls for TURN server data, yielding an initial set of credentials as soon as possible, and - * thereafter yielding new credentials whenever the previous ones expire. The widget API will - * have already verified that the widget has permission to access TURN servers. - * @yields {ITurnServer} The TURN server URIs and credentials currently available to the client. - */ - getTurnServers(): AsyncGenerator; - /** - * Search for users in the user directory. - * @param searchTerm The term to search for. - * @param limit The maximum number of results to return. If not supplied, the - * @returns Resolves to the search results. - */ - searchUserDirectory(searchTerm: string, limit?: number): Promise; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/driver/WidgetDriver.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/driver/WidgetDriver.js deleted file mode 100644 index 5a598b1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/driver/WidgetDriver.js +++ /dev/null @@ -1,229 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetDriver = void 0; - -var _ = require(".."); - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -/** - * Represents the functions and behaviour the widget-api is unable to - * do, such as prompting the user for information or interacting with - * the UI. Clients are expected to implement this class and override - * any functions they need/want to support. - * - * This class assumes the client will have a context of a Widget - * instance already. - */ -var WidgetDriver = /*#__PURE__*/function () { - function WidgetDriver() { - _classCallCheck(this, WidgetDriver); - } - - _createClass(WidgetDriver, [{ - key: "validateCapabilities", - value: - /** - * Verifies the widget's requested capabilities, returning the ones - * it is approved to use. Mutating the requested capabilities will - * have no effect. - * - * This SHOULD result in the user being prompted to approve/deny - * capabilities. - * - * By default this rejects all capabilities (returns an empty set). - * @param {Set} requested The set of requested capabilities. - * @returns {Promise>} Resolves to the allowed capabilities. - */ - function validateCapabilities(requested) { - return Promise.resolve(new Set()); - } - /** - * Sends an event into a room. If `roomId` is falsy, the client should send the event - * into the room the user is currently looking at. The widget API will have already - * verified that the widget is capable of sending the event to that room. - * @param {string} eventType The event type to be sent. - * @param {*} content The content for the event. - * @param {string|null} stateKey The state key if this is a state event, otherwise null. - * May be an empty string. - * @param {string|null} roomId The room ID to send the event to. If falsy, the room the - * user is currently looking at. - * @returns {Promise} Resolves when the event has been sent with - * details of that event. - * @throws Rejected when the event could not be sent. - */ - - }, { - key: "sendEvent", - value: function sendEvent(eventType, content) { - var stateKey = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; - var roomId = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; - return Promise.reject(new Error("Failed to override function")); - } - /** - * Sends a to-device event. The widget API will have already verified that the widget - * is capable of sending the event. - * @param {string} eventType The event type to be sent. - * @param {boolean} encrypted Whether to encrypt the message contents. - * @param {Object} contentMap A map from user ID and device ID to event content. - * @returns {Promise} Resolves when the event has been sent. - * @throws Rejected when the event could not be sent. - */ - - }, { - key: "sendToDevice", - value: function sendToDevice(eventType, encrypted, contentMap) { - return Promise.reject(new Error("Failed to override function")); - } - /** - * Reads all events of the given type, and optionally `msgtype` (if applicable/defined), - * the user has access to. The widget API will have already verified that the widget is - * capable of receiving the events. Less events than the limit are allowed to be returned, - * but not more. If `roomIds` is supplied, it may contain `Symbols.AnyRoom` to denote that - * `limit` in each of the client's known rooms should be returned. When `null`, only the - * room the user is currently looking at should be considered. - * @param eventType The event type to be read. - * @param msgtype The msgtype of the events to be read, if applicable/defined. - * @param limit The maximum number of events to retrieve per room. Will be zero to denote "as many - * as possible". - * @param roomIds When null, the user's currently viewed room. Otherwise, the list of room IDs - * to look within, possibly containing Symbols.AnyRoom to denote all known rooms. - * @returns {Promise} Resolves to the room events, or an empty array. - */ - - }, { - key: "readRoomEvents", - value: function readRoomEvents(eventType, msgtype, limit) { - var roomIds = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; - return Promise.resolve([]); - } - /** - * Reads all events of the given type, and optionally state key (if applicable/defined), - * the user has access to. The widget API will have already verified that the widget is - * capable of receiving the events. Less events than the limit are allowed to be returned, - * but not more. If `roomIds` is supplied, it may contain `Symbols.AnyRoom` to denote that - * `limit` in each of the client's known rooms should be returned. When `null`, only the - * room the user is currently looking at should be considered. - * @param eventType The event type to be read. - * @param stateKey The state key of the events to be read, if applicable/defined. - * @param limit The maximum number of events to retrieve. Will be zero to denote "as many - * as possible". - * @param roomIds When null, the user's currently viewed room. Otherwise, the list of room IDs - * to look within, possibly containing Symbols.AnyRoom to denote all known rooms. - * @returns {Promise} Resolves to the state events, or an empty array. - */ - - }, { - key: "readStateEvents", - value: function readStateEvents(eventType, stateKey, limit) { - var roomIds = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; - return Promise.resolve([]); - } - /** - * Reads all events that are related to a given event. The widget API will - * have already verified that the widget is capable of receiving the event, - * or will make sure to reject access to events which are returned from this - * function, but are not capable of receiving. If `relationType` or `eventType` - * are set, the returned events should already be filtered. Less events than - * the limit are allowed to be returned, but not more. - * @param eventId The id of the parent event to be read. - * @param roomId The room to look within. When undefined, the user's - * currently viewed room. - * @param relationType The relationship type of child events to search for. - * When undefined, all relations are returned. - * @param eventType The event type of child events to search for. When undefined, - * all related events are returned. - * @param from The pagination token to start returning results from, as - * received from a previous call. If not supplied, results start at the most - * recent topological event known to the server. - * @param to The pagination token to stop returning results at. If not - * supplied, results continue up to limit or until there are no more events. - * @param limit The maximum number of events to retrieve per room. If not - * supplied, the server will apply a default limit. - * @param direction The direction to search for according to MSC3715 - * @returns Resolves to the room relations. - */ - - }, { - key: "readEventRelations", - value: function readEventRelations(eventId, roomId, relationType, eventType, from, to, limit, direction) { - return Promise.resolve({ - chunk: [] - }); - } - /** - * Asks the user for permission to validate their identity through OpenID Connect. The - * interface for this function is an observable which accepts the state machine of the - * OIDC exchange flow. For example, if the client/user blocks the request then it would - * feed back a `{state: Blocked}` into the observable. Similarly, if the user already - * approved the widget then a `{state: Allowed}` would be fed into the observable alongside - * the token itself. If the client is asking for permission, it should feed in a - * `{state: PendingUserConfirmation}` followed by the relevant Allowed or Blocked state. - * - * The widget API will reject the widget's request with an error if this contract is not - * met properly. By default, the widget driver will block all OIDC requests. - * @param {SimpleObservable} observer The observable to feed updates into. - */ - - }, { - key: "askOpenID", - value: function askOpenID(observer) { - observer.update({ - state: _.OpenIDRequestState.Blocked - }); - } - /** - * Navigates the client with a matrix.to URI. In future this function will also be provided - * with the Matrix URIs once matrix.to is replaced. The given URI will have already been - * lightly checked to ensure it looks like a valid URI, though the implementation is recommended - * to do further checks on the URI. - * @param {string} uri The URI to navigate to. - * @returns {Promise} Resolves when complete. - * @throws Throws if there's a problem with the navigation, such as invalid format. - */ - - }, { - key: "navigate", - value: function navigate(uri) { - throw new Error("Navigation is not implemented"); - } - /** - * Polls for TURN server data, yielding an initial set of credentials as soon as possible, and - * thereafter yielding new credentials whenever the previous ones expire. The widget API will - * have already verified that the widget has permission to access TURN servers. - * @yields {ITurnServer} The TURN server URIs and credentials currently available to the client. - */ - - }, { - key: "getTurnServers", - value: function getTurnServers() { - throw new Error("TURN server support is not implemented"); - } - /** - * Search for users in the user directory. - * @param searchTerm The term to search for. - * @param limit The maximum number of results to return. If not supplied, the - * @returns Resolves to the search results. - */ - - }, { - key: "searchUserDirectory", - value: function searchUserDirectory(searchTerm, limit) { - return Promise.resolve({ - limited: false, - results: [] - }); - } - }]); - - return WidgetDriver; -}(); - -exports.WidgetDriver = WidgetDriver; \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/index.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/index.d.ts deleted file mode 100644 index f11c89d..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/index.d.ts +++ /dev/null @@ -1,46 +0,0 @@ -export * from "./WidgetApi"; -export * from "./ClientWidgetApi"; -export * from "./Symbols"; -export * from "./transport/ITransport"; -export * from "./transport/PostmessageTransport"; -export * from "./interfaces/ICustomWidgetData"; -export * from "./interfaces/IJitsiWidgetData"; -export * from "./interfaces/IStickerpickerWidgetData"; -export * from "./interfaces/IWidget"; -export * from "./interfaces/WidgetType"; -export * from "./interfaces/IWidgetApiErrorResponse"; -export * from "./interfaces/IWidgetApiRequest"; -export * from "./interfaces/IWidgetApiResponse"; -export * from "./interfaces/WidgetApiAction"; -export * from "./interfaces/WidgetApiDirection"; -export * from "./interfaces/ApiVersion"; -export * from "./interfaces/Capabilities"; -export * from "./interfaces/CapabilitiesAction"; -export * from "./interfaces/ContentLoadedAction"; -export * from "./interfaces/ScreenshotAction"; -export * from "./interfaces/StickerAction"; -export * from "./interfaces/StickyAction"; -export * from "./interfaces/SupportedVersionsAction"; -export * from "./interfaces/VisibilityAction"; -export * from "./interfaces/GetOpenIDAction"; -export * from "./interfaces/OpenIDCredentialsAction"; -export * from "./interfaces/WidgetKind"; -export * from "./interfaces/ModalButtonKind"; -export * from "./interfaces/ModalWidgetActions"; -export * from "./interfaces/SetModalButtonEnabledAction"; -export * from "./interfaces/WidgetConfigAction"; -export * from "./interfaces/SendEventAction"; -export * from "./interfaces/SendToDeviceAction"; -export * from "./interfaces/ReadEventAction"; -export * from "./interfaces/IRoomEvent"; -export * from "./interfaces/NavigateAction"; -export * from "./interfaces/TurnServerActions"; -export * from "./interfaces/ReadRelationsAction"; -export * from "./models/WidgetEventCapability"; -export * from "./models/validation/url"; -export * from "./models/validation/utils"; -export * from "./models/Widget"; -export * from "./models/WidgetParser"; -export * from "./templating/url-template"; -export * from "./util/SimpleObservable"; -export * from "./driver/WidgetDriver"; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/index.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/index.js deleted file mode 100644 index 15a7d2b..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/index.js +++ /dev/null @@ -1,603 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); - -var _WidgetApi = require("./WidgetApi"); - -Object.keys(_WidgetApi).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetApi[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetApi[key]; - } - }); -}); - -var _ClientWidgetApi = require("./ClientWidgetApi"); - -Object.keys(_ClientWidgetApi).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ClientWidgetApi[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ClientWidgetApi[key]; - } - }); -}); - -var _Symbols = require("./Symbols"); - -Object.keys(_Symbols).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _Symbols[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _Symbols[key]; - } - }); -}); - -var _ITransport = require("./transport/ITransport"); - -Object.keys(_ITransport).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ITransport[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ITransport[key]; - } - }); -}); - -var _PostmessageTransport = require("./transport/PostmessageTransport"); - -Object.keys(_PostmessageTransport).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _PostmessageTransport[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _PostmessageTransport[key]; - } - }); -}); - -var _ICustomWidgetData = require("./interfaces/ICustomWidgetData"); - -Object.keys(_ICustomWidgetData).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ICustomWidgetData[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ICustomWidgetData[key]; - } - }); -}); - -var _IJitsiWidgetData = require("./interfaces/IJitsiWidgetData"); - -Object.keys(_IJitsiWidgetData).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IJitsiWidgetData[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IJitsiWidgetData[key]; - } - }); -}); - -var _IStickerpickerWidgetData = require("./interfaces/IStickerpickerWidgetData"); - -Object.keys(_IStickerpickerWidgetData).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IStickerpickerWidgetData[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IStickerpickerWidgetData[key]; - } - }); -}); - -var _IWidget = require("./interfaces/IWidget"); - -Object.keys(_IWidget).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IWidget[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IWidget[key]; - } - }); -}); - -var _WidgetType = require("./interfaces/WidgetType"); - -Object.keys(_WidgetType).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetType[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetType[key]; - } - }); -}); - -var _IWidgetApiErrorResponse = require("./interfaces/IWidgetApiErrorResponse"); - -Object.keys(_IWidgetApiErrorResponse).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IWidgetApiErrorResponse[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IWidgetApiErrorResponse[key]; - } - }); -}); - -var _IWidgetApiRequest = require("./interfaces/IWidgetApiRequest"); - -Object.keys(_IWidgetApiRequest).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IWidgetApiRequest[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IWidgetApiRequest[key]; - } - }); -}); - -var _IWidgetApiResponse = require("./interfaces/IWidgetApiResponse"); - -Object.keys(_IWidgetApiResponse).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IWidgetApiResponse[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IWidgetApiResponse[key]; - } - }); -}); - -var _WidgetApiAction = require("./interfaces/WidgetApiAction"); - -Object.keys(_WidgetApiAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetApiAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetApiAction[key]; - } - }); -}); - -var _WidgetApiDirection = require("./interfaces/WidgetApiDirection"); - -Object.keys(_WidgetApiDirection).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetApiDirection[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetApiDirection[key]; - } - }); -}); - -var _ApiVersion = require("./interfaces/ApiVersion"); - -Object.keys(_ApiVersion).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ApiVersion[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ApiVersion[key]; - } - }); -}); - -var _Capabilities = require("./interfaces/Capabilities"); - -Object.keys(_Capabilities).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _Capabilities[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _Capabilities[key]; - } - }); -}); - -var _CapabilitiesAction = require("./interfaces/CapabilitiesAction"); - -Object.keys(_CapabilitiesAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _CapabilitiesAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _CapabilitiesAction[key]; - } - }); -}); - -var _ContentLoadedAction = require("./interfaces/ContentLoadedAction"); - -Object.keys(_ContentLoadedAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ContentLoadedAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ContentLoadedAction[key]; - } - }); -}); - -var _ScreenshotAction = require("./interfaces/ScreenshotAction"); - -Object.keys(_ScreenshotAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ScreenshotAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ScreenshotAction[key]; - } - }); -}); - -var _StickerAction = require("./interfaces/StickerAction"); - -Object.keys(_StickerAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _StickerAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _StickerAction[key]; - } - }); -}); - -var _StickyAction = require("./interfaces/StickyAction"); - -Object.keys(_StickyAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _StickyAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _StickyAction[key]; - } - }); -}); - -var _SupportedVersionsAction = require("./interfaces/SupportedVersionsAction"); - -Object.keys(_SupportedVersionsAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _SupportedVersionsAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _SupportedVersionsAction[key]; - } - }); -}); - -var _VisibilityAction = require("./interfaces/VisibilityAction"); - -Object.keys(_VisibilityAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _VisibilityAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _VisibilityAction[key]; - } - }); -}); - -var _GetOpenIDAction = require("./interfaces/GetOpenIDAction"); - -Object.keys(_GetOpenIDAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _GetOpenIDAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _GetOpenIDAction[key]; - } - }); -}); - -var _OpenIDCredentialsAction = require("./interfaces/OpenIDCredentialsAction"); - -Object.keys(_OpenIDCredentialsAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _OpenIDCredentialsAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _OpenIDCredentialsAction[key]; - } - }); -}); - -var _WidgetKind = require("./interfaces/WidgetKind"); - -Object.keys(_WidgetKind).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetKind[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetKind[key]; - } - }); -}); - -var _ModalButtonKind = require("./interfaces/ModalButtonKind"); - -Object.keys(_ModalButtonKind).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ModalButtonKind[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ModalButtonKind[key]; - } - }); -}); - -var _ModalWidgetActions = require("./interfaces/ModalWidgetActions"); - -Object.keys(_ModalWidgetActions).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ModalWidgetActions[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ModalWidgetActions[key]; - } - }); -}); - -var _SetModalButtonEnabledAction = require("./interfaces/SetModalButtonEnabledAction"); - -Object.keys(_SetModalButtonEnabledAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _SetModalButtonEnabledAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _SetModalButtonEnabledAction[key]; - } - }); -}); - -var _WidgetConfigAction = require("./interfaces/WidgetConfigAction"); - -Object.keys(_WidgetConfigAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetConfigAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetConfigAction[key]; - } - }); -}); - -var _SendEventAction = require("./interfaces/SendEventAction"); - -Object.keys(_SendEventAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _SendEventAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _SendEventAction[key]; - } - }); -}); - -var _SendToDeviceAction = require("./interfaces/SendToDeviceAction"); - -Object.keys(_SendToDeviceAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _SendToDeviceAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _SendToDeviceAction[key]; - } - }); -}); - -var _ReadEventAction = require("./interfaces/ReadEventAction"); - -Object.keys(_ReadEventAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ReadEventAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ReadEventAction[key]; - } - }); -}); - -var _IRoomEvent = require("./interfaces/IRoomEvent"); - -Object.keys(_IRoomEvent).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _IRoomEvent[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _IRoomEvent[key]; - } - }); -}); - -var _NavigateAction = require("./interfaces/NavigateAction"); - -Object.keys(_NavigateAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _NavigateAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _NavigateAction[key]; - } - }); -}); - -var _TurnServerActions = require("./interfaces/TurnServerActions"); - -Object.keys(_TurnServerActions).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _TurnServerActions[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _TurnServerActions[key]; - } - }); -}); - -var _ReadRelationsAction = require("./interfaces/ReadRelationsAction"); - -Object.keys(_ReadRelationsAction).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _ReadRelationsAction[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _ReadRelationsAction[key]; - } - }); -}); - -var _WidgetEventCapability = require("./models/WidgetEventCapability"); - -Object.keys(_WidgetEventCapability).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetEventCapability[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetEventCapability[key]; - } - }); -}); - -var _url = require("./models/validation/url"); - -Object.keys(_url).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _url[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _url[key]; - } - }); -}); - -var _utils = require("./models/validation/utils"); - -Object.keys(_utils).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _utils[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _utils[key]; - } - }); -}); - -var _Widget = require("./models/Widget"); - -Object.keys(_Widget).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _Widget[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _Widget[key]; - } - }); -}); - -var _WidgetParser = require("./models/WidgetParser"); - -Object.keys(_WidgetParser).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetParser[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetParser[key]; - } - }); -}); - -var _urlTemplate = require("./templating/url-template"); - -Object.keys(_urlTemplate).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _urlTemplate[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _urlTemplate[key]; - } - }); -}); - -var _SimpleObservable = require("./util/SimpleObservable"); - -Object.keys(_SimpleObservable).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _SimpleObservable[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _SimpleObservable[key]; - } - }); -}); - -var _WidgetDriver = require("./driver/WidgetDriver"); - -Object.keys(_WidgetDriver).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _WidgetDriver[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function get() { - return _WidgetDriver[key]; - } - }); -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ApiVersion.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ApiVersion.d.ts deleted file mode 100644 index 1234c5b..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ApiVersion.d.ts +++ /dev/null @@ -1,17 +0,0 @@ -export declare enum MatrixApiVersion { - Prerelease1 = "0.0.1", - Prerelease2 = "0.0.2" -} -export declare enum UnstableApiVersion { - MSC2762 = "org.matrix.msc2762", - MSC2871 = "org.matrix.msc2871", - MSC2931 = "org.matrix.msc2931", - MSC2974 = "org.matrix.msc2974", - MSC2876 = "org.matrix.msc2876", - MSC3819 = "org.matrix.msc3819", - MSC3846 = "town.robin.msc3846", - MSC3869 = "org.matrix.msc3869", - MSC3973 = "org.matrix.msc3973" -} -export declare type ApiVersion = MatrixApiVersion | UnstableApiVersion | string; -export declare const CurrentApiVersions: ApiVersion[]; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ApiVersion.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ApiVersion.js deleted file mode 100644 index 2454c0a..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ApiVersion.js +++ /dev/null @@ -1,48 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.UnstableApiVersion = exports.MatrixApiVersion = exports.CurrentApiVersions = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var MatrixApiVersion; -exports.MatrixApiVersion = MatrixApiVersion; - -(function (MatrixApiVersion) { - MatrixApiVersion["Prerelease1"] = "0.0.1"; - MatrixApiVersion["Prerelease2"] = "0.0.2"; -})(MatrixApiVersion || (exports.MatrixApiVersion = MatrixApiVersion = {})); - -var UnstableApiVersion; -exports.UnstableApiVersion = UnstableApiVersion; - -(function (UnstableApiVersion) { - UnstableApiVersion["MSC2762"] = "org.matrix.msc2762"; - UnstableApiVersion["MSC2871"] = "org.matrix.msc2871"; - UnstableApiVersion["MSC2931"] = "org.matrix.msc2931"; - UnstableApiVersion["MSC2974"] = "org.matrix.msc2974"; - UnstableApiVersion["MSC2876"] = "org.matrix.msc2876"; - UnstableApiVersion["MSC3819"] = "org.matrix.msc3819"; - UnstableApiVersion["MSC3846"] = "town.robin.msc3846"; - UnstableApiVersion["MSC3869"] = "org.matrix.msc3869"; - UnstableApiVersion["MSC3973"] = "org.matrix.msc3973"; -})(UnstableApiVersion || (exports.UnstableApiVersion = UnstableApiVersion = {})); - -var CurrentApiVersions = [MatrixApiVersion.Prerelease1, MatrixApiVersion.Prerelease2, //MatrixApiVersion.V010, -UnstableApiVersion.MSC2762, UnstableApiVersion.MSC2871, UnstableApiVersion.MSC2931, UnstableApiVersion.MSC2974, UnstableApiVersion.MSC2876, UnstableApiVersion.MSC3819, UnstableApiVersion.MSC3846, UnstableApiVersion.MSC3869, UnstableApiVersion.MSC3973]; -exports.CurrentApiVersions = CurrentApiVersions; \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/Capabilities.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/Capabilities.d.ts deleted file mode 100644 index 941e359..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/Capabilities.d.ts +++ /dev/null @@ -1,42 +0,0 @@ -import { Symbols } from "../Symbols"; -export declare enum MatrixCapabilities { - Screenshots = "m.capability.screenshot", - StickerSending = "m.sticker", - AlwaysOnScreen = "m.always_on_screen", - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - * Ask Element to not give the option to move the widget into a separate tab. - */ - RequiresClient = "io.element.requires_client", - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC2931Navigate = "org.matrix.msc2931.navigate", - MSC3846TurnServers = "town.robin.msc3846.turn_servers", - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC3973UserDirectorySearch = "org.matrix.msc3973.user_directory_search" -} -export declare type Capability = MatrixCapabilities | string; -export declare const StickerpickerCapabilities: Capability[]; -export declare const VideoConferenceCapabilities: Capability[]; -/** - * Determines if a capability is a capability for a timeline. - * @param {Capability} capability The capability to test. - * @returns {boolean} True if a timeline capability, false otherwise. - */ -export declare function isTimelineCapability(capability: Capability): boolean; -/** - * Determines if a capability is a timeline capability for the given room. - * @param {Capability} capability The capability to test. - * @param {string | Symbols.AnyRoom} roomId The room ID, or `Symbols.AnyRoom` for that designation. - * @returns {boolean} True if a matching capability, false otherwise. - */ -export declare function isTimelineCapabilityFor(capability: Capability, roomId: string | Symbols.AnyRoom): boolean; -/** - * Gets the room ID described by a timeline capability. - * @param {string} capability The capability to parse. - * @returns {string} The room ID. - */ -export declare function getTimelineRoomIDFromCapability(capability: Capability): string; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/Capabilities.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/Capabilities.js deleted file mode 100644 index 110b91a..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/Capabilities.js +++ /dev/null @@ -1,74 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.VideoConferenceCapabilities = exports.StickerpickerCapabilities = exports.MatrixCapabilities = void 0; -exports.getTimelineRoomIDFromCapability = getTimelineRoomIDFromCapability; -exports.isTimelineCapability = isTimelineCapability; -exports.isTimelineCapabilityFor = isTimelineCapabilityFor; - -/* - * Copyright 2020 - 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var MatrixCapabilities; -exports.MatrixCapabilities = MatrixCapabilities; - -(function (MatrixCapabilities) { - MatrixCapabilities["Screenshots"] = "m.capability.screenshot"; - MatrixCapabilities["StickerSending"] = "m.sticker"; - MatrixCapabilities["AlwaysOnScreen"] = "m.always_on_screen"; - MatrixCapabilities["RequiresClient"] = "io.element.requires_client"; - MatrixCapabilities["MSC2931Navigate"] = "org.matrix.msc2931.navigate"; - MatrixCapabilities["MSC3846TurnServers"] = "town.robin.msc3846.turn_servers"; - MatrixCapabilities["MSC3973UserDirectorySearch"] = "org.matrix.msc3973.user_directory_search"; -})(MatrixCapabilities || (exports.MatrixCapabilities = MatrixCapabilities = {})); - -var StickerpickerCapabilities = [MatrixCapabilities.StickerSending]; -exports.StickerpickerCapabilities = StickerpickerCapabilities; -var VideoConferenceCapabilities = [MatrixCapabilities.AlwaysOnScreen]; -/** - * Determines if a capability is a capability for a timeline. - * @param {Capability} capability The capability to test. - * @returns {boolean} True if a timeline capability, false otherwise. - */ - -exports.VideoConferenceCapabilities = VideoConferenceCapabilities; - -function isTimelineCapability(capability) { - // TODO: Change when MSC2762 becomes stable. - return capability === null || capability === void 0 ? void 0 : capability.startsWith("org.matrix.msc2762.timeline:"); -} -/** - * Determines if a capability is a timeline capability for the given room. - * @param {Capability} capability The capability to test. - * @param {string | Symbols.AnyRoom} roomId The room ID, or `Symbols.AnyRoom` for that designation. - * @returns {boolean} True if a matching capability, false otherwise. - */ - - -function isTimelineCapabilityFor(capability, roomId) { - return capability === "org.matrix.msc2762.timeline:".concat(roomId); -} -/** - * Gets the room ID described by a timeline capability. - * @param {string} capability The capability to parse. - * @returns {string} The room ID. - */ - - -function getTimelineRoomIDFromCapability(capability) { - return capability.substring(capability.indexOf(":") + 1); -} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/CapabilitiesAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/CapabilitiesAction.d.ts deleted file mode 100644 index c8fb957..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/CapabilitiesAction.d.ts +++ /dev/null @@ -1,34 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData, IWidgetApiRequestEmptyData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { Capability } from "./Capabilities"; -import { IWidgetApiAcknowledgeResponseData, IWidgetApiResponseData } from "./IWidgetApiResponse"; -export interface ICapabilitiesActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.Capabilities; - data: IWidgetApiRequestEmptyData; -} -export interface ICapabilitiesActionResponseData extends IWidgetApiResponseData { - capabilities: Capability[]; -} -export interface ICapabilitiesActionResponse extends ICapabilitiesActionRequest { - response: ICapabilitiesActionResponseData; -} -export interface INotifyCapabilitiesActionRequestData extends IWidgetApiRequestData { - requested: Capability[]; - approved: Capability[]; -} -export interface INotifyCapabilitiesActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.NotifyCapabilities; - data: INotifyCapabilitiesActionRequestData; -} -export interface INotifyCapabilitiesActionResponse extends INotifyCapabilitiesActionRequest { - response: IWidgetApiAcknowledgeResponseData; -} -export interface IRenegotiateCapabilitiesActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.MSC2974RenegotiateCapabilities; - data: IRenegotiateCapabilitiesRequestData; -} -export interface IRenegotiateCapabilitiesRequestData extends IWidgetApiResponseData { - capabilities: Capability[]; -} -export interface IRenegotiateCapabilitiesActionResponse extends IRenegotiateCapabilitiesActionRequest { -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/CapabilitiesAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/CapabilitiesAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/CapabilitiesAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ContentLoadedAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ContentLoadedAction.d.ts deleted file mode 100644 index 65a768c..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ContentLoadedAction.d.ts +++ /dev/null @@ -1,10 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestEmptyData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData } from "./IWidgetApiResponse"; -export interface IContentLoadedActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.ContentLoaded; - data: IWidgetApiRequestEmptyData; -} -export interface IContentLoadedActionResponse extends IContentLoadedActionRequest { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ContentLoadedAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ContentLoadedAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ContentLoadedAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/GetOpenIDAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/GetOpenIDAction.d.ts deleted file mode 100644 index 0b090f9..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/GetOpenIDAction.d.ts +++ /dev/null @@ -1,26 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -export declare enum OpenIDRequestState { - Allowed = "allowed", - Blocked = "blocked", - PendingUserConfirmation = "request" -} -export interface IOpenIDCredentials { - access_token?: string; - expires_in?: number; - matrix_server_name?: string; - token_type?: "Bearer" | string; -} -export interface IGetOpenIDActionRequestData extends IWidgetApiRequestData { -} -export interface IGetOpenIDActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.GetOpenIDCredentials; - data: IGetOpenIDActionRequestData; -} -export interface IGetOpenIDActionResponseData extends IWidgetApiResponseData, IOpenIDCredentials { - state: OpenIDRequestState; -} -export interface IGetOpenIDActionResponse extends IGetOpenIDActionRequest { - response: IGetOpenIDActionResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/GetOpenIDAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/GetOpenIDAction.js deleted file mode 100644 index 4a38dfa..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/GetOpenIDAction.js +++ /dev/null @@ -1,30 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.OpenIDRequestState = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var OpenIDRequestState; -exports.OpenIDRequestState = OpenIDRequestState; - -(function (OpenIDRequestState) { - OpenIDRequestState["Allowed"] = "allowed"; - OpenIDRequestState["Blocked"] = "blocked"; - OpenIDRequestState["PendingUserConfirmation"] = "request"; -})(OpenIDRequestState || (exports.OpenIDRequestState = OpenIDRequestState = {})); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ICustomWidgetData.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ICustomWidgetData.d.ts deleted file mode 100644 index 862ab54..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ICustomWidgetData.d.ts +++ /dev/null @@ -1,10 +0,0 @@ -import { IWidgetData } from "./IWidget"; -/** - * Widget data for m.custom specifically. - */ -export interface ICustomWidgetData extends IWidgetData { - /** - * The URL for the widget if the templated URL is not exactly what will be loaded. - */ - url?: string; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ICustomWidgetData.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ICustomWidgetData.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ICustomWidgetData.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IJitsiWidgetData.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IJitsiWidgetData.d.ts deleted file mode 100644 index 695b322..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IJitsiWidgetData.d.ts +++ /dev/null @@ -1,19 +0,0 @@ -import { IWidgetData } from "./IWidget"; -/** - * Widget data for m.jitsi widgets. - */ -export interface IJitsiWidgetData extends IWidgetData { - /** - * The domain where the Jitsi Meet conference is being held. - */ - domain: string; - /** - * The conference ID (also known as the room name) where the conference is being held. - */ - conferenceId: string; - /** - * Optional. True to indicate that the conference should be without video, false - * otherwise (default). - */ - isAudioOnly?: boolean; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IJitsiWidgetData.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IJitsiWidgetData.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IJitsiWidgetData.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IRoomEvent.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IRoomEvent.d.ts deleted file mode 100644 index 15b258c..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IRoomEvent.d.ts +++ /dev/null @@ -1,10 +0,0 @@ -export interface IRoomEvent { - type: string; - sender: string; - event_id: string; - room_id: string; - state_key?: string; - origin_server_ts: number; - content: unknown; - unsigned: unknown; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IRoomEvent.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IRoomEvent.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IRoomEvent.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IStickerpickerWidgetData.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IStickerpickerWidgetData.d.ts deleted file mode 100644 index 5188bab..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IStickerpickerWidgetData.d.ts +++ /dev/null @@ -1,3 +0,0 @@ -import { IWidgetData } from "./IWidget"; -export interface IStickerpickerWidgetData extends IWidgetData { -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IStickerpickerWidgetData.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IStickerpickerWidgetData.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IStickerpickerWidgetData.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidget.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidget.d.ts deleted file mode 100644 index fbc3d90..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidget.d.ts +++ /dev/null @@ -1,50 +0,0 @@ -import { WidgetType } from "./WidgetType"; -/** - * Widget data. - */ -export interface IWidgetData { - /** - * Optional title for the widget. - */ - title?: string; - /** - * Custom keys for inclusion in the template URL. - */ - [key: string]: unknown; -} -/** - * Common properties of a widget. - * https://matrix.org/docs/spec/widgets/latest#widgetcommonproperties-schema - */ -export interface IWidget { - /** - * The ID of the widget. - */ - id: string; - /** - * The user ID who originally created the widget. - */ - creatorUserId: string; - /** - * Optional name for the widget. - */ - name?: string; - /** - * The type of widget. - */ - type: WidgetType; - /** - * The URL for the widget, with template variables. - */ - url: string; - /** - * Optional flag to indicate whether or not the client should initiate communication - * right after the iframe loads (default, true) or when the widget indicates it is - * ready (false). - */ - waitForIframeLoad?: boolean; - /** - * Data for the widget. - */ - data?: IWidgetData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidget.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidget.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidget.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiErrorResponse.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiErrorResponse.d.ts deleted file mode 100644 index af8105f..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiErrorResponse.d.ts +++ /dev/null @@ -1,10 +0,0 @@ -import { IWidgetApiResponse, IWidgetApiResponseData } from "./IWidgetApiResponse"; -export interface IWidgetApiErrorResponseData extends IWidgetApiResponseData { - error: { - message: string; - }; -} -export interface IWidgetApiErrorResponse extends IWidgetApiResponse { - response: IWidgetApiErrorResponseData; -} -export declare function isErrorResponse(responseData: IWidgetApiResponseData): boolean; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiErrorResponse.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiErrorResponse.js deleted file mode 100644 index e20ea22..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiErrorResponse.js +++ /dev/null @@ -1,30 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.isErrorResponse = isErrorResponse; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function isErrorResponse(responseData) { - if ("error" in responseData) { - var err = responseData; - return !!err.error.message; - } - - return false; -} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiRequest.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiRequest.d.ts deleted file mode 100644 index 1e43391..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiRequest.d.ts +++ /dev/null @@ -1,15 +0,0 @@ -import { WidgetApiDirection } from "./WidgetApiDirection"; -import { WidgetApiAction } from "./WidgetApiAction"; -export interface IWidgetApiRequestData { - [key: string]: unknown; -} -export interface IWidgetApiRequestEmptyData extends IWidgetApiRequestData { -} -export interface IWidgetApiRequest { - api: WidgetApiDirection; - requestId: string; - action: WidgetApiAction; - widgetId: string; - data: IWidgetApiRequestData; - visible?: any; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiRequest.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiRequest.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiRequest.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiResponse.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiResponse.d.ts deleted file mode 100644 index df28eac..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiResponse.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -import { IWidgetApiRequest } from "./IWidgetApiRequest"; -export interface IWidgetApiResponseData { - [key: string]: unknown; -} -export interface IWidgetApiAcknowledgeResponseData extends IWidgetApiResponseData { -} -export interface IWidgetApiResponse extends IWidgetApiRequest { - response: IWidgetApiResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiResponse.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiResponse.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/IWidgetApiResponse.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalButtonKind.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalButtonKind.d.ts deleted file mode 100644 index 71c9feb..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalButtonKind.d.ts +++ /dev/null @@ -1,7 +0,0 @@ -export declare enum ModalButtonKind { - Primary = "m.primary", - Secondary = "m.secondary", - Warning = "m.warning", - Danger = "m.danger", - Link = "m.link" -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalButtonKind.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalButtonKind.js deleted file mode 100644 index 25d3b66..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalButtonKind.js +++ /dev/null @@ -1,32 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ModalButtonKind = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var ModalButtonKind; -exports.ModalButtonKind = ModalButtonKind; - -(function (ModalButtonKind) { - ModalButtonKind["Primary"] = "m.primary"; - ModalButtonKind["Secondary"] = "m.secondary"; - ModalButtonKind["Warning"] = "m.warning"; - ModalButtonKind["Danger"] = "m.danger"; - ModalButtonKind["Link"] = "m.link"; -})(ModalButtonKind || (exports.ModalButtonKind = ModalButtonKind = {})); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalWidgetActions.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalWidgetActions.d.ts deleted file mode 100644 index 52089b8..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalWidgetActions.d.ts +++ /dev/null @@ -1,55 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData, IWidgetApiResponse } from "./IWidgetApiResponse"; -import { IWidget } from "./IWidget"; -import { ModalButtonKind } from "./ModalButtonKind"; -export declare enum BuiltInModalButtonID { - Close = "m.close" -} -export declare type ModalButtonID = BuiltInModalButtonID | string; -export interface IModalWidgetCreateData extends IWidgetApiRequestData { - [key: string]: unknown; -} -export interface IModalWidgetReturnData { - [key: string]: unknown; -} -export interface IModalWidgetOpenRequestDataButton { - id: ModalButtonID; - label: string; - kind: ModalButtonKind | string; - disabled?: boolean; -} -export interface IModalWidgetOpenRequestData extends IModalWidgetCreateData, Omit { - buttons?: IModalWidgetOpenRequestDataButton[]; -} -export interface IModalWidgetOpenRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.OpenModalWidget; - data: IModalWidgetOpenRequestData; -} -export interface IModalWidgetOpenResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} -export interface IModalWidgetButtonClickedRequestData extends IWidgetApiRequestData { - id: IModalWidgetOpenRequestDataButton["id"]; -} -export interface IModalWidgetButtonClickedRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.ButtonClicked; - data: IModalWidgetButtonClickedRequestData; -} -export interface IModalWidgetButtonClickedResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} -export interface IModalWidgetCloseRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.CloseModalWidget; - data: IModalWidgetReturnData; -} -export interface IModalWidgetCloseResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} -export interface IModalWidgetCloseNotificationRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.CloseModalWidget; - data: IModalWidgetReturnData; -} -export interface IModalWidgetCloseNotificationResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalWidgetActions.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalWidgetActions.js deleted file mode 100644 index 39dc434..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ModalWidgetActions.js +++ /dev/null @@ -1,28 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.BuiltInModalButtonID = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var BuiltInModalButtonID; -exports.BuiltInModalButtonID = BuiltInModalButtonID; - -(function (BuiltInModalButtonID) { - BuiltInModalButtonID["Close"] = "m.close"; -})(BuiltInModalButtonID || (exports.BuiltInModalButtonID = BuiltInModalButtonID = {})); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/NavigateAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/NavigateAction.d.ts deleted file mode 100644 index a0447dd..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/NavigateAction.d.ts +++ /dev/null @@ -1,13 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData } from "./IWidgetApiResponse"; -export interface INavigateActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.MSC2931Navigate; - data: INavigateActionRequestData; -} -export interface INavigateActionRequestData extends IWidgetApiRequestData { - uri: string; -} -export interface INavigateActionResponse extends INavigateActionRequest { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/NavigateAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/NavigateAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/NavigateAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/OpenIDCredentialsAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/OpenIDCredentialsAction.d.ts deleted file mode 100644 index 7cd0410..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/OpenIDCredentialsAction.d.ts +++ /dev/null @@ -1,17 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -import { IOpenIDCredentials, OpenIDRequestState } from "./GetOpenIDAction"; -export interface IOpenIDCredentialsActionRequestData extends IWidgetApiRequestData, IOpenIDCredentials { - state: OpenIDRequestState; - original_request_id: string; -} -export interface IOpenIDCredentialsActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.OpenIDCredentials; - data: IOpenIDCredentialsActionRequestData; -} -export interface IOpenIDCredentialsActionResponseData extends IWidgetApiResponseData { -} -export interface IOpenIDCredentialsIDActionResponse extends IOpenIDCredentialsActionRequest { - response: IOpenIDCredentialsActionResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/OpenIDCredentialsAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/OpenIDCredentialsAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/OpenIDCredentialsAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadEventAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadEventAction.d.ts deleted file mode 100644 index 807f9be..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadEventAction.d.ts +++ /dev/null @@ -1,22 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -import { IRoomEvent } from "./IRoomEvent"; -import { Symbols } from "../Symbols"; -export interface IReadEventFromWidgetRequestData extends IWidgetApiRequestData { - state_key?: string | boolean; - msgtype?: string; - type: string; - limit?: number; - room_ids?: Symbols.AnyRoom | string[]; -} -export interface IReadEventFromWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.MSC2876ReadEvents; - data: IReadEventFromWidgetRequestData; -} -export interface IReadEventFromWidgetResponseData extends IWidgetApiResponseData { - events: IRoomEvent[]; -} -export interface IReadEventFromWidgetActionResponse extends IReadEventFromWidgetActionRequest { - response: IReadEventFromWidgetResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadEventAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadEventAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadEventAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadRelationsAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadRelationsAction.d.ts deleted file mode 100644 index 0d15dfe..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadRelationsAction.d.ts +++ /dev/null @@ -1,26 +0,0 @@ -import { IRoomEvent } from "./IRoomEvent"; -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -export interface IReadRelationsFromWidgetRequestData extends IWidgetApiRequestData { - event_id: string; - rel_type?: string; - event_type?: string; - room_id?: string; - limit?: number; - from?: string; - to?: string; - direction?: 'f' | 'b'; -} -export interface IReadRelationsFromWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.MSC3869ReadRelations; - data: IReadRelationsFromWidgetRequestData; -} -export interface IReadRelationsFromWidgetResponseData extends IWidgetApiResponseData { - chunk: IRoomEvent[]; - next_batch?: string; - prev_batch?: string; -} -export interface IReadRelationsFromWidgetActionResponse extends IReadRelationsFromWidgetActionRequest { - response: IReadRelationsFromWidgetResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadRelationsAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadRelationsAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ReadRelationsAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ScreenshotAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ScreenshotAction.d.ts deleted file mode 100644 index 7f0f62a..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ScreenshotAction.d.ts +++ /dev/null @@ -1,13 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestEmptyData } from "./IWidgetApiRequest"; -import { WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -export interface IScreenshotActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.TakeScreenshot; - data: IWidgetApiRequestEmptyData; -} -export interface IScreenshotActionResponseData extends IWidgetApiResponseData { - screenshot: Blob; -} -export interface IScreenshotActionResponse extends IScreenshotActionRequest { - response: IScreenshotActionResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ScreenshotAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ScreenshotAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/ScreenshotAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendEventAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendEventAction.d.ts deleted file mode 100644 index cb27110..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendEventAction.d.ts +++ /dev/null @@ -1,32 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -import { IRoomEvent } from "./IRoomEvent"; -export interface ISendEventFromWidgetRequestData extends IWidgetApiRequestData { - state_key?: string; - type: string; - content: unknown; - room_id?: string; -} -export interface ISendEventFromWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.SendEvent; - data: ISendEventFromWidgetRequestData; -} -export interface ISendEventFromWidgetResponseData extends IWidgetApiResponseData { - room_id: string; - event_id: string; -} -export interface ISendEventFromWidgetActionResponse extends ISendEventFromWidgetActionRequest { - response: ISendEventFromWidgetResponseData; -} -export interface ISendEventToWidgetRequestData extends IWidgetApiRequestData, IRoomEvent { -} -export interface ISendEventToWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.SendEvent; - data: ISendEventToWidgetRequestData; -} -export interface ISendEventToWidgetResponseData extends IWidgetApiResponseData { -} -export interface ISendEventToWidgetActionResponse extends ISendEventToWidgetActionRequest { - response: ISendEventToWidgetResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendEventAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendEventAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendEventAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendToDeviceAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendToDeviceAction.d.ts deleted file mode 100644 index f9e3841..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendToDeviceAction.d.ts +++ /dev/null @@ -1,34 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -import { IRoomEvent } from "./IRoomEvent"; -export interface ISendToDeviceFromWidgetRequestData extends IWidgetApiRequestData { - type: string; - encrypted: boolean; - messages: { - [userId: string]: { - [deviceId: string]: object; - }; - }; -} -export interface ISendToDeviceFromWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.SendToDevice; - data: ISendToDeviceFromWidgetRequestData; -} -export interface ISendToDeviceFromWidgetResponseData extends IWidgetApiResponseData { -} -export interface ISendToDeviceFromWidgetActionResponse extends ISendToDeviceFromWidgetActionRequest { - response: ISendToDeviceFromWidgetResponseData; -} -export interface ISendToDeviceToWidgetRequestData extends IWidgetApiRequestData, IRoomEvent { - encrypted: boolean; -} -export interface ISendToDeviceToWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.SendToDevice; - data: ISendToDeviceToWidgetRequestData; -} -export interface ISendToDeviceToWidgetResponseData extends IWidgetApiResponseData { -} -export interface ISendToDeviceToWidgetActionResponse extends ISendToDeviceToWidgetActionRequest { - response: ISendToDeviceToWidgetResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendToDeviceAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendToDeviceAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SendToDeviceAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SetModalButtonEnabledAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SetModalButtonEnabledAction.d.ts deleted file mode 100644 index 177dfce..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SetModalButtonEnabledAction.d.ts +++ /dev/null @@ -1,15 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData } from "./IWidgetApiResponse"; -import { ModalButtonID } from "./ModalWidgetActions"; -export interface ISetModalButtonEnabledActionRequestData extends IWidgetApiRequestData { - enabled: boolean; - button: ModalButtonID; -} -export interface ISetModalButtonEnabledActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.SetModalButtonEnabled; - data: ISetModalButtonEnabledActionRequestData; -} -export interface ISetModalButtonEnabledActionResponse extends ISetModalButtonEnabledActionRequest { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SetModalButtonEnabledAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SetModalButtonEnabledAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SetModalButtonEnabledAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickerAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickerAction.d.ts deleted file mode 100644 index 0ae474b..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickerAction.d.ts +++ /dev/null @@ -1,29 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData } from "./IWidgetApiResponse"; -export interface IStickerActionRequestData extends IWidgetApiRequestData { - name: string; - description?: string; - content: { - url: string; - info?: { - h?: number; - w?: number; - mimetype?: string; - size?: number; - thumbnail_info?: { - h?: number; - w?: number; - mimetype?: string; - size?: number; - }; - }; - }; -} -export interface IStickerActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.SendSticker; - data: IStickerActionRequestData; -} -export interface IStickerActionResponse extends IStickerActionRequest { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickerAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickerAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickerAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickyAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickyAction.d.ts deleted file mode 100644 index bb6faa4..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickyAction.d.ts +++ /dev/null @@ -1,16 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -export interface IStickyActionRequestData extends IWidgetApiRequestData { - value: boolean; -} -export interface IStickyActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.UpdateAlwaysOnScreen; - data: IStickyActionRequestData; -} -export interface IStickyActionResponseData extends IWidgetApiResponseData { - success: boolean; -} -export interface IStickyActionResponse extends IStickyActionRequest { - response: IStickyActionResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickyAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickyAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/StickyAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SupportedVersionsAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SupportedVersionsAction.d.ts deleted file mode 100644 index 3e1dd13..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SupportedVersionsAction.d.ts +++ /dev/null @@ -1,14 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestEmptyData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { ApiVersion } from "./ApiVersion"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -export interface ISupportedVersionsActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.SupportedApiVersions | WidgetApiToWidgetAction.SupportedApiVersions; - data: IWidgetApiRequestEmptyData; -} -export interface ISupportedVersionsActionResponseData extends IWidgetApiResponseData { - supported_versions: ApiVersion[]; -} -export interface ISupportedVersionsActionResponse extends ISupportedVersionsActionRequest { - response: ISupportedVersionsActionResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SupportedVersionsAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SupportedVersionsAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/SupportedVersionsAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/TurnServerActions.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/TurnServerActions.d.ts deleted file mode 100644 index 55d5b3d..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/TurnServerActions.d.ts +++ /dev/null @@ -1,31 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData, IWidgetApiRequestEmptyData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData, IWidgetApiResponse } from "./IWidgetApiResponse"; -export interface ITurnServer { - uris: string[]; - username: string; - password: string; -} -export interface IWatchTurnServersRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.WatchTurnServers; - data: IWidgetApiRequestEmptyData; -} -export interface IWatchTurnServersResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} -export interface IUnwatchTurnServersRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.UnwatchTurnServers; - data: IWidgetApiRequestEmptyData; -} -export interface IUnwatchTurnServersResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} -export interface IUpdateTurnServersRequestData extends IWidgetApiRequestData, ITurnServer { -} -export interface IUpdateTurnServersRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.UpdateTurnServers; - data: IUpdateTurnServersRequestData; -} -export interface IUpdateTurnServersResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/TurnServerActions.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/TurnServerActions.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/TurnServerActions.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/UserDirectorySearchAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/UserDirectorySearchAction.d.ts deleted file mode 100644 index 923cfa1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/UserDirectorySearchAction.d.ts +++ /dev/null @@ -1,22 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -export interface IUserDirectorySearchFromWidgetRequestData extends IWidgetApiRequestData { - search_term: string; - limit?: number; -} -export interface IUserDirectorySearchFromWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.MSC3973UserDirectorySearch; - data: IUserDirectorySearchFromWidgetRequestData; -} -export interface IUserDirectorySearchFromWidgetResponseData extends IWidgetApiResponseData { - limited: boolean; - results: Array<{ - user_id: string; - display_name?: string; - avatar_url?: string; - }>; -} -export interface IUserDirectorySearchFromWidgetActionResponse extends IUserDirectorySearchFromWidgetActionRequest { - response: IUserDirectorySearchFromWidgetResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/UserDirectorySearchAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/UserDirectorySearchAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/UserDirectorySearchAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/VisibilityAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/VisibilityAction.d.ts deleted file mode 100644 index 814f9e9..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/VisibilityAction.d.ts +++ /dev/null @@ -1,13 +0,0 @@ -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData } from "./IWidgetApiResponse"; -export interface IVisibilityActionRequestData extends IWidgetApiRequestData { - visible: boolean; -} -export interface IVisibilityActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.UpdateVisibility; - data: IVisibilityActionRequestData; -} -export interface IVisibilityActionResponse extends IVisibilityActionRequest { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/VisibilityAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/VisibilityAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/VisibilityAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiAction.d.ts deleted file mode 100644 index 0e67d07..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiAction.d.ts +++ /dev/null @@ -1,49 +0,0 @@ -export declare enum WidgetApiToWidgetAction { - SupportedApiVersions = "supported_api_versions", - Capabilities = "capabilities", - NotifyCapabilities = "notify_capabilities", - TakeScreenshot = "screenshot", - UpdateVisibility = "visibility", - OpenIDCredentials = "openid_credentials", - WidgetConfig = "widget_config", - CloseModalWidget = "close_modal", - ButtonClicked = "button_clicked", - SendEvent = "send_event", - SendToDevice = "send_to_device", - UpdateTurnServers = "update_turn_servers" -} -export declare enum WidgetApiFromWidgetAction { - SupportedApiVersions = "supported_api_versions", - ContentLoaded = "content_loaded", - SendSticker = "m.sticker", - UpdateAlwaysOnScreen = "set_always_on_screen", - GetOpenIDCredentials = "get_openid", - CloseModalWidget = "close_modal", - OpenModalWidget = "open_modal", - SetModalButtonEnabled = "set_button_enabled", - SendEvent = "send_event", - SendToDevice = "send_to_device", - WatchTurnServers = "watch_turn_servers", - UnwatchTurnServers = "unwatch_turn_servers", - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC2876ReadEvents = "org.matrix.msc2876.read_events", - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC2931Navigate = "org.matrix.msc2931.navigate", - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC2974RenegotiateCapabilities = "org.matrix.msc2974.request_capabilities", - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC3869ReadRelations = "org.matrix.msc3869.read_relations", - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC3973UserDirectorySearch = "org.matrix.msc3973.user_directory_search" -} -export declare type WidgetApiAction = WidgetApiToWidgetAction | WidgetApiFromWidgetAction | string; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiAction.js deleted file mode 100644 index 2a2aede..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiAction.js +++ /dev/null @@ -1,62 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetApiToWidgetAction = exports.WidgetApiFromWidgetAction = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var WidgetApiToWidgetAction; -exports.WidgetApiToWidgetAction = WidgetApiToWidgetAction; - -(function (WidgetApiToWidgetAction) { - WidgetApiToWidgetAction["SupportedApiVersions"] = "supported_api_versions"; - WidgetApiToWidgetAction["Capabilities"] = "capabilities"; - WidgetApiToWidgetAction["NotifyCapabilities"] = "notify_capabilities"; - WidgetApiToWidgetAction["TakeScreenshot"] = "screenshot"; - WidgetApiToWidgetAction["UpdateVisibility"] = "visibility"; - WidgetApiToWidgetAction["OpenIDCredentials"] = "openid_credentials"; - WidgetApiToWidgetAction["WidgetConfig"] = "widget_config"; - WidgetApiToWidgetAction["CloseModalWidget"] = "close_modal"; - WidgetApiToWidgetAction["ButtonClicked"] = "button_clicked"; - WidgetApiToWidgetAction["SendEvent"] = "send_event"; - WidgetApiToWidgetAction["SendToDevice"] = "send_to_device"; - WidgetApiToWidgetAction["UpdateTurnServers"] = "update_turn_servers"; -})(WidgetApiToWidgetAction || (exports.WidgetApiToWidgetAction = WidgetApiToWidgetAction = {})); - -var WidgetApiFromWidgetAction; -exports.WidgetApiFromWidgetAction = WidgetApiFromWidgetAction; - -(function (WidgetApiFromWidgetAction) { - WidgetApiFromWidgetAction["SupportedApiVersions"] = "supported_api_versions"; - WidgetApiFromWidgetAction["ContentLoaded"] = "content_loaded"; - WidgetApiFromWidgetAction["SendSticker"] = "m.sticker"; - WidgetApiFromWidgetAction["UpdateAlwaysOnScreen"] = "set_always_on_screen"; - WidgetApiFromWidgetAction["GetOpenIDCredentials"] = "get_openid"; - WidgetApiFromWidgetAction["CloseModalWidget"] = "close_modal"; - WidgetApiFromWidgetAction["OpenModalWidget"] = "open_modal"; - WidgetApiFromWidgetAction["SetModalButtonEnabled"] = "set_button_enabled"; - WidgetApiFromWidgetAction["SendEvent"] = "send_event"; - WidgetApiFromWidgetAction["SendToDevice"] = "send_to_device"; - WidgetApiFromWidgetAction["WatchTurnServers"] = "watch_turn_servers"; - WidgetApiFromWidgetAction["UnwatchTurnServers"] = "unwatch_turn_servers"; - WidgetApiFromWidgetAction["MSC2876ReadEvents"] = "org.matrix.msc2876.read_events"; - WidgetApiFromWidgetAction["MSC2931Navigate"] = "org.matrix.msc2931.navigate"; - WidgetApiFromWidgetAction["MSC2974RenegotiateCapabilities"] = "org.matrix.msc2974.request_capabilities"; - WidgetApiFromWidgetAction["MSC3869ReadRelations"] = "org.matrix.msc3869.read_relations"; - WidgetApiFromWidgetAction["MSC3973UserDirectorySearch"] = "org.matrix.msc3973.user_directory_search"; -})(WidgetApiFromWidgetAction || (exports.WidgetApiFromWidgetAction = WidgetApiFromWidgetAction = {})); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiDirection.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiDirection.d.ts deleted file mode 100644 index 19e58f4..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiDirection.d.ts +++ /dev/null @@ -1,5 +0,0 @@ -export declare enum WidgetApiDirection { - ToWidget = "toWidget", - FromWidget = "fromWidget" -} -export declare function invertedDirection(dir: WidgetApiDirection): WidgetApiDirection; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiDirection.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiDirection.js deleted file mode 100644 index 69f296c..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetApiDirection.js +++ /dev/null @@ -1,40 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetApiDirection = void 0; -exports.invertedDirection = invertedDirection; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var WidgetApiDirection; -exports.WidgetApiDirection = WidgetApiDirection; - -(function (WidgetApiDirection) { - WidgetApiDirection["ToWidget"] = "toWidget"; - WidgetApiDirection["FromWidget"] = "fromWidget"; -})(WidgetApiDirection || (exports.WidgetApiDirection = WidgetApiDirection = {})); - -function invertedDirection(dir) { - if (dir === WidgetApiDirection.ToWidget) { - return WidgetApiDirection.FromWidget; - } else if (dir === WidgetApiDirection.FromWidget) { - return WidgetApiDirection.ToWidget; - } else { - throw new Error("Invalid direction"); - } -} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetConfigAction.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetConfigAction.d.ts deleted file mode 100644 index 1d23330..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetConfigAction.d.ts +++ /dev/null @@ -1,11 +0,0 @@ -import { IWidgetApiRequest } from "./IWidgetApiRequest"; -import { WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData, IWidgetApiResponse } from "./IWidgetApiResponse"; -import { IModalWidgetOpenRequestData } from "./ModalWidgetActions"; -export interface IWidgetConfigRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.WidgetConfig; - data: IModalWidgetOpenRequestData; -} -export interface IWidgetConfigResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetConfigAction.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetConfigAction.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetConfigAction.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetKind.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetKind.d.ts deleted file mode 100644 index ee039b8..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetKind.d.ts +++ /dev/null @@ -1,5 +0,0 @@ -export declare enum WidgetKind { - Room = "room", - Account = "account", - Modal = "modal" -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetKind.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetKind.js deleted file mode 100644 index 1f0c622..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetKind.js +++ /dev/null @@ -1,30 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetKind = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var WidgetKind; -exports.WidgetKind = WidgetKind; - -(function (WidgetKind) { - WidgetKind["Room"] = "room"; - WidgetKind["Account"] = "account"; - WidgetKind["Modal"] = "modal"; -})(WidgetKind || (exports.WidgetKind = WidgetKind = {})); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetType.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetType.d.ts deleted file mode 100644 index 87cb6c2..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetType.d.ts +++ /dev/null @@ -1,6 +0,0 @@ -export declare enum MatrixWidgetType { - Custom = "m.custom", - JitsiMeet = "m.jitsi", - Stickerpicker = "m.stickerpicker" -} -export declare type WidgetType = MatrixWidgetType | string; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetType.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetType.js deleted file mode 100644 index 5a96344..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/interfaces/WidgetType.js +++ /dev/null @@ -1,30 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MatrixWidgetType = void 0; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var MatrixWidgetType; -exports.MatrixWidgetType = MatrixWidgetType; - -(function (MatrixWidgetType) { - MatrixWidgetType["Custom"] = "m.custom"; - MatrixWidgetType["JitsiMeet"] = "m.jitsi"; - MatrixWidgetType["Stickerpicker"] = "m.stickerpicker"; -})(MatrixWidgetType || (exports.MatrixWidgetType = MatrixWidgetType = {})); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/Widget.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/models/Widget.d.ts deleted file mode 100644 index d2278e6..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/Widget.d.ts +++ /dev/null @@ -1,53 +0,0 @@ -import { IWidget, IWidgetData, WidgetType } from ".."; -import { ITemplateParams } from ".."; -/** - * Represents the barest form of widget. - */ -export declare class Widget { - private definition; - constructor(definition: IWidget); - /** - * The user ID who created the widget. - */ - get creatorUserId(): string; - /** - * The type of widget. - */ - get type(): WidgetType; - /** - * The ID of the widget. - */ - get id(): string; - /** - * The name of the widget, or null if not set. - */ - get name(): string | null; - /** - * The title for the widget, or null if not set. - */ - get title(): string | null; - /** - * The templated URL for the widget. - */ - get templateUrl(): string; - /** - * The origin for this widget. - */ - get origin(): string; - /** - * Whether or not the client should wait for the iframe to load. Defaults - * to true. - */ - get waitForIframeLoad(): boolean; - /** - * The raw data for the widget. This will always be defined, though - * may be empty. - */ - get rawData(): IWidgetData; - /** - * Gets a complete widget URL for the client to render. - * @param {ITemplateParams} params The template parameters. - * @returns {string} A templated URL. - */ - getCompleteUrl(params: ITemplateParams): string; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/Widget.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/models/Widget.js deleted file mode 100644 index 4650c54..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/Widget.js +++ /dev/null @@ -1,134 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.Widget = void 0; - -var _utils = require("./validation/utils"); - -var _ = require(".."); - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -/** - * Represents the barest form of widget. - */ -var Widget = /*#__PURE__*/function () { - function Widget(definition) { - _classCallCheck(this, Widget); - - this.definition = definition; - if (!this.definition) throw new Error("Definition is required"); - (0, _utils.assertPresent)(definition, "id"); - (0, _utils.assertPresent)(definition, "creatorUserId"); - (0, _utils.assertPresent)(definition, "type"); - (0, _utils.assertPresent)(definition, "url"); - } - /** - * The user ID who created the widget. - */ - - - _createClass(Widget, [{ - key: "creatorUserId", - get: function get() { - return this.definition.creatorUserId; - } - /** - * The type of widget. - */ - - }, { - key: "type", - get: function get() { - return this.definition.type; - } - /** - * The ID of the widget. - */ - - }, { - key: "id", - get: function get() { - return this.definition.id; - } - /** - * The name of the widget, or null if not set. - */ - - }, { - key: "name", - get: function get() { - return this.definition.name || null; - } - /** - * The title for the widget, or null if not set. - */ - - }, { - key: "title", - get: function get() { - return this.rawData.title || null; - } - /** - * The templated URL for the widget. - */ - - }, { - key: "templateUrl", - get: function get() { - return this.definition.url; - } - /** - * The origin for this widget. - */ - - }, { - key: "origin", - get: function get() { - return new URL(this.templateUrl).origin; - } - /** - * Whether or not the client should wait for the iframe to load. Defaults - * to true. - */ - - }, { - key: "waitForIframeLoad", - get: function get() { - if (this.definition.waitForIframeLoad === false) return false; - if (this.definition.waitForIframeLoad === true) return true; - return true; // default true - } - /** - * The raw data for the widget. This will always be defined, though - * may be empty. - */ - - }, { - key: "rawData", - get: function get() { - return this.definition.data || {}; - } - /** - * Gets a complete widget URL for the client to render. - * @param {ITemplateParams} params The template parameters. - * @returns {string} A templated URL. - */ - - }, { - key: "getCompleteUrl", - value: function getCompleteUrl(params) { - return (0, _.runTemplate)(this.templateUrl, this.definition, params); - } - }]); - - return Widget; -}(); - -exports.Widget = Widget; \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetEventCapability.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetEventCapability.d.ts deleted file mode 100644 index c0fbcdb..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetEventCapability.d.ts +++ /dev/null @@ -1,31 +0,0 @@ -import { Capability } from ".."; -export declare enum EventKind { - Event = "event", - State = "state_event", - ToDevice = "to_device" -} -export declare enum EventDirection { - Send = "send", - Receive = "receive" -} -export declare class WidgetEventCapability { - readonly direction: EventDirection; - readonly eventType: string; - readonly kind: EventKind; - readonly keyStr: string | null; - readonly raw: string; - private constructor(); - matchesAsStateEvent(direction: EventDirection, eventType: string, stateKey: string | null): boolean; - matchesAsToDeviceEvent(direction: EventDirection, eventType: string): boolean; - matchesAsRoomEvent(direction: EventDirection, eventType: string, msgtype?: string | null): boolean; - static forStateEvent(direction: EventDirection, eventType: string, stateKey?: string): WidgetEventCapability; - static forToDeviceEvent(direction: EventDirection, eventType: string): WidgetEventCapability; - static forRoomEvent(direction: EventDirection, eventType: string): WidgetEventCapability; - static forRoomMessageEvent(direction: EventDirection, msgtype?: string): WidgetEventCapability; - /** - * Parses a capabilities request to find all the event capability requests. - * @param {Iterable} capabilities The capabilities requested/to parse. - * @returns {WidgetEventCapability[]} An array of event capability requests. May be empty, but never null. - */ - static findEventCapabilities(capabilities: Iterable): WidgetEventCapability[]; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetEventCapability.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetEventCapability.js deleted file mode 100644 index 337665e..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetEventCapability.js +++ /dev/null @@ -1,253 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetEventCapability = exports.EventKind = exports.EventDirection = void 0; - -function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; } - -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } - -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var EventKind; -exports.EventKind = EventKind; - -(function (EventKind) { - EventKind["Event"] = "event"; - EventKind["State"] = "state_event"; - EventKind["ToDevice"] = "to_device"; -})(EventKind || (exports.EventKind = EventKind = {})); - -var EventDirection; -exports.EventDirection = EventDirection; - -(function (EventDirection) { - EventDirection["Send"] = "send"; - EventDirection["Receive"] = "receive"; -})(EventDirection || (exports.EventDirection = EventDirection = {})); - -var WidgetEventCapability = /*#__PURE__*/function () { - function WidgetEventCapability(direction, eventType, kind, keyStr, raw) { - _classCallCheck(this, WidgetEventCapability); - - this.direction = direction; - this.eventType = eventType; - this.kind = kind; - this.keyStr = keyStr; - this.raw = raw; - } - - _createClass(WidgetEventCapability, [{ - key: "matchesAsStateEvent", - value: function matchesAsStateEvent(direction, eventType, stateKey) { - if (this.kind !== EventKind.State) return false; // not a state event - - if (this.direction !== direction) return false; // direction mismatch - - if (this.eventType !== eventType) return false; // event type mismatch - - if (this.keyStr === null) return true; // all state keys are allowed - - if (this.keyStr === stateKey) return true; // this state key is allowed - // Default not allowed - - return false; - } - }, { - key: "matchesAsToDeviceEvent", - value: function matchesAsToDeviceEvent(direction, eventType) { - if (this.kind !== EventKind.ToDevice) return false; // not a to-device event - - if (this.direction !== direction) return false; // direction mismatch - - if (this.eventType !== eventType) return false; // event type mismatch - // Checks passed, the event is allowed - - return true; - } - }, { - key: "matchesAsRoomEvent", - value: function matchesAsRoomEvent(direction, eventType) { - var msgtype = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; - if (this.kind !== EventKind.Event) return false; // not a room event - - if (this.direction !== direction) return false; // direction mismatch - - if (this.eventType !== eventType) return false; // event type mismatch - - if (this.eventType === "m.room.message") { - if (this.keyStr === null) return true; // all message types are allowed - - if (this.keyStr === msgtype) return true; // this message type is allowed - } else { - return true; // already passed the check for if the event is allowed - } // Default not allowed - - - return false; - } - }], [{ - key: "forStateEvent", - value: function forStateEvent(direction, eventType, stateKey) { - // TODO: Enable support for m.* namespace once the MSC lands. - // https://github.com/matrix-org/matrix-widget-api/issues/22 - eventType = eventType.replace(/#/g, '\\#'); - stateKey = stateKey !== null && stateKey !== undefined ? "#".concat(stateKey) : ''; - var str = "org.matrix.msc2762.".concat(direction, ".state_event:").concat(eventType).concat(stateKey); // cheat by sending it through the processor - - return WidgetEventCapability.findEventCapabilities([str])[0]; - } - }, { - key: "forToDeviceEvent", - value: function forToDeviceEvent(direction, eventType) { - // TODO: Enable support for m.* namespace once the MSC lands. - // https://github.com/matrix-org/matrix-widget-api/issues/56 - var str = "org.matrix.msc3819.".concat(direction, ".to_device:").concat(eventType); // cheat by sending it through the processor - - return WidgetEventCapability.findEventCapabilities([str])[0]; - } - }, { - key: "forRoomEvent", - value: function forRoomEvent(direction, eventType) { - // TODO: Enable support for m.* namespace once the MSC lands. - // https://github.com/matrix-org/matrix-widget-api/issues/22 - var str = "org.matrix.msc2762.".concat(direction, ".event:").concat(eventType); // cheat by sending it through the processor - - return WidgetEventCapability.findEventCapabilities([str])[0]; - } - }, { - key: "forRoomMessageEvent", - value: function forRoomMessageEvent(direction, msgtype) { - // TODO: Enable support for m.* namespace once the MSC lands. - // https://github.com/matrix-org/matrix-widget-api/issues/22 - msgtype = msgtype === null || msgtype === undefined ? '' : msgtype; - var str = "org.matrix.msc2762.".concat(direction, ".event:m.room.message#").concat(msgtype); // cheat by sending it through the processor - - return WidgetEventCapability.findEventCapabilities([str])[0]; - } - /** - * Parses a capabilities request to find all the event capability requests. - * @param {Iterable} capabilities The capabilities requested/to parse. - * @returns {WidgetEventCapability[]} An array of event capability requests. May be empty, but never null. - */ - - }, { - key: "findEventCapabilities", - value: function findEventCapabilities(capabilities) { - var parsed = []; - - var _iterator = _createForOfIteratorHelper(capabilities), - _step; - - try { - for (_iterator.s(); !(_step = _iterator.n()).done;) { - var cap = _step.value; - var _direction = null; - var eventSegment = void 0; - var _kind = null; // TODO: Enable support for m.* namespace once the MSCs land. - // https://github.com/matrix-org/matrix-widget-api/issues/22 - // https://github.com/matrix-org/matrix-widget-api/issues/56 - - if (cap.startsWith("org.matrix.msc2762.send.event:")) { - _direction = EventDirection.Send; - _kind = EventKind.Event; - eventSegment = cap.substring("org.matrix.msc2762.send.event:".length); - } else if (cap.startsWith("org.matrix.msc2762.send.state_event:")) { - _direction = EventDirection.Send; - _kind = EventKind.State; - eventSegment = cap.substring("org.matrix.msc2762.send.state_event:".length); - } else if (cap.startsWith("org.matrix.msc3819.send.to_device:")) { - _direction = EventDirection.Send; - _kind = EventKind.ToDevice; - eventSegment = cap.substring("org.matrix.msc3819.send.to_device:".length); - } else if (cap.startsWith("org.matrix.msc2762.receive.event:")) { - _direction = EventDirection.Receive; - _kind = EventKind.Event; - eventSegment = cap.substring("org.matrix.msc2762.receive.event:".length); - } else if (cap.startsWith("org.matrix.msc2762.receive.state_event:")) { - _direction = EventDirection.Receive; - _kind = EventKind.State; - eventSegment = cap.substring("org.matrix.msc2762.receive.state_event:".length); - } else if (cap.startsWith("org.matrix.msc3819.receive.to_device:")) { - _direction = EventDirection.Receive; - _kind = EventKind.ToDevice; - eventSegment = cap.substring("org.matrix.msc3819.receive.to_device:".length); - } - - if (_direction === null || _kind === null || eventSegment === undefined) continue; // The capability uses `#` as a separator between event type and state key/msgtype, - // so we split on that. However, a # is also valid in either one of those so we - // join accordingly. - // Eg: `m.room.message##m.text` is "m.room.message" event with msgtype "#m.text". - - var expectingKeyStr = eventSegment.startsWith("m.room.message#") || _kind === EventKind.State; - - var _keyStr = null; - - if (eventSegment.includes('#') && expectingKeyStr) { - // Dev note: regex is difficult to write, so instead the rules are manually written - // out. This is probably just as understandable as a boring regex though, so win-win? - // Test cases: - // str eventSegment keyStr - // ------------------------------------------------------------- - // m.room.message# m.room.message - // m.room.message#test m.room.message test - // m.room.message\# m.room.message# test - // m.room.message##test m.room.message #test - // m.room.message\##test m.room.message# test - // m.room.message\\##test m.room.message\# test - // m.room.message\\###test m.room.message\# #test - // First step: explode the string - var parts = eventSegment.split('#'); // To form the eventSegment, we'll keep finding parts of the exploded string until - // there's one that doesn't end with the escape character (\). We'll then join those - // segments together with the exploding character. We have to remember to consume the - // escape character as well. - - var idx = parts.findIndex(function (p) { - return !p.endsWith("\\"); - }); - eventSegment = parts.slice(0, idx + 1).map(function (p) { - return p.endsWith('\\') ? p.substring(0, p.length - 1) : p; - }).join('#'); // The keyStr is whatever is left over. - - _keyStr = parts.slice(idx + 1).join('#'); - } - - parsed.push(new WidgetEventCapability(_direction, eventSegment, _kind, _keyStr, cap)); - } - } catch (err) { - _iterator.e(err); - } finally { - _iterator.f(); - } - - return parsed; - } - }]); - - return WidgetEventCapability; -}(); - -exports.WidgetEventCapability = WidgetEventCapability; \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetParser.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetParser.d.ts deleted file mode 100644 index f0cde3b..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetParser.d.ts +++ /dev/null @@ -1,46 +0,0 @@ -import { Widget } from "./Widget"; -import { IWidget } from ".."; -export interface IStateEvent { - event_id: string; - room_id: string; - type: string; - sender: string; - origin_server_ts: number; - unsigned?: unknown; - content: unknown; - state_key: string; -} -export interface IAccountDataWidgets { - [widgetId: string]: { - type: "m.widget"; - state_key: string; - sender: string; - content: IWidget; - id?: string; - }; -} -export declare class WidgetParser { - private constructor(); - /** - * Parses widgets from the "m.widgets" account data event. This will always - * return an array, though may be empty if no valid widgets were found. - * @param {IAccountDataWidgets} content The content of the "m.widgets" account data. - * @returns {Widget[]} The widgets in account data, or an empty array. - */ - static parseAccountData(content: IAccountDataWidgets): Widget[]; - /** - * Parses all the widgets possible in the given array. This will always return - * an array, though may be empty if no widgets could be parsed. - * @param {IStateEvent[]} currentState The room state to parse. - * @returns {Widget[]} The widgets in the state, or an empty array. - */ - static parseWidgetsFromRoomState(currentState: IStateEvent[]): Widget[]; - /** - * Parses a state event into a widget. If the state event does not represent - * a widget (wrong event type, invalid widget, etc) then null is returned. - * @param {IStateEvent} stateEvent The state event. - * @returns {Widget|null} The widget, or null if invalid - */ - static parseRoomWidget(stateEvent: IStateEvent): Widget | null; - private static processEstimatedWidget; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetParser.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetParser.js deleted file mode 100644 index 42c61d8..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/WidgetParser.js +++ /dev/null @@ -1,150 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WidgetParser = void 0; - -var _Widget = require("./Widget"); - -var _url = require("./validation/url"); - -function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; } - -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } - -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -var WidgetParser = /*#__PURE__*/function () { - function WidgetParser() {// private constructor because this is a util class - - _classCallCheck(this, WidgetParser); - } - /** - * Parses widgets from the "m.widgets" account data event. This will always - * return an array, though may be empty if no valid widgets were found. - * @param {IAccountDataWidgets} content The content of the "m.widgets" account data. - * @returns {Widget[]} The widgets in account data, or an empty array. - */ - - - _createClass(WidgetParser, null, [{ - key: "parseAccountData", - value: function parseAccountData(content) { - if (!content) return []; - var result = []; - - for (var _i = 0, _Object$keys = Object.keys(content); _i < _Object$keys.length; _i++) { - var _widgetId = _Object$keys[_i]; - var roughWidget = content[_widgetId]; - if (!roughWidget) continue; - if (roughWidget.type !== "m.widget" && roughWidget.type !== "im.vector.modular.widgets") continue; - if (!roughWidget.sender) continue; - var probableWidgetId = roughWidget.state_key || roughWidget.id; - if (probableWidgetId !== _widgetId) continue; - var asStateEvent = { - content: roughWidget.content, - sender: roughWidget.sender, - type: "m.widget", - state_key: _widgetId, - event_id: "$example", - room_id: "!example", - origin_server_ts: 1 - }; - var widget = WidgetParser.parseRoomWidget(asStateEvent); - if (widget) result.push(widget); - } - - return result; - } - /** - * Parses all the widgets possible in the given array. This will always return - * an array, though may be empty if no widgets could be parsed. - * @param {IStateEvent[]} currentState The room state to parse. - * @returns {Widget[]} The widgets in the state, or an empty array. - */ - - }, { - key: "parseWidgetsFromRoomState", - value: function parseWidgetsFromRoomState(currentState) { - if (!currentState) return []; - var result = []; - - var _iterator = _createForOfIteratorHelper(currentState), - _step; - - try { - for (_iterator.s(); !(_step = _iterator.n()).done;) { - var state = _step.value; - var widget = WidgetParser.parseRoomWidget(state); - if (widget) result.push(widget); - } - } catch (err) { - _iterator.e(err); - } finally { - _iterator.f(); - } - - return result; - } - /** - * Parses a state event into a widget. If the state event does not represent - * a widget (wrong event type, invalid widget, etc) then null is returned. - * @param {IStateEvent} stateEvent The state event. - * @returns {Widget|null} The widget, or null if invalid - */ - - }, { - key: "parseRoomWidget", - value: function parseRoomWidget(stateEvent) { - if (!stateEvent) return null; // TODO: [Legacy] Remove legacy support - - if (stateEvent.type !== "m.widget" && stateEvent.type !== "im.vector.modular.widgets") { - return null; - } // Dev note: Throughout this function we have null safety to ensure that - // if the caller did not supply something useful that we don't error. This - // is done against the requirements of the interface because not everyone - // will have an interface to validate against. - - - var content = stateEvent.content || {}; // Form our best approximation of a widget with the information we have - - var estimatedWidget = { - id: stateEvent.state_key, - creatorUserId: content['creatorUserId'] || stateEvent.sender, - name: content['name'], - type: content['type'], - url: content['url'], - waitForIframeLoad: content['waitForIframeLoad'], - data: content['data'] - }; // Finally, process that widget - - return WidgetParser.processEstimatedWidget(estimatedWidget); - } - }, { - key: "processEstimatedWidget", - value: function processEstimatedWidget(widget) { - // Validate that the widget has the best chance of passing as a widget - if (!widget.id || !widget.creatorUserId || !widget.type) { - return null; - } - - if (!(0, _url.isValidUrl)(widget.url)) { - return null; - } // TODO: Validate data for known widget types - - - return new _Widget.Widget(widget); - } - }]); - - return WidgetParser; -}(); - -exports.WidgetParser = WidgetParser; \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/url.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/url.d.ts deleted file mode 100644 index 0c6625d..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/url.d.ts +++ /dev/null @@ -1 +0,0 @@ -export declare function isValidUrl(val: string): boolean; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/url.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/url.js deleted file mode 100644 index 1e927f9..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/url.js +++ /dev/null @@ -1,41 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.isValidUrl = isValidUrl; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function isValidUrl(val) { - if (!val) return false; // easy: not valid if not present - - try { - var parsed = new URL(val); - - if (parsed.protocol !== "http" && parsed.protocol !== "https") { - return false; - } - - return true; - } catch (e) { - if (e instanceof TypeError) { - return false; - } - - throw e; - } -} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/utils.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/utils.d.ts deleted file mode 100644 index 90252db..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/utils.d.ts +++ /dev/null @@ -1 +0,0 @@ -export declare function assertPresent(obj: O, key: keyof O): void; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/utils.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/utils.js deleted file mode 100644 index 961fd14..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/models/validation/utils.js +++ /dev/null @@ -1,27 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.assertPresent = assertPresent; - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function assertPresent(obj, key) { - if (!obj[key]) { - throw new Error("".concat(key, " is required")); - } -} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/templating/url-template.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/templating/url-template.d.ts deleted file mode 100644 index 33d5ee3..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/templating/url-template.d.ts +++ /dev/null @@ -1,12 +0,0 @@ -import { IWidget } from ".."; -export interface ITemplateParams { - widgetRoomId?: string; - currentUserId: string; - userDisplayName?: string; - userHttpAvatarUrl?: string; - clientId?: string; - clientTheme?: string; - clientLanguage?: string; -} -export declare function runTemplate(url: string, widget: IWidget, params: ITemplateParams): string; -export declare function toString(a: unknown): string; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/templating/url-template.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/templating/url-template.js deleted file mode 100644 index 8eb51da..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/templating/url-template.js +++ /dev/null @@ -1,60 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.runTemplate = runTemplate; -exports.toString = toString; - -/* - * Copyright 2020, 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -function runTemplate(url, widget, params) { - // Always apply the supplied params over top of data to ensure the data can't lie about them. - var variables = Object.assign({}, widget.data, { - 'matrix_room_id': params.widgetRoomId || "", - 'matrix_user_id': params.currentUserId, - 'matrix_display_name': params.userDisplayName || params.currentUserId, - 'matrix_avatar_url': params.userHttpAvatarUrl || "", - 'matrix_widget_id': widget.id, - // TODO: Convert to stable (https://github.com/matrix-org/matrix-doc/pull/2873) - 'org.matrix.msc2873.client_id': params.clientId || "", - 'org.matrix.msc2873.client_theme': params.clientTheme || "", - 'org.matrix.msc2873.client_language': params.clientLanguage || "" - }); - var result = url; - - for (var _i = 0, _Object$keys = Object.keys(variables); _i < _Object$keys.length; _i++) { - var key = _Object$keys[_i]; - // Regex escape from https://stackoverflow.com/a/6969486/7037379 - var pattern = "$".concat(key).replace(/[.*+?^${}()|[\]\\]/g, '\\$&'); // $& means the whole matched string - - var rexp = new RegExp(pattern, 'g'); // This is technically not what we're supposed to do for a couple of reasons: - // 1. We are assuming that there won't later be a $key match after we replace a variable. - // 2. We are assuming that the variable is in a place where it can be escaped (eg: path or query string). - - result = result.replace(rexp, encodeURIComponent(toString(variables[key]))); - } - - return result; -} - -function toString(a) { - if (a === null || a === undefined) { - return "".concat(a); - } - - return String(a); -} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/transport/ITransport.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/transport/ITransport.d.ts deleted file mode 100644 index 62688db..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/transport/ITransport.d.ts +++ /dev/null @@ -1,67 +0,0 @@ -import { EventEmitter } from "events"; -import { IWidgetApiAcknowledgeResponseData, IWidgetApiRequest, IWidgetApiRequestData, IWidgetApiResponse, IWidgetApiResponseData, WidgetApiAction } from ".."; -/** - * A transport for widget requests/responses. All actions - * get raised through a "message" CustomEvent with detail - * of the IWidgetApiRequest. - */ -export interface ITransport extends EventEmitter { - /** - * True if the transport is ready to start sending, false otherwise. - */ - readonly ready: boolean; - /** - * The widget ID, if known. If not known, null. - */ - readonly widgetId: string | null; - /** - * If true, the transport will refuse requests from origins other than the - * widget's current origin. This is intended to be used only by widgets which - * need excess security. - */ - strictOriginCheck: boolean; - /** - * The origin the transport should be replying/sending to. If not known, leave - * null. - */ - targetOrigin: string | null; - /** - * The number of seconds an outbound request is allowed to take before it - * times out. - */ - timeoutSeconds: number; - /** - * Starts the transport for listening - */ - start(): void; - /** - * Stops the transport. It cannot be re-started. - */ - stop(): void; - /** - * Sends a request to the remote end. - * @param {WidgetApiAction} action The action to send. - * @param {IWidgetApiRequestData} data The request data. - * @returns {Promise} A promise which resolves - * to the remote end's response, or throws with an Error if the request - * failed. - */ - send(action: WidgetApiAction, data: T): Promise; - /** - * Sends a request to the remote end. This is similar to the send() function - * however this version returns the full response rather than just the response - * data. - * @param {WidgetApiAction} action The action to send. - * @param {IWidgetApiRequestData} data The request data. - * @returns {Promise} A promise which resolves - * to the remote end's response, or throws with an Error if the request - * failed. - */ - sendComplete(action: WidgetApiAction, data: T): Promise; - /** - * Replies to a request. - * @param {IWidgetApiRequest} request The request to reply to. - * @param {IWidgetApiResponseData} responseData The response data to reply with. - */ - reply(request: IWidgetApiRequest, responseData: T): void; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/transport/ITransport.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/transport/ITransport.js deleted file mode 100644 index 430afc1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/transport/ITransport.js +++ /dev/null @@ -1,5 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/transport/PostmessageTransport.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/transport/PostmessageTransport.d.ts deleted file mode 100644 index 8cfbbd9..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/transport/PostmessageTransport.d.ts +++ /dev/null @@ -1,32 +0,0 @@ -import { EventEmitter } from "events"; -import { ITransport } from "./ITransport"; -import { IWidgetApiRequest, IWidgetApiRequestData, IWidgetApiResponse, IWidgetApiResponseData, WidgetApiAction, WidgetApiDirection } from ".."; -/** - * Transport for the Widget API over postMessage. - */ -export declare class PostmessageTransport extends EventEmitter implements ITransport { - private sendDirection; - private initialWidgetId; - private transportWindow; - private inboundWindow; - strictOriginCheck: boolean; - targetOrigin: string; - timeoutSeconds: number; - private _ready; - private _widgetId; - private outboundRequests; - private stopController; - get ready(): boolean; - get widgetId(): string | null; - constructor(sendDirection: WidgetApiDirection, initialWidgetId: string | null, transportWindow: Window, inboundWindow: Window); - private get nextRequestId(); - private sendInternal; - reply(request: IWidgetApiRequest, responseData: T): void; - send(action: WidgetApiAction, data: T): Promise; - sendComplete(action: WidgetApiAction, data: T): Promise; - start(): void; - stop(): void; - private handleMessage; - private handleRequest; - private handleResponse; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/transport/PostmessageTransport.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/transport/PostmessageTransport.js deleted file mode 100644 index 7f8e3d6..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/transport/PostmessageTransport.js +++ /dev/null @@ -1,255 +0,0 @@ -"use strict"; - -function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.PostmessageTransport = void 0; - -var _events = require("events"); - -var _ = require(".."); - -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } - -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); } - -function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } - -function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } - -function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); } - -function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } - -function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } - -function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } - -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } - -/** - * Transport for the Widget API over postMessage. - */ -var PostmessageTransport = /*#__PURE__*/function (_EventEmitter) { - _inherits(PostmessageTransport, _EventEmitter); - - var _super = _createSuper(PostmessageTransport); - - function PostmessageTransport(sendDirection, initialWidgetId, transportWindow, inboundWindow) { - var _this; - - _classCallCheck(this, PostmessageTransport); - - _this = _super.call(this); - _this.sendDirection = sendDirection; - _this.initialWidgetId = initialWidgetId; - _this.transportWindow = transportWindow; - _this.inboundWindow = inboundWindow; - - _defineProperty(_assertThisInitialized(_this), "strictOriginCheck", false); - - _defineProperty(_assertThisInitialized(_this), "targetOrigin", "*"); - - _defineProperty(_assertThisInitialized(_this), "timeoutSeconds", 10); - - _defineProperty(_assertThisInitialized(_this), "_ready", false); - - _defineProperty(_assertThisInitialized(_this), "_widgetId", null); - - _defineProperty(_assertThisInitialized(_this), "outboundRequests", new Map()); - - _defineProperty(_assertThisInitialized(_this), "stopController", new AbortController()); - - _this._widgetId = initialWidgetId; - return _this; - } - - _createClass(PostmessageTransport, [{ - key: "ready", - get: function get() { - return this._ready; - } - }, { - key: "widgetId", - get: function get() { - return this._widgetId || null; - } - }, { - key: "nextRequestId", - get: function get() { - var idBase = "widgetapi-".concat(Date.now()); - var index = 0; - var id = idBase; - - while (this.outboundRequests.has(id)) { - id = "".concat(idBase, "-").concat(index++); - } // reserve the ID - - - this.outboundRequests.set(id, null); - return id; - } - }, { - key: "sendInternal", - value: function sendInternal(message) { - console.log("[PostmessageTransport] Sending object to ".concat(this.targetOrigin, ": "), message); - this.transportWindow.postMessage(message, this.targetOrigin); - } - }, { - key: "reply", - value: function reply(request, responseData) { - return this.sendInternal(_objectSpread(_objectSpread({}, request), {}, { - response: responseData - })); - } - }, { - key: "send", - value: function send(action, data) { - return this.sendComplete(action, data).then(function (r) { - return r.response; - }); - } - }, { - key: "sendComplete", - value: function sendComplete(action, data) { - var _this2 = this; - - if (!this.ready || !this.widgetId) { - return Promise.reject(new Error("Not ready or unknown widget ID")); - } - - var request = { - api: this.sendDirection, - widgetId: this.widgetId, - requestId: this.nextRequestId, - action: action, - data: data - }; - - if (action === _.WidgetApiToWidgetAction.UpdateVisibility) { - request['visible'] = data['visible']; - } - - return new Promise(function (prResolve, prReject) { - var resolve = function resolve(response) { - cleanUp(); - prResolve(response); - }; - - var reject = function reject(err) { - cleanUp(); - prReject(err); - }; - - var timerId = setTimeout(function () { - return reject(new Error("Request timed out")); - }, (_this2.timeoutSeconds || 1) * 1000); - - var onStop = function onStop() { - return reject(new Error("Transport stopped")); - }; - - _this2.stopController.signal.addEventListener("abort", onStop); - - var cleanUp = function cleanUp() { - _this2.outboundRequests["delete"](request.requestId); - - clearTimeout(timerId); - - _this2.stopController.signal.removeEventListener("abort", onStop); - }; - - _this2.outboundRequests.set(request.requestId, { - request: request, - resolve: resolve, - reject: reject - }); - - _this2.sendInternal(request); - }); - } - }, { - key: "start", - value: function start() { - var _this3 = this; - - this.inboundWindow.addEventListener("message", function (ev) { - _this3.handleMessage(ev); - }); - this._ready = true; - } - }, { - key: "stop", - value: function stop() { - this._ready = false; - this.stopController.abort(); - } - }, { - key: "handleMessage", - value: function handleMessage(ev) { - if (this.stopController.signal.aborted) return; - if (!ev.data) return; // invalid event - - if (this.strictOriginCheck && ev.origin !== window.origin) return; // bad origin - // treat the message as a response first, then downgrade to a request - - var response = ev.data; - if (!response.action || !response.requestId || !response.widgetId) return; // invalid request/response - - if (!response.response) { - // it's a request - var request = response; - if (request.api !== (0, _.invertedDirection)(this.sendDirection)) return; // wrong direction - - this.handleRequest(request); - } else { - // it's a response - if (response.api !== this.sendDirection) return; // wrong direction - - this.handleResponse(response); - } - } - }, { - key: "handleRequest", - value: function handleRequest(request) { - if (this.widgetId) { - if (this.widgetId !== request.widgetId) return; // wrong widget - } else { - this._widgetId = request.widgetId; - } - - this.emit("message", new CustomEvent("message", { - detail: request - })); - } - }, { - key: "handleResponse", - value: function handleResponse(response) { - if (response.widgetId !== this.widgetId) return; // wrong widget - - var req = this.outboundRequests.get(response.requestId); - if (!req) return; // response to an unknown request - - if ((0, _.isErrorResponse)(response.response)) { - var _err = response.response; - req.reject(new Error(_err.error.message)); - } else { - req.resolve(response); - } - } - }]); - - return PostmessageTransport; -}(_events.EventEmitter); - -exports.PostmessageTransport = PostmessageTransport; \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/util/SimpleObservable.d.ts b/includes/external/matrix/node_modules/matrix-widget-api/lib/util/SimpleObservable.d.ts deleted file mode 100644 index 886eca2..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/util/SimpleObservable.d.ts +++ /dev/null @@ -1,8 +0,0 @@ -export declare type ObservableFunction = (val: T) => void; -export declare class SimpleObservable { - private listeners; - constructor(initialFn?: ObservableFunction); - onUpdate(fn: ObservableFunction): void; - update(val: T): void; - close(): void; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/lib/util/SimpleObservable.js b/includes/external/matrix/node_modules/matrix-widget-api/lib/util/SimpleObservable.js deleted file mode 100644 index d8ef3c3..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/lib/util/SimpleObservable.js +++ /dev/null @@ -1,78 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SimpleObservable = void 0; - -function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; } - -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } - -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } - -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } - -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -var SimpleObservable = /*#__PURE__*/function () { - function SimpleObservable(initialFn) { - _classCallCheck(this, SimpleObservable); - - _defineProperty(this, "listeners", []); - - if (initialFn) this.listeners.push(initialFn); - } - - _createClass(SimpleObservable, [{ - key: "onUpdate", - value: function onUpdate(fn) { - this.listeners.push(fn); - } - }, { - key: "update", - value: function update(val) { - var _iterator = _createForOfIteratorHelper(this.listeners), - _step; - - try { - for (_iterator.s(); !(_step = _iterator.n()).done;) { - var listener = _step.value; - listener(val); - } - } catch (err) { - _iterator.e(err); - } finally { - _iterator.f(); - } - } - }, { - key: "close", - value: function close() { - this.listeners = []; // reset - } - }]); - - return SimpleObservable; -}(); - -exports.SimpleObservable = SimpleObservable; \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-widget-api/package.json b/includes/external/matrix/node_modules/matrix-widget-api/package.json deleted file mode 100644 index 8de81ab..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/package.json +++ /dev/null @@ -1,63 +0,0 @@ -{ - "name": "matrix-widget-api", - "version": "1.3.1", - "description": "Matrix Widget API SDK", - "main": "./lib/index.js", - "types": "./lib/index.d.ts", - "repository": "https://github.com/matrix-org/matrix-widget-api", - "author": "The Matrix.org Foundation C.I.C.", - "license": "Apache-2.0", - "scripts": { - "prepublishOnly": "yarn build", - "start": "tsc -w", - "clean": "rimraf lib dist", - "build": "yarn clean && yarn build:compile && yarn build:types && yarn build:browser", - "build:compile": "babel -d lib --verbose --extensions \".ts\" src", - "build:types": "tsc --emitDeclarationOnly", - "build:browser": "yarn build:browser:dev && yarn build:browser:prod", - "build:browser:dev": "browserify lib/index.js --debug --s mxwidgets -o dist/api.js", - "build:browser:prod": "browserify lib/index.js --s mxwidgets -p tinyify -o dist/api.min.js", - "lint": "yarn lint:types && yarn lint:ts", - "lint:ts": "eslint src test", - "lint:types": "tsc --noEmit", - "lint:fix": "eslint src test --fix", - "test": "jest" - }, - "files": [ - "src", - "lib", - "dist", - "package.json", - "README.md", - "LICENSE", - "CONTRIBUTING.rst" - ], - "devDependencies": { - "@babel/cli": "^7.11.6", - "@babel/core": "^7.11.6", - "@babel/plugin-proposal-class-properties": "^7.10.4", - "@babel/preset-env": "^7.11.5", - "@babel/preset-typescript": "^7.10.4", - "@testing-library/dom": "^8.0.0", - "@types/jest": "^27.4.0", - "babel-eslint": "^10.1.0", - "browserify": "^17.0.0", - "eslint": "^7.8.1", - "eslint-config-matrix-org": "^0.1.2", - "eslint-plugin-babel": "^5.3.1", - "jest": "^27.4.0", - "jest-environment-jsdom": "^27.0.6", - "rimraf": "^3.0.2", - "tinyify": "^3.0.0" - }, - "dependencies": { - "@types/events": "^3.0.0", - "events": "^3.2.0" - }, - "jest": { - "testEnvironment": "jsdom", - "testMatch": [ - "/test/**/*-test.[jt]s?(x)" - ] - } -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/ClientWidgetApi.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/ClientWidgetApi.ts deleted file mode 100644 index fecbefc..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/ClientWidgetApi.ts +++ /dev/null @@ -1,798 +0,0 @@ -/* - * Copyright 2020 - 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { EventEmitter } from "events"; -import { ITransport } from "./transport/ITransport"; -import { Widget } from "./models/Widget"; -import { PostmessageTransport } from "./transport/PostmessageTransport"; -import { WidgetApiDirection } from "./interfaces/WidgetApiDirection"; -import { IWidgetApiRequest, IWidgetApiRequestEmptyData } from "./interfaces/IWidgetApiRequest"; -import { IContentLoadedActionRequest } from "./interfaces/ContentLoadedAction"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./interfaces/WidgetApiAction"; -import { IWidgetApiErrorResponseData } from "./interfaces/IWidgetApiErrorResponse"; -import { Capability, MatrixCapabilities } from "./interfaces/Capabilities"; -import { IOpenIDUpdate, ISendEventDetails, WidgetDriver } from "./driver/WidgetDriver"; -import { - ICapabilitiesActionResponseData, - INotifyCapabilitiesActionRequestData, - IRenegotiateCapabilitiesActionRequest, -} from "./interfaces/CapabilitiesAction"; -import { - ISupportedVersionsActionRequest, - ISupportedVersionsActionResponseData, -} from "./interfaces/SupportedVersionsAction"; -import { CurrentApiVersions } from "./interfaces/ApiVersion"; -import { IScreenshotActionResponseData } from "./interfaces/ScreenshotAction"; -import { IVisibilityActionRequestData } from "./interfaces/VisibilityAction"; -import { IWidgetApiAcknowledgeResponseData, IWidgetApiResponseData } from "./interfaces/IWidgetApiResponse"; -import { - IModalWidgetButtonClickedRequestData, - IModalWidgetOpenRequestData, - IModalWidgetOpenRequestDataButton, - IModalWidgetReturnData, -} from "./interfaces/ModalWidgetActions"; -import { - ISendEventFromWidgetActionRequest, - ISendEventFromWidgetResponseData, - ISendEventToWidgetRequestData, -} from "./interfaces/SendEventAction"; -import { - ISendToDeviceFromWidgetActionRequest, - ISendToDeviceFromWidgetResponseData, - ISendToDeviceToWidgetRequestData, -} from "./interfaces/SendToDeviceAction"; -import { EventDirection, WidgetEventCapability } from "./models/WidgetEventCapability"; -import { IRoomEvent } from "./interfaces/IRoomEvent"; -import { - IGetOpenIDActionRequest, - IGetOpenIDActionResponseData, - IOpenIDCredentials, - OpenIDRequestState, -} from "./interfaces/GetOpenIDAction"; -import { SimpleObservable } from "./util/SimpleObservable"; -import { IOpenIDCredentialsActionRequestData } from "./interfaces/OpenIDCredentialsAction"; -import { INavigateActionRequest } from "./interfaces/NavigateAction"; -import { IReadEventFromWidgetActionRequest, IReadEventFromWidgetResponseData } from "./interfaces/ReadEventAction"; -import { - ITurnServer, - IWatchTurnServersRequest, - IUnwatchTurnServersRequest, - IUpdateTurnServersRequestData, -} from "./interfaces/TurnServerActions"; -import { Symbols } from "./Symbols"; -import { - IReadRelationsFromWidgetActionRequest, - IReadRelationsFromWidgetResponseData, -} from "./interfaces/ReadRelationsAction"; -import { - IUserDirectorySearchFromWidgetActionRequest, - IUserDirectorySearchFromWidgetResponseData, -} from "./interfaces/UserDirectorySearchAction"; - -/** - * API handler for the client side of widgets. This raises events - * for each action received as `action:${action}` (eg: "action:screenshot"). - * Default handling can be prevented by using preventDefault() on the - * raised event. The default handling varies for each action: ones - * which the SDK can handle safely are acknowledged appropriately and - * ones which are unhandled (custom or require the client to do something) - * are rejected with an error. - * - * Events which are preventDefault()ed must reply using the transport. - * The events raised will have a default of an IWidgetApiRequest - * interface. - * - * When the ClientWidgetApi is ready to start sending requests, it will - * raise a "ready" CustomEvent. After the ready event fires, actions can - * be sent and the transport will be ready. - * - * When the widget has indicated it has loaded, this class raises a - * "preparing" CustomEvent. The preparing event does not indicate that - * the widget is ready to receive communications - that is signified by - * the ready event exclusively. - * - * This class only handles one widget at a time. - */ -export class ClientWidgetApi extends EventEmitter { - public readonly transport: ITransport; - - // contentLoadedActionSent is used to check that only one ContentLoaded request is send. - private contentLoadedActionSent = false; - private allowedCapabilities = new Set(); - private allowedEvents: WidgetEventCapability[] = []; - private isStopped = false; - private turnServers: AsyncGenerator | null = null; - - /** - * Creates a new client widget API. This will instantiate the transport - * and start everything. When the iframe is loaded under the widget's - * conditions, a "ready" event will be raised. - * @param {Widget} widget The widget to communicate with. - * @param {HTMLIFrameElement} iframe The iframe the widget is in. - * @param {WidgetDriver} driver The driver for this widget/client. - */ - public constructor( - public readonly widget: Widget, - private iframe: HTMLIFrameElement, - private driver: WidgetDriver, - ) { - super(); - if (!iframe?.contentWindow) { - throw new Error("No iframe supplied"); - } - if (!widget) { - throw new Error("Invalid widget"); - } - if (!driver) { - throw new Error("Invalid driver"); - } - this.transport = new PostmessageTransport( - WidgetApiDirection.ToWidget, - widget.id, - iframe.contentWindow, - window, - ); - this.transport.targetOrigin = widget.origin; - this.transport.on("message", this.handleMessage.bind(this)); - - iframe.addEventListener("load", this.onIframeLoad.bind(this)); - - this.transport.start(); - } - - public hasCapability(capability: Capability): boolean { - return this.allowedCapabilities.has(capability); - } - - public canUseRoomTimeline(roomId: string | Symbols.AnyRoom): boolean { - return this.hasCapability(`org.matrix.msc2762.timeline:${Symbols.AnyRoom}`) - || this.hasCapability(`org.matrix.msc2762.timeline:${roomId}`); - } - - public canSendRoomEvent(eventType: string, msgtype: string | null = null): boolean { - return this.allowedEvents.some(e => e.matchesAsRoomEvent(EventDirection.Send, eventType, msgtype)); - } - - public canSendStateEvent(eventType: string, stateKey: string): boolean { - return this.allowedEvents.some(e => e.matchesAsStateEvent(EventDirection.Send, eventType, stateKey)); - } - - public canSendToDeviceEvent(eventType: string): boolean { - return this.allowedEvents.some(e => e.matchesAsToDeviceEvent(EventDirection.Send, eventType)); - } - - public canReceiveRoomEvent(eventType: string, msgtype: string | null = null): boolean { - return this.allowedEvents.some(e => e.matchesAsRoomEvent(EventDirection.Receive, eventType, msgtype)); - } - - public canReceiveStateEvent(eventType: string, stateKey: string | null): boolean { - return this.allowedEvents.some(e => e.matchesAsStateEvent(EventDirection.Receive, eventType, stateKey)); - } - - public canReceiveToDeviceEvent(eventType: string): boolean { - return this.allowedEvents.some(e => e.matchesAsToDeviceEvent(EventDirection.Receive, eventType)); - } - - public stop() { - this.isStopped = true; - this.transport.stop(); - } - - private beginCapabilities() { - // widget has loaded - tell all the listeners that - this.emit("preparing"); - - let requestedCaps: Capability[]; - this.transport.send( - WidgetApiToWidgetAction.Capabilities, {}, - ).then(caps => { - requestedCaps = caps.capabilities; - return this.driver.validateCapabilities(new Set(caps.capabilities)); - }).then(allowedCaps => { - console.log(`Widget ${this.widget.id} is allowed capabilities:`, Array.from(allowedCaps)); - this.allowedCapabilities = allowedCaps; - this.allowedEvents = WidgetEventCapability.findEventCapabilities(allowedCaps); - this.notifyCapabilities(requestedCaps); - this.emit("ready"); - }); - } - - private notifyCapabilities(requested: Capability[]) { - this.transport.send(WidgetApiToWidgetAction.NotifyCapabilities, { - requested: requested, - approved: Array.from(this.allowedCapabilities), - }).catch(e => { - console.warn("non-fatal error notifying widget of approved capabilities:", e); - }).then(() => { - this.emit("capabilitiesNotified") - }); - } - - private onIframeLoad(ev: Event) { - if (this.widget.waitForIframeLoad) { - // If the widget is set to waitForIframeLoad the capabilities immediatly get setup after load. - // The client does not wait for the ContentLoaded action. - this.beginCapabilities(); - } else { - // Reaching this means, that the Iframe got reloaded/loaded and - // the clientApi is awaiting the FIRST ContentLoaded action. - this.contentLoadedActionSent = false; - } - } - - private handleContentLoadedAction(action: IContentLoadedActionRequest) { - if (this.contentLoadedActionSent) { - throw new Error("Improper sequence: ContentLoaded Action can only be send once after the widget loaded " - +"and should only be used if waitForIframeLoad is false (default=true)"); - } - if (this.widget.waitForIframeLoad) { - this.transport.reply(action, { - error: { - message: "Improper sequence: not expecting ContentLoaded event if " - +"waitForIframLoad is true (default=true)", - }, - }); - } else { - this.transport.reply(action, {}); - this.beginCapabilities(); - } - this.contentLoadedActionSent = true; - } - - private replyVersions(request: ISupportedVersionsActionRequest) { - this.transport.reply(request, { - supported_versions: CurrentApiVersions, - }); - } - - private handleCapabilitiesRenegotiate(request: IRenegotiateCapabilitiesActionRequest) { - // acknowledge first - this.transport.reply(request, {}); - - const requested = request.data?.capabilities || []; - const newlyRequested = new Set(requested.filter(r => !this.hasCapability(r))); - if (newlyRequested.size === 0) { - // Nothing to do - notify capabilities - return this.notifyCapabilities([]); - } - - this.driver.validateCapabilities(newlyRequested).then(allowed => { - allowed.forEach(c => this.allowedCapabilities.add(c)); - - const allowedEvents = WidgetEventCapability.findEventCapabilities(allowed); - allowedEvents.forEach(c => this.allowedEvents.push(c)); - - return this.notifyCapabilities(Array.from(newlyRequested)); - }); - } - - private handleNavigate(request: INavigateActionRequest) { - if (!this.hasCapability(MatrixCapabilities.MSC2931Navigate)) { - return this.transport.reply(request, { - error: {message: "Missing capability"}, - }); - } - - if (!request.data?.uri || !request.data?.uri.toString().startsWith("https://matrix.to/#")) { - return this.transport.reply(request, { - error: {message: "Invalid matrix.to URI"}, - }); - } - - const onErr = (e: any) => { - console.error("[ClientWidgetApi] Failed to handle navigation: ", e); - return this.transport.reply(request, { - error: {message: "Error handling navigation"}, - }); - }; - - try { - this.driver.navigate(request.data.uri.toString()).catch(e => onErr(e)).then(() => { - return this.transport.reply(request, {}); - }); - } catch (e) { - return onErr(e); - } - } - - private handleOIDC(request: IGetOpenIDActionRequest) { - let phase = 1; // 1 = initial request, 2 = after user manual confirmation - - const replyState = (state: OpenIDRequestState, credential?: IOpenIDCredentials) => { - credential = credential || {}; - if (phase > 1) { - return this.transport.send( - WidgetApiToWidgetAction.OpenIDCredentials, - { - state: state, - original_request_id: request.requestId, - ...credential, - }, - ); - } else { - return this.transport.reply(request, { - state: state, - ...credential, - }); - } - }; - - const replyError = (msg: string) => { - console.error("[ClientWidgetApi] Failed to handle OIDC: ", msg); - if (phase > 1) { - // We don't have a way to indicate that a random error happened in this flow, so - // just block the attempt. - return replyState(OpenIDRequestState.Blocked); - } else { - return this.transport.reply(request, { - error: {message: msg}, - }); - } - }; - - const observer = new SimpleObservable(update => { - if (update.state === OpenIDRequestState.PendingUserConfirmation && phase > 1) { - observer.close(); - return replyError("client provided out-of-phase response to OIDC flow"); - } - - if (update.state === OpenIDRequestState.PendingUserConfirmation) { - replyState(update.state); - phase++; - return; - } - - if (update.state === OpenIDRequestState.Allowed && !update.token) { - return replyError("client provided invalid OIDC token for an allowed request"); - } - if (update.state === OpenIDRequestState.Blocked) { - update.token = undefined; // just in case the client did something weird - } - - observer.close(); - return replyState(update.state, update.token); - }); - - this.driver.askOpenID(observer); - } - - private handleReadEvents(request: IReadEventFromWidgetActionRequest) { - if (!request.data.type) { - return this.transport.reply(request, { - error: {message: "Invalid request - missing event type"}, - }); - } - if (request.data.limit !== undefined && (!request.data.limit || request.data.limit < 0)) { - return this.transport.reply(request, { - error: {message: "Invalid request - limit out of range"}, - }); - } - - let askRoomIds: string[] | null = null; // null denotes current room only - if (request.data.room_ids) { - askRoomIds = request.data.room_ids as string[]; - if (!Array.isArray(askRoomIds)) { - askRoomIds = [askRoomIds as any as string]; - } - for (const roomId of askRoomIds) { - if (!this.canUseRoomTimeline(roomId)) { - return this.transport.reply(request, { - error: {message: `Unable to access room timeline: ${roomId}`}, - }); - } - } - } - - const limit = request.data.limit || 0; - - let events: Promise = Promise.resolve([]); - if (request.data.state_key !== undefined) { - const stateKey = request.data.state_key === true ? undefined : request.data.state_key.toString(); - if (!this.canReceiveStateEvent(request.data.type, stateKey ?? null)) { - return this.transport.reply(request, { - error: {message: "Cannot read state events of this type"}, - }); - } - events = this.driver.readStateEvents(request.data.type, stateKey, limit, askRoomIds); - } else { - if (!this.canReceiveRoomEvent(request.data.type, request.data.msgtype)) { - return this.transport.reply(request, { - error: {message: "Cannot read room events of this type"}, - }); - } - events = this.driver.readRoomEvents(request.data.type, request.data.msgtype, limit, askRoomIds); - } - - return events.then(evs => this.transport.reply(request, {events: evs})); - } - - private handleSendEvent(request: ISendEventFromWidgetActionRequest) { - if (!request.data.type) { - return this.transport.reply(request, { - error: {message: "Invalid request - missing event type"}, - }); - } - - if (!!request.data.room_id && !this.canUseRoomTimeline(request.data.room_id)) { - return this.transport.reply(request, { - error: {message: `Unable to access room timeline: ${request.data.room_id}`}, - }); - } - - const isState = request.data.state_key !== null && request.data.state_key !== undefined; - let sendEventPromise: Promise; - if (isState) { - if (!this.canSendStateEvent(request.data.type, request.data.state_key!)) { - return this.transport.reply(request, { - error: {message: "Cannot send state events of this type"}, - }); - } - - sendEventPromise = this.driver.sendEvent( - request.data.type, - request.data.content || {}, - request.data.state_key, - request.data.room_id, - ); - } else { - const content = request.data.content as { msgtype?: string } || {}; - const msgtype = content['msgtype']; - if (!this.canSendRoomEvent(request.data.type, msgtype)) { - return this.transport.reply(request, { - error: {message: "Cannot send room events of this type"}, - }); - } - - sendEventPromise = this.driver.sendEvent( - request.data.type, - content, - null, // not sending a state event - request.data.room_id, - ); - } - - sendEventPromise.then(sentEvent => { - return this.transport.reply(request, { - room_id: sentEvent.roomId, - event_id: sentEvent.eventId, - }); - }).catch(e => { - console.error("error sending event: ", e); - return this.transport.reply(request, { - error: {message: "Error sending event"}, - }); - }); - } - - private async handleSendToDevice(request: ISendToDeviceFromWidgetActionRequest): Promise { - if (!request.data.type) { - await this.transport.reply(request, { - error: {message: "Invalid request - missing event type"}, - }); - } else if (!request.data.messages) { - await this.transport.reply(request, { - error: {message: "Invalid request - missing event contents"}, - }); - } else if (typeof request.data.encrypted !== "boolean") { - await this.transport.reply(request, { - error: {message: "Invalid request - missing encryption flag"}, - }); - } else if (!this.canSendToDeviceEvent(request.data.type)) { - await this.transport.reply(request, { - error: {message: "Cannot send to-device events of this type"}, - }); - } else { - try { - await this.driver.sendToDevice(request.data.type, request.data.encrypted, request.data.messages); - await this.transport.reply(request, {}); - } catch (e) { - console.error("error sending to-device event", e); - await this.transport.reply(request, { - error: {message: "Error sending event"}, - }); - } - } - } - - private async pollTurnServers(turnServers: AsyncGenerator, initialServer: ITurnServer) { - try { - await this.transport.send( - WidgetApiToWidgetAction.UpdateTurnServers, - initialServer as IUpdateTurnServersRequestData, // it's compatible, but missing the index signature - ); - - // Pick the generator up where we left off - for await (const server of turnServers) { - await this.transport.send( - WidgetApiToWidgetAction.UpdateTurnServers, - server as IUpdateTurnServersRequestData, // it's compatible, but missing the index signature - ); - } - } catch (e) { - console.error("error polling for TURN servers", e); - } - } - - private async handleWatchTurnServers(request: IWatchTurnServersRequest): Promise { - if (!this.hasCapability(MatrixCapabilities.MSC3846TurnServers)) { - await this.transport.reply(request, { - error: {message: "Missing capability"}, - }); - } else if (this.turnServers) { - // We're already polling, so this is a no-op - await this.transport.reply(request, {}); - } else { - try { - const turnServers = this.driver.getTurnServers(); - - // Peek at the first result, so we can at least verify that the - // client isn't banned from getting TURN servers entirely - const { done, value } = await turnServers.next(); - if (done) throw new Error("Client refuses to provide any TURN servers"); - await this.transport.reply(request, {}); - - // Start the poll loop, sending the widget the initial result - this.pollTurnServers(turnServers, value); - this.turnServers = turnServers; - } catch (e) { - console.error("error getting first TURN server results", e); - await this.transport.reply(request, { - error: {message: "TURN servers not available"}, - }); - } - } - } - - private async handleUnwatchTurnServers(request: IUnwatchTurnServersRequest): Promise { - if (!this.hasCapability(MatrixCapabilities.MSC3846TurnServers)) { - await this.transport.reply(request, { - error: {message: "Missing capability"}, - }); - } else if (!this.turnServers) { - // We weren't polling anyways, so this is a no-op - await this.transport.reply(request, {}); - } else { - // Stop the generator, allowing it to clean up - await this.turnServers.return(undefined); - this.turnServers = null; - await this.transport.reply(request, {}); - } - } - - private async handleReadRelations(request: IReadRelationsFromWidgetActionRequest) { - if (!request.data.event_id) { - return this.transport.reply(request, { - error: { message: "Invalid request - missing event ID" }, - }); - } - - if (request.data.limit !== undefined && request.data.limit < 0) { - return this.transport.reply(request, { - error: { message: "Invalid request - limit out of range" }, - }); - } - - if (request.data.room_id !== undefined && !this.canUseRoomTimeline(request.data.room_id)) { - return this.transport.reply(request, { - error: { message: `Unable to access room timeline: ${request.data.room_id}` }, - }); - } - - try { - const result = await this.driver.readEventRelations( - request.data.event_id, request.data.room_id, request.data.rel_type, - request.data.event_type, request.data.from, request.data.to, - request.data.limit, request.data.direction, - ); - - // only return events that the user has the permission to receive - const chunk = result.chunk.filter(e => { - if (e.state_key !== undefined) { - return this.canReceiveStateEvent(e.type, e.state_key); - } else { - return this.canReceiveRoomEvent(e.type, (e.content as { msgtype?: string })['msgtype']); - } - }); - - return this.transport.reply( - request, - { - chunk, - prev_batch: result.prevBatch, - next_batch: result.nextBatch, - }, - ); - } catch (e) { - console.error("error getting the relations", e); - await this.transport.reply(request, { - error: { message: "Unexpected error while reading relations" }, - }); - } - } - - private async handleUserDirectorySearch(request: IUserDirectorySearchFromWidgetActionRequest) { - if (!this.hasCapability(MatrixCapabilities.MSC3973UserDirectorySearch)) { - return this.transport.reply(request, { - error: { message: "Missing capability" }, - }); - } - - if (typeof request.data.search_term !== 'string') { - return this.transport.reply(request, { - error: { message: "Invalid request - missing search term" }, - }); - } - - if (request.data.limit !== undefined && request.data.limit < 0) { - return this.transport.reply(request, { - error: { message: "Invalid request - limit out of range" }, - }); - } - - try { - const result = await this.driver.searchUserDirectory( - request.data.search_term, request.data.limit, - ); - - return this.transport.reply( - request, - { - limited: result.limited, - results: result.results.map(r => ({ - user_id: r.userId, - display_name: r.displayName, - avatar_url: r.avatarUrl, - })), - }, - ); - } catch (e) { - console.error("error searching in the user directory", e); - await this.transport.reply(request, { - error: { message: "Unexpected error while searching in the user directory" }, - }); - } - } - - private handleMessage(ev: CustomEvent) { - if (this.isStopped) return; - const actionEv = new CustomEvent(`action:${ev.detail.action}`, { - detail: ev.detail, - cancelable: true, - }); - this.emit(`action:${ev.detail.action}`, actionEv); - if (!actionEv.defaultPrevented) { - switch (ev.detail.action) { - case WidgetApiFromWidgetAction.ContentLoaded: - return this.handleContentLoadedAction(ev.detail); - case WidgetApiFromWidgetAction.SupportedApiVersions: - return this.replyVersions(ev.detail); - case WidgetApiFromWidgetAction.SendEvent: - return this.handleSendEvent(ev.detail); - case WidgetApiFromWidgetAction.SendToDevice: - return this.handleSendToDevice(ev.detail); - case WidgetApiFromWidgetAction.GetOpenIDCredentials: - return this.handleOIDC(ev.detail); - case WidgetApiFromWidgetAction.MSC2931Navigate: - return this.handleNavigate(ev.detail); - case WidgetApiFromWidgetAction.MSC2974RenegotiateCapabilities: - return this.handleCapabilitiesRenegotiate(ev.detail); - case WidgetApiFromWidgetAction.MSC2876ReadEvents: - return this.handleReadEvents(ev.detail); - case WidgetApiFromWidgetAction.WatchTurnServers: - return this.handleWatchTurnServers(ev.detail); - case WidgetApiFromWidgetAction.UnwatchTurnServers: - return this.handleUnwatchTurnServers(ev.detail); - case WidgetApiFromWidgetAction.MSC3869ReadRelations: - return this.handleReadRelations(ev.detail); - case WidgetApiFromWidgetAction.MSC3973UserDirectorySearch: - return this.handleUserDirectorySearch(ev.detail) - default: - return this.transport.reply(ev.detail, { - error: { - message: "Unknown or unsupported action: " + ev.detail.action, - }, - }); - } - } - } - - /** - * Takes a screenshot of the widget. - * @returns Resolves to the widget's screenshot. - * @throws Throws if there is a problem. - */ - public takeScreenshot(): Promise { - return this.transport.send(WidgetApiToWidgetAction.TakeScreenshot, {}); - } - - /** - * Alerts the widget to whether or not it is currently visible. - * @param {boolean} isVisible Whether the widget is visible or not. - * @returns {Promise} Resolves when the widget acknowledges the update. - */ - public updateVisibility(isVisible: boolean): Promise { - return this.transport.send(WidgetApiToWidgetAction.UpdateVisibility, { - visible: isVisible, - }); - } - - public sendWidgetConfig(data: IModalWidgetOpenRequestData): Promise { - return this.transport.send(WidgetApiToWidgetAction.WidgetConfig, data).then(); - } - - public notifyModalWidgetButtonClicked(id: IModalWidgetOpenRequestDataButton["id"]): Promise { - return this.transport.send( - WidgetApiToWidgetAction.ButtonClicked, {id}, - ).then(); - } - - public notifyModalWidgetClose(data: IModalWidgetReturnData): Promise { - return this.transport.send( - WidgetApiToWidgetAction.CloseModalWidget, data, - ).then(); - } - - /** - * Feeds an event to the widget. If the widget is not able to accept the event due to - * permissions, this will no-op and return calmly. If the widget failed to handle the - * event, this will raise an error. - * @param {IRoomEvent} rawEvent The event to (try to) send to the widget. - * @param {string} currentViewedRoomId The room ID the user is currently interacting with. - * Not the room ID of the event. - * @returns {Promise} Resolves when complete, rejects if there was an error sending. - */ - public async feedEvent(rawEvent: IRoomEvent, currentViewedRoomId: string): Promise { - if (rawEvent.room_id !== currentViewedRoomId && !this.canUseRoomTimeline(rawEvent.room_id)) { - return; // no-op - } - - if (rawEvent.state_key !== undefined && rawEvent.state_key !== null) { - // state event - if (!this.canReceiveStateEvent(rawEvent.type, rawEvent.state_key)) { - return; // no-op - } - } else { - // message event - if (!this.canReceiveRoomEvent(rawEvent.type, (rawEvent.content as { msgtype?: string })?.["msgtype"])) { - return; // no-op - } - } - - // Feed the event into the widget - await this.transport.send( - WidgetApiToWidgetAction.SendEvent, - rawEvent as ISendEventToWidgetRequestData, // it's compatible, but missing the index signature - ); - } - - /** - * Feeds a to-device event to the widget. If the widget is not able to accept the - * event due to permissions, this will no-op and return calmly. If the widget failed - * to handle the event, this will raise an error. - * @param {IRoomEvent} rawEvent The event to (try to) send to the widget. - * @param {boolean} encrypted Whether the event contents were encrypted. - * @returns {Promise} Resolves when complete, rejects if there was an error sending. - */ - public async feedToDevice(rawEvent: IRoomEvent, encrypted: boolean): Promise { - if (this.canReceiveToDeviceEvent(rawEvent.type)) { - await this.transport.send( - WidgetApiToWidgetAction.SendToDevice, - // it's compatible, but missing the index signature - { ...rawEvent, encrypted } as ISendToDeviceToWidgetRequestData, - ); - } - } -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/Symbols.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/Symbols.ts deleted file mode 100644 index 85ca12e..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/Symbols.ts +++ /dev/null @@ -1,19 +0,0 @@ -/* - * Copyright 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -export enum Symbols { - AnyRoom = "*", -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/WidgetApi.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/WidgetApi.ts deleted file mode 100644 index a74187a..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/WidgetApi.ts +++ /dev/null @@ -1,717 +0,0 @@ -/* - * Copyright 2020 - 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { EventEmitter } from "events"; -import { Capability } from "./interfaces/Capabilities"; -import { IWidgetApiRequest, IWidgetApiRequestEmptyData } from "./interfaces/IWidgetApiRequest"; -import { IWidgetApiAcknowledgeResponseData } from "./interfaces/IWidgetApiResponse"; -import { WidgetApiDirection } from "./interfaces/WidgetApiDirection"; -import { - ISupportedVersionsActionRequest, - ISupportedVersionsActionResponseData, -} from "./interfaces/SupportedVersionsAction"; -import { ApiVersion, CurrentApiVersions, UnstableApiVersion } from "./interfaces/ApiVersion"; -import { - ICapabilitiesActionRequest, - ICapabilitiesActionResponseData, - INotifyCapabilitiesActionRequest, - IRenegotiateCapabilitiesRequestData, -} from "./interfaces/CapabilitiesAction"; -import { ITransport } from "./transport/ITransport"; -import { PostmessageTransport } from "./transport/PostmessageTransport"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./interfaces/WidgetApiAction"; -import { IWidgetApiErrorResponseData } from "./interfaces/IWidgetApiErrorResponse"; -import { IStickerActionRequestData } from "./interfaces/StickerAction"; -import { IStickyActionRequestData, IStickyActionResponseData } from "./interfaces/StickyAction"; -import { - IGetOpenIDActionRequestData, - IGetOpenIDActionResponse, - IOpenIDCredentials, - OpenIDRequestState, -} from "./interfaces/GetOpenIDAction"; -import { IOpenIDCredentialsActionRequest } from "./interfaces/OpenIDCredentialsAction"; -import { MatrixWidgetType, WidgetType } from "./interfaces/WidgetType"; -import { - BuiltInModalButtonID, - IModalWidgetCreateData, - IModalWidgetOpenRequestData, - IModalWidgetOpenRequestDataButton, - IModalWidgetReturnData, - ModalButtonID, -} from "./interfaces/ModalWidgetActions"; -import { ISetModalButtonEnabledActionRequestData } from "./interfaces/SetModalButtonEnabledAction"; -import { ISendEventFromWidgetRequestData, ISendEventFromWidgetResponseData } from "./interfaces/SendEventAction"; -import { - ISendToDeviceFromWidgetRequestData, - ISendToDeviceFromWidgetResponseData, -} from "./interfaces/SendToDeviceAction"; -import { EventDirection, WidgetEventCapability } from "./models/WidgetEventCapability"; -import { INavigateActionRequestData } from "./interfaces/NavigateAction"; -import { IReadEventFromWidgetRequestData, IReadEventFromWidgetResponseData } from "./interfaces/ReadEventAction"; -import { IRoomEvent } from "./interfaces/IRoomEvent"; -import { ITurnServer, IUpdateTurnServersRequest } from "./interfaces/TurnServerActions"; -import { Symbols } from "./Symbols"; -import { - IReadRelationsFromWidgetRequestData, - IReadRelationsFromWidgetResponseData, -} from "./interfaces/ReadRelationsAction"; -import { - IUserDirectorySearchFromWidgetRequestData, - IUserDirectorySearchFromWidgetResponseData, -} from "./interfaces/UserDirectorySearchAction"; - -/** - * API handler for widgets. This raises events for each action - * received as `action:${action}` (eg: "action:screenshot"). - * Default handling can be prevented by using preventDefault() - * on the raised event. The default handling varies for each - * action: ones which the SDK can handle safely are acknowledged - * appropriately and ones which are unhandled (custom or require - * the widget to do something) are rejected with an error. - * - * Events which are preventDefault()ed must reply using the - * transport. The events raised will have a detail of an - * IWidgetApiRequest interface. - * - * When the WidgetApi is ready to start sending requests, it will - * raise a "ready" CustomEvent. After the ready event fires, actions - * can be sent and the transport will be ready. - */ -export class WidgetApi extends EventEmitter { - public readonly transport: ITransport; - - private capabilitiesFinished = false; - private supportsMSC2974Renegotiate = false; - private requestedCapabilities: Capability[] = []; - private approvedCapabilities?: Capability[]; - private cachedClientVersions?: ApiVersion[]; - private turnServerWatchers = 0; - - /** - * Creates a new API handler for the given widget. - * @param {string} widgetId The widget ID to listen for. If not supplied then - * the API will use the widget ID from the first valid request it receives. - * @param {string} clientOrigin The origin of the client, or null if not known. - */ - public constructor(widgetId: string | null = null, private clientOrigin: string | null = null) { - super(); - if (!window.parent) { - throw new Error("No parent window. This widget doesn't appear to be embedded properly."); - } - this.transport = new PostmessageTransport( - WidgetApiDirection.FromWidget, - widgetId, - window.parent, - window, - ); - this.transport.targetOrigin = clientOrigin; - this.transport.on("message", this.handleMessage.bind(this)); - } - - /** - * Determines if the widget was granted a particular capability. Note that on - * clients where the capabilities are not fed back to the widget this function - * will rely on requested capabilities instead. - * @param {Capability} capability The capability to check for approval of. - * @returns {boolean} True if the widget has approval for the given capability. - */ - public hasCapability(capability: Capability): boolean { - if (Array.isArray(this.approvedCapabilities)) { - return this.approvedCapabilities.includes(capability); - } - return this.requestedCapabilities.includes(capability); - } - - /** - * Request a capability from the client. It is not guaranteed to be allowed, - * but will be asked for. - * @param {Capability} capability The capability to request. - * @throws Throws if the capabilities negotiation has already started and the - * widget is unable to request additional capabilities. - */ - public requestCapability(capability: Capability) { - if (this.capabilitiesFinished && !this.supportsMSC2974Renegotiate) { - throw new Error("Capabilities have already been negotiated"); - } - - this.requestedCapabilities.push(capability); - } - - /** - * Request capabilities from the client. They are not guaranteed to be allowed, - * but will be asked for if the negotiation has not already happened. - * @param {Capability[]} capabilities The capabilities to request. - * @throws Throws if the capabilities negotiation has already started. - */ - public requestCapabilities(capabilities: Capability[]) { - capabilities.forEach(cap => this.requestCapability(cap)); - } - - /** - * Requests the capability to interact with rooms other than the user's currently - * viewed room. Applies to event receiving and sending. - * @param {string | Symbols.AnyRoom} roomId The room ID, or `Symbols.AnyRoom` to - * denote all known rooms. - */ - public requestCapabilityForRoomTimeline(roomId: string | Symbols.AnyRoom) { - this.requestCapability(`org.matrix.msc2762.timeline:${roomId}`); - } - - /** - * Requests the capability to send a given state event with optional explicit - * state key. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} eventType The state event type to ask for. - * @param {string} stateKey If specified, the specific state key to request. - * Otherwise all state keys will be requested. - */ - public requestCapabilityToSendState(eventType: string, stateKey?: string) { - this.requestCapability(WidgetEventCapability.forStateEvent(EventDirection.Send, eventType, stateKey).raw); - } - - /** - * Requests the capability to receive a given state event with optional explicit - * state key. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} eventType The state event type to ask for. - * @param {string} stateKey If specified, the specific state key to request. - * Otherwise all state keys will be requested. - */ - public requestCapabilityToReceiveState(eventType: string, stateKey?: string) { - this.requestCapability(WidgetEventCapability.forStateEvent(EventDirection.Receive, eventType, stateKey).raw); - } - - /** - * Requests the capability to send a given to-device event. It is not - * guaranteed to be allowed, but will be asked for if the negotiation has - * not already happened. - * @param {string} eventType The room event type to ask for. - */ - public requestCapabilityToSendToDevice(eventType: string) { - this.requestCapability(WidgetEventCapability.forToDeviceEvent(EventDirection.Send, eventType).raw); - } - - /** - * Requests the capability to receive a given to-device event. It is not - * guaranteed to be allowed, but will be asked for if the negotiation has - * not already happened. - * @param {string} eventType The room event type to ask for. - */ - public requestCapabilityToReceiveToDevice(eventType: string) { - this.requestCapability(WidgetEventCapability.forToDeviceEvent(EventDirection.Receive, eventType).raw); - } - - /** - * Requests the capability to send a given room event. It is not guaranteed to be - * allowed, but will be asked for if the negotiation has not already happened. - * @param {string} eventType The room event type to ask for. - */ - public requestCapabilityToSendEvent(eventType: string) { - this.requestCapability(WidgetEventCapability.forRoomEvent(EventDirection.Send, eventType).raw); - } - - /** - * Requests the capability to receive a given room event. It is not guaranteed to be - * allowed, but will be asked for if the negotiation has not already happened. - * @param {string} eventType The room event type to ask for. - */ - public requestCapabilityToReceiveEvent(eventType: string) { - this.requestCapability(WidgetEventCapability.forRoomEvent(EventDirection.Receive, eventType).raw); - } - - /** - * Requests the capability to send a given message event with optional explicit - * `msgtype`. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} msgtype If specified, the specific msgtype to request. - * Otherwise all message types will be requested. - */ - public requestCapabilityToSendMessage(msgtype?: string) { - this.requestCapability(WidgetEventCapability.forRoomMessageEvent(EventDirection.Send, msgtype).raw); - } - - /** - * Requests the capability to receive a given message event with optional explicit - * `msgtype`. It is not guaranteed to be allowed, but will be asked for if the - * negotiation has not already happened. - * @param {string} msgtype If specified, the specific msgtype to request. - * Otherwise all message types will be requested. - */ - public requestCapabilityToReceiveMessage(msgtype?: string) { - this.requestCapability(WidgetEventCapability.forRoomMessageEvent(EventDirection.Receive, msgtype).raw); - } - - /** - * Requests an OpenID Connect token from the client for the currently logged in - * user. This token can be validated server-side with the federation API. Note - * that the widget is responsible for validating the token and caching any results - * it needs. - * @returns {Promise} Resolves to a token for verification. - * @throws Throws if the user rejected the request or the request failed. - */ - public requestOpenIDConnectToken(): Promise { - return new Promise((resolve, reject) => { - this.transport.sendComplete( - WidgetApiFromWidgetAction.GetOpenIDCredentials, {}, - ).then(response => { - const rdata = response.response; - if (rdata.state === OpenIDRequestState.Allowed) { - resolve(rdata); - } else if (rdata.state === OpenIDRequestState.Blocked) { - reject(new Error("User declined to verify their identity")); - } else if (rdata.state === OpenIDRequestState.PendingUserConfirmation) { - const handlerFn = (ev: CustomEvent) => { - ev.preventDefault(); - const request = ev.detail; - if (request.data.original_request_id !== response.requestId) return; - if (request.data.state === OpenIDRequestState.Allowed) { - resolve(request.data); - this.transport.reply(request, {}); // ack - } else if (request.data.state === OpenIDRequestState.Blocked) { - reject(new Error("User declined to verify their identity")); - this.transport.reply(request, {}); // ack - } else { - reject(new Error("Invalid state on reply: " + rdata.state)); - this.transport.reply(request, { - error: { - message: "Invalid state", - }, - }); - } - this.off(`action:${WidgetApiToWidgetAction.OpenIDCredentials}`, handlerFn); - }; - this.on(`action:${WidgetApiToWidgetAction.OpenIDCredentials}`, handlerFn); - } else { - reject(new Error("Invalid state: " + rdata.state)); - } - }).catch(reject); - }); - } - - /** - * Asks the client for additional capabilities. Capabilities can be queued for this - * request with the requestCapability() functions. - * @returns {Promise} Resolves when complete. Note that the promise resolves when - * the capabilities request has gone through, not when the capabilities are approved/denied. - * Use the WidgetApiToWidgetAction.NotifyCapabilities action to detect changes. - */ - public updateRequestedCapabilities(): Promise { - return this.transport.send(WidgetApiFromWidgetAction.MSC2974RenegotiateCapabilities, - { - capabilities: this.requestedCapabilities, - }).then(); - } - - /** - * Tell the client that the content has been loaded. - * @returns {Promise} Resolves when the client acknowledges the request. - */ - public sendContentLoaded(): Promise { - return this.transport.send(WidgetApiFromWidgetAction.ContentLoaded, {}).then(); - } - - /** - * Sends a sticker to the client. - * @param {IStickerActionRequestData} sticker The sticker to send. - * @returns {Promise} Resolves when the client acknowledges the request. - */ - public sendSticker(sticker: IStickerActionRequestData): Promise { - return this.transport.send(WidgetApiFromWidgetAction.SendSticker, sticker).then(); - } - - /** - * Asks the client to set the always-on-screen status for this widget. - * @param {boolean} value The new state to request. - * @returns {Promise} Resolve with true if the client was able to fulfill - * the request, resolves to false otherwise. Rejects if an error occurred. - */ - public setAlwaysOnScreen(value: boolean): Promise { - return this.transport.send( - WidgetApiFromWidgetAction.UpdateAlwaysOnScreen, {value}, - ).then(res => res.success); - } - - /** - * Opens a modal widget. - * @param {string} url The URL to the modal widget. - * @param {string} name The name of the widget. - * @param {IModalWidgetOpenRequestDataButton[]} buttons The buttons to have on the widget. - * @param {IModalWidgetCreateData} data Data to supply to the modal widget. - * @param {WidgetType} type The type of modal widget. - * @returns {Promise} Resolves when the modal widget has been opened. - */ - public openModalWidget( - url: string, - name: string, - buttons: IModalWidgetOpenRequestDataButton[] = [], - data: IModalWidgetCreateData = {}, - type: WidgetType = MatrixWidgetType.Custom, - ): Promise { - return this.transport.send( - WidgetApiFromWidgetAction.OpenModalWidget, { type, url, name, buttons, data }, - ).then(); - } - - /** - * Closes the modal widget. The widget's session will be terminated shortly after. - * @param {IModalWidgetReturnData} data Optional data to close the modal widget with. - * @returns {Promise} Resolves when complete. - */ - public closeModalWidget(data: IModalWidgetReturnData = {}): Promise { - return this.transport.send(WidgetApiFromWidgetAction.CloseModalWidget, data).then(); - } - - public sendRoomEvent( - eventType: string, - content: unknown, - roomId?: string, - ): Promise { - return this.transport.send( - WidgetApiFromWidgetAction.SendEvent, - {type: eventType, content, room_id: roomId}, - ); - } - - public sendStateEvent( - eventType: string, - stateKey: string, - content: unknown, - roomId?: string, - ): Promise { - return this.transport.send( - WidgetApiFromWidgetAction.SendEvent, - {type: eventType, content, state_key: stateKey, room_id: roomId}, - ); - } - - /** - * Sends a to-device event. - * @param {string} eventType The type of events being sent. - * @param {boolean} encrypted Whether to encrypt the message contents. - * @param {Object} contentMap A map from user IDs to device IDs to message contents. - * @returns {Promise} Resolves when complete. - */ - public sendToDevice( - eventType: string, - encrypted: boolean, - contentMap: { [userId: string]: { [deviceId: string]: object } }, - ): Promise { - return this.transport.send( - WidgetApiFromWidgetAction.SendToDevice, - {type: eventType, encrypted, messages: contentMap}, - ); - } - - public readRoomEvents( - eventType: string, - limit?: number, - msgtype?: string, - roomIds?: (string | Symbols.AnyRoom)[], - ): Promise { - const data: IReadEventFromWidgetRequestData = {type: eventType, msgtype: msgtype}; - if (limit !== undefined) { - data.limit = limit; - } - if (roomIds) { - if (roomIds.includes(Symbols.AnyRoom)) { - data.room_ids = Symbols.AnyRoom; - } else { - data.room_ids = roomIds; - } - } - return this.transport.send( - WidgetApiFromWidgetAction.MSC2876ReadEvents, - data, - ).then(r => r.events); - } - - /** - * Reads all related events given a known eventId. - * @param eventId The id of the parent event to be read. - * @param roomId The room to look within. When undefined, the user's currently - * viewed room. - * @param relationType The relationship type of child events to search for. - * When undefined, all relations are returned. - * @param eventType The event type of child events to search for. When undefined, - * all related events are returned. - * @param limit The maximum number of events to retrieve per room. If not - * supplied, the server will apply a default limit. - * @param from The pagination token to start returning results from, as - * received from a previous call. If not supplied, results start at the most - * recent topological event known to the server. - * @param to The pagination token to stop returning results at. If not - * supplied, results continue up to limit or until there are no more events. - * @param direction The direction to search for according to MSC3715. - * @returns Resolves to the room relations. - */ - public async readEventRelations( - eventId: string, - roomId?: string, - relationType?: string, - eventType?: string, - limit?: number, - from?: string, - to?: string, - direction?: 'f' | 'b', - ): Promise { - const versions = await this.getClientVersions(); - if (!versions.includes(UnstableApiVersion.MSC3869)) { - throw new Error("The read_relations action is not supported by the client.") - } - - const data: IReadRelationsFromWidgetRequestData = { - event_id: eventId, - rel_type: relationType, - event_type: eventType, - room_id: roomId, - to, - from, - limit, - direction, - }; - - return this.transport.send( - WidgetApiFromWidgetAction.MSC3869ReadRelations, - data, - ) - } - - public readStateEvents( - eventType: string, - limit?: number, - stateKey?: string, - roomIds?: (string | Symbols.AnyRoom)[], - ): Promise { - const data: IReadEventFromWidgetRequestData = { - type: eventType, - state_key: stateKey === undefined ? true : stateKey, - }; - if (limit !== undefined) { - data.limit = limit; - } - if (roomIds) { - if (roomIds.includes(Symbols.AnyRoom)) { - data.room_ids = Symbols.AnyRoom; - } else { - data.room_ids = roomIds; - } - } - return this.transport.send( - WidgetApiFromWidgetAction.MSC2876ReadEvents, - data, - ).then(r => r.events); - } - - /** - * Sets a button as disabled or enabled on the modal widget. Buttons are enabled by default. - * @param {ModalButtonID} buttonId The button ID to enable/disable. - * @param {boolean} isEnabled Whether or not the button is enabled. - * @returns {Promise} Resolves when complete. - * @throws Throws if the button cannot be disabled, or the client refuses to disable the button. - */ - public setModalButtonEnabled(buttonId: ModalButtonID, isEnabled: boolean): Promise { - if (buttonId === BuiltInModalButtonID.Close) { - throw new Error("The close button cannot be disabled"); - } - return this.transport.send( - WidgetApiFromWidgetAction.SetModalButtonEnabled, {button: buttonId, enabled: isEnabled}, - ).then(); - } - - /** - * Attempts to navigate the client to the given URI. This can only be called with Matrix URIs - * (currently only matrix.to, but in future a Matrix URI scheme will be defined). - * @param {string} uri The URI to navigate to. - * @returns {Promise} Resolves when complete. - * @throws Throws if the URI is invalid or cannot be processed. - * @deprecated This currently relies on an unstable MSC (MSC2931). - */ - public navigateTo(uri: string): Promise { - if (!uri || !uri.startsWith("https://matrix.to/#")) { - throw new Error("Invalid matrix.to URI"); - } - - return this.transport.send( - WidgetApiFromWidgetAction.MSC2931Navigate, {uri}, - ).then(); - } - - /** - * Starts watching for TURN servers, yielding an initial set of credentials as soon as possible, - * and thereafter yielding new credentials whenever the previous ones expire. - * @yields {ITurnServer} The TURN server URIs and credentials currently available to the widget. - */ - public async* getTurnServers(): AsyncGenerator { - let setTurnServer: (server: ITurnServer) => void; - - const onUpdateTurnServers = async (ev: CustomEvent) => { - ev.preventDefault(); - setTurnServer(ev.detail.data); - await this.transport.reply(ev.detail, {}); - }; - - // Start listening for updates before we even start watching, to catch - // TURN data that is sent immediately - this.on(`action:${WidgetApiToWidgetAction.UpdateTurnServers}`, onUpdateTurnServers); - - // Only send the 'watch' action if we aren't already watching - if (this.turnServerWatchers === 0) { - try { - await this.transport.send(WidgetApiFromWidgetAction.WatchTurnServers, {}); - } catch (e) { - this.off(`action:${WidgetApiToWidgetAction.UpdateTurnServers}`, onUpdateTurnServers); - throw e; - } - } - this.turnServerWatchers++; - - try { - // Watch for new data indefinitely (until this generator's return method is called) - while (true) { - yield await new Promise(resolve => setTurnServer = resolve); - } - } finally { - // The loop was broken by the caller - clean up - this.off(`action:${WidgetApiToWidgetAction.UpdateTurnServers}`, onUpdateTurnServers); - - // Since sending the 'unwatch' action will end updates for all other - // consumers, only send it if we're the only consumer remaining - this.turnServerWatchers--; - if (this.turnServerWatchers === 0) { - await this.transport.send(WidgetApiFromWidgetAction.UnwatchTurnServers, {}); - } - } - } - - /** - * Search for users in the user directory. - * @param searchTerm The term to search for. - * @param limit The maximum number of results to return. If not supplied, the - * @returns Resolves to the search results. - */ - public async searchUserDirectory( - searchTerm: string, - limit?: number, - ): Promise { - const versions = await this.getClientVersions(); - if (!versions.includes(UnstableApiVersion.MSC3973)) { - throw new Error("The user_directory_search action is not supported by the client.") - } - - const data: IUserDirectorySearchFromWidgetRequestData = { - search_term: searchTerm, - limit, - }; - - return this.transport.send< - IUserDirectorySearchFromWidgetRequestData, - IUserDirectorySearchFromWidgetResponseData - >(WidgetApiFromWidgetAction.MSC3973UserDirectorySearch, data); - } - - /** - * Starts the communication channel. This should be done early to ensure - * that messages are not missed. Communication can only be stopped by the client. - */ - public start() { - this.transport.start(); - this.getClientVersions().then(v => { - if (v.includes(UnstableApiVersion.MSC2974)) { - this.supportsMSC2974Renegotiate = true; - } - }); - } - - private handleMessage(ev: CustomEvent) { - const actionEv = new CustomEvent(`action:${ev.detail.action}`, { - detail: ev.detail, - cancelable: true, - }); - this.emit(`action:${ev.detail.action}`, actionEv); - if (!actionEv.defaultPrevented) { - switch (ev.detail.action) { - case WidgetApiToWidgetAction.SupportedApiVersions: - return this.replyVersions(ev.detail); - case WidgetApiToWidgetAction.Capabilities: - return this.handleCapabilities(ev.detail); - case WidgetApiToWidgetAction.UpdateVisibility: - return this.transport.reply(ev.detail, {}); // ack to avoid error spam - case WidgetApiToWidgetAction.NotifyCapabilities: - return this.transport.reply(ev.detail, {}); // ack to avoid error spam - default: - return this.transport.reply(ev.detail, { - error: { - message: "Unknown or unsupported action: " + ev.detail.action, - }, - }); - } - } - } - - private replyVersions(request: ISupportedVersionsActionRequest) { - this.transport.reply(request, { - supported_versions: CurrentApiVersions, - }); - } - - public getClientVersions(): Promise { - if (Array.isArray(this.cachedClientVersions)) { - return Promise.resolve(this.cachedClientVersions); - } - - return this.transport.send( - WidgetApiFromWidgetAction.SupportedApiVersions, {}, - ).then(r => { - this.cachedClientVersions = r.supported_versions; - return r.supported_versions; - }).catch(e => { - console.warn("non-fatal error getting supported client versions: ", e); - return []; - }); - } - - private handleCapabilities(request: ICapabilitiesActionRequest) { - if (this.capabilitiesFinished) { - return this.transport.reply(request, { - error: { - message: "Capability negotiation already completed", - }, - }); - } - - // See if we can expect a capabilities notification or not - return this.getClientVersions().then(v => { - if (v.includes(UnstableApiVersion.MSC2871)) { - this.once( - `action:${WidgetApiToWidgetAction.NotifyCapabilities}`, - (ev: CustomEvent) => { - this.approvedCapabilities = ev.detail.data.approved; - this.emit("ready"); - }, - ); - } else { - // if we can't expect notification, we're as done as we can be - this.emit("ready"); - } - - // in either case, reply to that capabilities request - this.capabilitiesFinished = true; - return this.transport.reply(request, { - capabilities: this.requestedCapabilities, - }); - }); - } -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/driver/WidgetDriver.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/driver/WidgetDriver.ts deleted file mode 100644 index 9fdeee2..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/driver/WidgetDriver.ts +++ /dev/null @@ -1,247 +0,0 @@ -/* - * Copyright 2020 - 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { Capability, IOpenIDCredentials, OpenIDRequestState, SimpleObservable, IRoomEvent, ITurnServer } from ".."; - -export interface ISendEventDetails { - roomId: string; - eventId: string; -} - -export interface IOpenIDUpdate { - state: OpenIDRequestState; - token?: IOpenIDCredentials; -} - -export interface IReadEventRelationsResult { - chunk: IRoomEvent[]; - nextBatch?: string; - prevBatch?: string; -} - -export interface ISearchUserDirectoryResult { - limited: boolean; - results: Array<{ - userId: string; - displayName?: string; - avatarUrl?: string; - }>; -} - -/** - * Represents the functions and behaviour the widget-api is unable to - * do, such as prompting the user for information or interacting with - * the UI. Clients are expected to implement this class and override - * any functions they need/want to support. - * - * This class assumes the client will have a context of a Widget - * instance already. - */ -export abstract class WidgetDriver { - /** - * Verifies the widget's requested capabilities, returning the ones - * it is approved to use. Mutating the requested capabilities will - * have no effect. - * - * This SHOULD result in the user being prompted to approve/deny - * capabilities. - * - * By default this rejects all capabilities (returns an empty set). - * @param {Set} requested The set of requested capabilities. - * @returns {Promise>} Resolves to the allowed capabilities. - */ - public validateCapabilities(requested: Set): Promise> { - return Promise.resolve(new Set()); - } - - /** - * Sends an event into a room. If `roomId` is falsy, the client should send the event - * into the room the user is currently looking at. The widget API will have already - * verified that the widget is capable of sending the event to that room. - * @param {string} eventType The event type to be sent. - * @param {*} content The content for the event. - * @param {string|null} stateKey The state key if this is a state event, otherwise null. - * May be an empty string. - * @param {string|null} roomId The room ID to send the event to. If falsy, the room the - * user is currently looking at. - * @returns {Promise} Resolves when the event has been sent with - * details of that event. - * @throws Rejected when the event could not be sent. - */ - public sendEvent( - eventType: string, - content: unknown, - stateKey: string | null = null, - roomId: string | null = null, - ): Promise { - return Promise.reject(new Error("Failed to override function")); - } - - /** - * Sends a to-device event. The widget API will have already verified that the widget - * is capable of sending the event. - * @param {string} eventType The event type to be sent. - * @param {boolean} encrypted Whether to encrypt the message contents. - * @param {Object} contentMap A map from user ID and device ID to event content. - * @returns {Promise} Resolves when the event has been sent. - * @throws Rejected when the event could not be sent. - */ - public sendToDevice( - eventType: string, - encrypted: boolean, - contentMap: { [userId: string]: { [deviceId: string]: object } }, - ): Promise { - return Promise.reject(new Error("Failed to override function")); - } - - /** - * Reads all events of the given type, and optionally `msgtype` (if applicable/defined), - * the user has access to. The widget API will have already verified that the widget is - * capable of receiving the events. Less events than the limit are allowed to be returned, - * but not more. If `roomIds` is supplied, it may contain `Symbols.AnyRoom` to denote that - * `limit` in each of the client's known rooms should be returned. When `null`, only the - * room the user is currently looking at should be considered. - * @param eventType The event type to be read. - * @param msgtype The msgtype of the events to be read, if applicable/defined. - * @param limit The maximum number of events to retrieve per room. Will be zero to denote "as many - * as possible". - * @param roomIds When null, the user's currently viewed room. Otherwise, the list of room IDs - * to look within, possibly containing Symbols.AnyRoom to denote all known rooms. - * @returns {Promise} Resolves to the room events, or an empty array. - */ - public readRoomEvents( - eventType: string, - msgtype: string | undefined, - limit: number, - roomIds: string[] | null = null, - ): Promise { - return Promise.resolve([]); - } - - /** - * Reads all events of the given type, and optionally state key (if applicable/defined), - * the user has access to. The widget API will have already verified that the widget is - * capable of receiving the events. Less events than the limit are allowed to be returned, - * but not more. If `roomIds` is supplied, it may contain `Symbols.AnyRoom` to denote that - * `limit` in each of the client's known rooms should be returned. When `null`, only the - * room the user is currently looking at should be considered. - * @param eventType The event type to be read. - * @param stateKey The state key of the events to be read, if applicable/defined. - * @param limit The maximum number of events to retrieve. Will be zero to denote "as many - * as possible". - * @param roomIds When null, the user's currently viewed room. Otherwise, the list of room IDs - * to look within, possibly containing Symbols.AnyRoom to denote all known rooms. - * @returns {Promise} Resolves to the state events, or an empty array. - */ - public readStateEvents( - eventType: string, - stateKey: string | undefined, - limit: number, - roomIds: string[] | null = null, - ): Promise { - return Promise.resolve([]); - } - - /** - * Reads all events that are related to a given event. The widget API will - * have already verified that the widget is capable of receiving the event, - * or will make sure to reject access to events which are returned from this - * function, but are not capable of receiving. If `relationType` or `eventType` - * are set, the returned events should already be filtered. Less events than - * the limit are allowed to be returned, but not more. - * @param eventId The id of the parent event to be read. - * @param roomId The room to look within. When undefined, the user's - * currently viewed room. - * @param relationType The relationship type of child events to search for. - * When undefined, all relations are returned. - * @param eventType The event type of child events to search for. When undefined, - * all related events are returned. - * @param from The pagination token to start returning results from, as - * received from a previous call. If not supplied, results start at the most - * recent topological event known to the server. - * @param to The pagination token to stop returning results at. If not - * supplied, results continue up to limit or until there are no more events. - * @param limit The maximum number of events to retrieve per room. If not - * supplied, the server will apply a default limit. - * @param direction The direction to search for according to MSC3715 - * @returns Resolves to the room relations. - */ - public readEventRelations( - eventId: string, - roomId?: string, - relationType?: string, - eventType?: string, - from?: string, - to?: string, - limit?: number, - direction?: 'f' | 'b', - ): Promise { - return Promise.resolve({ chunk: [] }); - } - - /** - * Asks the user for permission to validate their identity through OpenID Connect. The - * interface for this function is an observable which accepts the state machine of the - * OIDC exchange flow. For example, if the client/user blocks the request then it would - * feed back a `{state: Blocked}` into the observable. Similarly, if the user already - * approved the widget then a `{state: Allowed}` would be fed into the observable alongside - * the token itself. If the client is asking for permission, it should feed in a - * `{state: PendingUserConfirmation}` followed by the relevant Allowed or Blocked state. - * - * The widget API will reject the widget's request with an error if this contract is not - * met properly. By default, the widget driver will block all OIDC requests. - * @param {SimpleObservable} observer The observable to feed updates into. - */ - public askOpenID(observer: SimpleObservable) { - observer.update({state: OpenIDRequestState.Blocked}); - } - - /** - * Navigates the client with a matrix.to URI. In future this function will also be provided - * with the Matrix URIs once matrix.to is replaced. The given URI will have already been - * lightly checked to ensure it looks like a valid URI, though the implementation is recommended - * to do further checks on the URI. - * @param {string} uri The URI to navigate to. - * @returns {Promise} Resolves when complete. - * @throws Throws if there's a problem with the navigation, such as invalid format. - */ - public navigate(uri: string): Promise { - throw new Error("Navigation is not implemented"); - } - - /** - * Polls for TURN server data, yielding an initial set of credentials as soon as possible, and - * thereafter yielding new credentials whenever the previous ones expire. The widget API will - * have already verified that the widget has permission to access TURN servers. - * @yields {ITurnServer} The TURN server URIs and credentials currently available to the client. - */ - public getTurnServers(): AsyncGenerator { - throw new Error("TURN server support is not implemented"); - } - - /** - * Search for users in the user directory. - * @param searchTerm The term to search for. - * @param limit The maximum number of results to return. If not supplied, the - * @returns Resolves to the search results. - */ - public searchUserDirectory( - searchTerm: string, - limit?: number, - ): Promise { - return Promise.resolve({ limited: false, results: [] }); - } -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/index.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/index.ts deleted file mode 100644 index b7247c9..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/index.ts +++ /dev/null @@ -1,73 +0,0 @@ -/* -Copyright 2020 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -// Primary structures -export * from "./WidgetApi"; -export * from "./ClientWidgetApi"; -export * from "./Symbols"; - -// Transports (not sure why you'd use these directly, but might as well export all the things) -export * from "./transport/ITransport"; -export * from "./transport/PostmessageTransport"; - -// Interfaces and simple models -export * from "./interfaces/ICustomWidgetData"; -export * from "./interfaces/IJitsiWidgetData"; -export * from "./interfaces/IStickerpickerWidgetData"; -export * from "./interfaces/IWidget"; -export * from "./interfaces/WidgetType"; -export * from "./interfaces/IWidgetApiErrorResponse"; -export * from "./interfaces/IWidgetApiRequest"; -export * from "./interfaces/IWidgetApiResponse"; -export * from "./interfaces/WidgetApiAction"; -export * from "./interfaces/WidgetApiDirection"; -export * from "./interfaces/ApiVersion"; -export * from "./interfaces/Capabilities"; -export * from "./interfaces/CapabilitiesAction"; -export * from "./interfaces/ContentLoadedAction"; -export * from "./interfaces/ScreenshotAction"; -export * from "./interfaces/StickerAction"; -export * from "./interfaces/StickyAction"; -export * from "./interfaces/SupportedVersionsAction"; -export * from "./interfaces/VisibilityAction"; -export * from "./interfaces/GetOpenIDAction"; -export * from "./interfaces/OpenIDCredentialsAction"; -export * from "./interfaces/WidgetKind"; -export * from "./interfaces/ModalButtonKind"; -export * from "./interfaces/ModalWidgetActions"; -export * from "./interfaces/SetModalButtonEnabledAction"; -export * from "./interfaces/WidgetConfigAction"; -export * from "./interfaces/SendEventAction"; -export * from "./interfaces/SendToDeviceAction"; -export * from "./interfaces/ReadEventAction"; -export * from "./interfaces/IRoomEvent"; -export * from "./interfaces/NavigateAction"; -export * from "./interfaces/TurnServerActions"; -export * from "./interfaces/ReadRelationsAction"; - -// Complex models -export * from "./models/WidgetEventCapability"; -export * from "./models/validation/url"; -export * from "./models/validation/utils"; -export * from "./models/Widget"; -export * from "./models/WidgetParser"; - -// Utilities -export * from "./templating/url-template"; -export * from "./util/SimpleObservable"; - -// Drivers -export * from "./driver/WidgetDriver"; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ApiVersion.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ApiVersion.ts deleted file mode 100644 index 6586c14..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ApiVersion.ts +++ /dev/null @@ -1,50 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -export enum MatrixApiVersion { - Prerelease1 = "0.0.1", - Prerelease2 = "0.0.2", - //V010 = "0.1.0", // first release -} - -export enum UnstableApiVersion { - MSC2762 = "org.matrix.msc2762", - MSC2871 = "org.matrix.msc2871", - MSC2931 = "org.matrix.msc2931", - MSC2974 = "org.matrix.msc2974", - MSC2876 = "org.matrix.msc2876", - MSC3819 = "org.matrix.msc3819", - MSC3846 = "town.robin.msc3846", - MSC3869 = "org.matrix.msc3869", - MSC3973 = "org.matrix.msc3973", -} - -export type ApiVersion = MatrixApiVersion | UnstableApiVersion | string; - -export const CurrentApiVersions: ApiVersion[] = [ - MatrixApiVersion.Prerelease1, - MatrixApiVersion.Prerelease2, - //MatrixApiVersion.V010, - UnstableApiVersion.MSC2762, - UnstableApiVersion.MSC2871, - UnstableApiVersion.MSC2931, - UnstableApiVersion.MSC2974, - UnstableApiVersion.MSC2876, - UnstableApiVersion.MSC3819, - UnstableApiVersion.MSC3846, - UnstableApiVersion.MSC3869, - UnstableApiVersion.MSC3973, -]; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/Capabilities.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/Capabilities.ts deleted file mode 100644 index 1572105..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/Capabilities.ts +++ /dev/null @@ -1,71 +0,0 @@ -/* - * Copyright 2020 - 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { Symbols } from "../Symbols"; - -export enum MatrixCapabilities { - Screenshots = "m.capability.screenshot", - StickerSending = "m.sticker", - AlwaysOnScreen = "m.always_on_screen", - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - * Ask Element to not give the option to move the widget into a separate tab. - */ - RequiresClient = "io.element.requires_client", - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC2931Navigate = "org.matrix.msc2931.navigate", - MSC3846TurnServers = "town.robin.msc3846.turn_servers", - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC3973UserDirectorySearch = "org.matrix.msc3973.user_directory_search", -} - -export type Capability = MatrixCapabilities | string; - -export const StickerpickerCapabilities: Capability[] = [MatrixCapabilities.StickerSending]; -export const VideoConferenceCapabilities: Capability[] = [MatrixCapabilities.AlwaysOnScreen]; - -/** - * Determines if a capability is a capability for a timeline. - * @param {Capability} capability The capability to test. - * @returns {boolean} True if a timeline capability, false otherwise. - */ -export function isTimelineCapability(capability: Capability): boolean { - // TODO: Change when MSC2762 becomes stable. - return capability?.startsWith("org.matrix.msc2762.timeline:"); -} - -/** - * Determines if a capability is a timeline capability for the given room. - * @param {Capability} capability The capability to test. - * @param {string | Symbols.AnyRoom} roomId The room ID, or `Symbols.AnyRoom` for that designation. - * @returns {boolean} True if a matching capability, false otherwise. - */ -export function isTimelineCapabilityFor(capability: Capability, roomId: string | Symbols.AnyRoom): boolean { - return capability === `org.matrix.msc2762.timeline:${roomId}`; -} - -/** - * Gets the room ID described by a timeline capability. - * @param {string} capability The capability to parse. - * @returns {string} The room ID. - */ -export function getTimelineRoomIDFromCapability(capability: Capability): string { - return capability.substring(capability.indexOf(":") + 1); -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/CapabilitiesAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/CapabilitiesAction.ts deleted file mode 100644 index 365bb79..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/CapabilitiesAction.ts +++ /dev/null @@ -1,60 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData, IWidgetApiRequestEmptyData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { Capability } from "./Capabilities"; -import { IWidgetApiAcknowledgeResponseData, IWidgetApiResponseData } from "./IWidgetApiResponse"; - -export interface ICapabilitiesActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.Capabilities; - data: IWidgetApiRequestEmptyData; -} - -export interface ICapabilitiesActionResponseData extends IWidgetApiResponseData { - capabilities: Capability[]; -} - -export interface ICapabilitiesActionResponse extends ICapabilitiesActionRequest { - response: ICapabilitiesActionResponseData; -} - -export interface INotifyCapabilitiesActionRequestData extends IWidgetApiRequestData { - requested: Capability[]; - approved: Capability[]; -} - -export interface INotifyCapabilitiesActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.NotifyCapabilities; - data: INotifyCapabilitiesActionRequestData; -} - -export interface INotifyCapabilitiesActionResponse extends INotifyCapabilitiesActionRequest { - response: IWidgetApiAcknowledgeResponseData; -} - -export interface IRenegotiateCapabilitiesActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.MSC2974RenegotiateCapabilities; - data: IRenegotiateCapabilitiesRequestData; -} - -export interface IRenegotiateCapabilitiesRequestData extends IWidgetApiResponseData { - capabilities: Capability[]; -} - -export interface IRenegotiateCapabilitiesActionResponse extends IRenegotiateCapabilitiesActionRequest { - // nothing -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ContentLoadedAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ContentLoadedAction.ts deleted file mode 100644 index ceca93f..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ContentLoadedAction.ts +++ /dev/null @@ -1,28 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestEmptyData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData } from "./IWidgetApiResponse"; - -export interface IContentLoadedActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.ContentLoaded; - data: IWidgetApiRequestEmptyData; -} - -export interface IContentLoadedActionResponse extends IContentLoadedActionRequest { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/GetOpenIDAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/GetOpenIDAction.ts deleted file mode 100644 index 000313c..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/GetOpenIDAction.ts +++ /dev/null @@ -1,49 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; - -export enum OpenIDRequestState { - Allowed = "allowed", - Blocked = "blocked", - PendingUserConfirmation = "request", -} - -export interface IOpenIDCredentials { - access_token?: string; // eslint-disable-line camelcase - expires_in?: number; // eslint-disable-line camelcase - matrix_server_name?: string; // eslint-disable-line camelcase - token_type?: "Bearer" | string; // eslint-disable-line camelcase -} - -export interface IGetOpenIDActionRequestData extends IWidgetApiRequestData { - // nothing -} - -export interface IGetOpenIDActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.GetOpenIDCredentials; - data: IGetOpenIDActionRequestData; -} - -export interface IGetOpenIDActionResponseData extends IWidgetApiResponseData, IOpenIDCredentials { - state: OpenIDRequestState; -} - -export interface IGetOpenIDActionResponse extends IGetOpenIDActionRequest { - response: IGetOpenIDActionResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ICustomWidgetData.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ICustomWidgetData.ts deleted file mode 100644 index 56657fb..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ICustomWidgetData.ts +++ /dev/null @@ -1,27 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetData } from "./IWidget"; - -/** - * Widget data for m.custom specifically. - */ -export interface ICustomWidgetData extends IWidgetData { - /** - * The URL for the widget if the templated URL is not exactly what will be loaded. - */ - url?: string; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IJitsiWidgetData.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IJitsiWidgetData.ts deleted file mode 100644 index 65b22a0..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IJitsiWidgetData.ts +++ /dev/null @@ -1,38 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetData } from "./IWidget"; - -/** - * Widget data for m.jitsi widgets. - */ -export interface IJitsiWidgetData extends IWidgetData { - /** - * The domain where the Jitsi Meet conference is being held. - */ - domain: string; - - /** - * The conference ID (also known as the room name) where the conference is being held. - */ - conferenceId: string; - - /** - * Optional. True to indicate that the conference should be without video, false - * otherwise (default). - */ - isAudioOnly?: boolean; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IRoomEvent.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IRoomEvent.ts deleted file mode 100644 index 5e90005..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IRoomEvent.ts +++ /dev/null @@ -1,26 +0,0 @@ -/* - * Copyright 2020 - 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -export interface IRoomEvent { - type: string; - sender: string; - event_id: string; // eslint-disable-line camelcase - room_id: string; // eslint-disable-line camelcase - state_key?: string; // eslint-disable-line camelcase - origin_server_ts: number; // eslint-disable-line camelcase - content: unknown; - unsigned: unknown; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IStickerpickerWidgetData.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IStickerpickerWidgetData.ts deleted file mode 100644 index 1459fa5..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IStickerpickerWidgetData.ts +++ /dev/null @@ -1,21 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetData } from "./IWidget"; - -export interface IStickerpickerWidgetData extends IWidgetData { - // no additional properties (for now) -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidget.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidget.ts deleted file mode 100644 index a6ee670..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidget.ts +++ /dev/null @@ -1,75 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { WidgetType } from "./WidgetType"; - -/** - * Widget data. - */ -export interface IWidgetData { - /** - * Optional title for the widget. - */ - title?: string; - - /** - * Custom keys for inclusion in the template URL. - */ - [key: string]: unknown; -} - -/** - * Common properties of a widget. - * https://matrix.org/docs/spec/widgets/latest#widgetcommonproperties-schema - */ -export interface IWidget { - /** - * The ID of the widget. - */ - id: string; - - /** - * The user ID who originally created the widget. - */ - creatorUserId: string; - - /** - * Optional name for the widget. - */ - name?: string; - - /** - * The type of widget. - */ - type: WidgetType; - - /** - * The URL for the widget, with template variables. - */ - url: string; - - /** - * Optional flag to indicate whether or not the client should initiate communication - * right after the iframe loads (default, true) or when the widget indicates it is - * ready (false). - */ - waitForIframeLoad?: boolean; - - /** - * Data for the widget. - */ - data?: IWidgetData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidgetApiErrorResponse.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidgetApiErrorResponse.ts deleted file mode 100644 index f9e123f..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidgetApiErrorResponse.ts +++ /dev/null @@ -1,35 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiResponse, IWidgetApiResponseData } from "./IWidgetApiResponse"; - -export interface IWidgetApiErrorResponseData extends IWidgetApiResponseData { - error: { - message: string; - }; -} - -export interface IWidgetApiErrorResponse extends IWidgetApiResponse { - response: IWidgetApiErrorResponseData; -} - -export function isErrorResponse(responseData: IWidgetApiResponseData): boolean { - if ("error" in responseData) { - const err = responseData; - return !!err.error.message; - } - return false; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidgetApiRequest.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidgetApiRequest.ts deleted file mode 100644 index ec9e211..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidgetApiRequest.ts +++ /dev/null @@ -1,37 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { WidgetApiDirection } from "./WidgetApiDirection"; -import { WidgetApiAction } from "./WidgetApiAction"; - -export interface IWidgetApiRequestData { - [key: string]: unknown; -} - -export interface IWidgetApiRequestEmptyData extends IWidgetApiRequestData { - // nothing -} - -export interface IWidgetApiRequest { - api: WidgetApiDirection; - requestId: string; - action: WidgetApiAction; - widgetId: string; - data: IWidgetApiRequestData; - // XXX: This is for Scalar support - // TODO: Fix scalar - visible?: any; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidgetApiResponse.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidgetApiResponse.ts deleted file mode 100644 index 2347b6f..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/IWidgetApiResponse.ts +++ /dev/null @@ -1,29 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest } from "./IWidgetApiRequest"; - -export interface IWidgetApiResponseData { - [key: string]: unknown; -} - -export interface IWidgetApiAcknowledgeResponseData extends IWidgetApiResponseData { - // nothing -} - -export interface IWidgetApiResponse extends IWidgetApiRequest { - response: IWidgetApiResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ModalButtonKind.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ModalButtonKind.ts deleted file mode 100644 index e82c939..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ModalButtonKind.ts +++ /dev/null @@ -1,23 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -export enum ModalButtonKind { - Primary = "m.primary", - Secondary = "m.secondary", - Warning = "m.warning", - Danger = "m.danger", - Link = "m.link", -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ModalWidgetActions.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ModalWidgetActions.ts deleted file mode 100644 index b8f07d4..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ModalWidgetActions.ts +++ /dev/null @@ -1,89 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData, IWidgetApiResponse } from "./IWidgetApiResponse"; -import { IWidget } from "./IWidget"; -import { ModalButtonKind } from "./ModalButtonKind"; - -export enum BuiltInModalButtonID { - Close = "m.close", -} -export type ModalButtonID = BuiltInModalButtonID | string; - -export interface IModalWidgetCreateData extends IWidgetApiRequestData { - [key: string]: unknown; -} - -export interface IModalWidgetReturnData { - [key: string]: unknown; -} - -// Types for a normal modal requesting the opening a modal widget -export interface IModalWidgetOpenRequestDataButton { - id: ModalButtonID; - label: string; - kind: ModalButtonKind | string; - disabled?: boolean; -} - -export interface IModalWidgetOpenRequestData extends IModalWidgetCreateData, Omit { - buttons?: IModalWidgetOpenRequestDataButton[]; -} - -export interface IModalWidgetOpenRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.OpenModalWidget; - data: IModalWidgetOpenRequestData; -} - -export interface IModalWidgetOpenResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} - -// Types for a modal widget receiving notifications that its buttons have been pressed -export interface IModalWidgetButtonClickedRequestData extends IWidgetApiRequestData { - id: IModalWidgetOpenRequestDataButton["id"]; -} - -export interface IModalWidgetButtonClickedRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.ButtonClicked; - data: IModalWidgetButtonClickedRequestData; -} - -export interface IModalWidgetButtonClickedResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} - -// Types for a modal widget requesting close -export interface IModalWidgetCloseRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.CloseModalWidget; - data: IModalWidgetReturnData; -} - -export interface IModalWidgetCloseResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} - -// Types for a normal widget being notified that the modal widget it opened has been closed -export interface IModalWidgetCloseNotificationRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.CloseModalWidget; - data: IModalWidgetReturnData; -} - -export interface IModalWidgetCloseNotificationResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/NavigateAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/NavigateAction.ts deleted file mode 100644 index 04960eb..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/NavigateAction.ts +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData } from "./IWidgetApiResponse"; - -export interface INavigateActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.MSC2931Navigate; - data: INavigateActionRequestData; -} - -export interface INavigateActionRequestData extends IWidgetApiRequestData { - uri: string; -} - -export interface INavigateActionResponse extends INavigateActionRequest { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/OpenIDCredentialsAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/OpenIDCredentialsAction.ts deleted file mode 100644 index c4766f1..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/OpenIDCredentialsAction.ts +++ /dev/null @@ -1,38 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -import { IOpenIDCredentials, OpenIDRequestState } from "./GetOpenIDAction"; - -export interface IOpenIDCredentialsActionRequestData extends IWidgetApiRequestData, IOpenIDCredentials { - state: OpenIDRequestState; - original_request_id: string; // eslint-disable-line camelcase -} - -export interface IOpenIDCredentialsActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.OpenIDCredentials; - data: IOpenIDCredentialsActionRequestData; -} - -export interface IOpenIDCredentialsActionResponseData extends IWidgetApiResponseData { - // nothing -} - -export interface IOpenIDCredentialsIDActionResponse extends IOpenIDCredentialsActionRequest { - response: IOpenIDCredentialsActionResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ReadEventAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ReadEventAction.ts deleted file mode 100644 index 8cea7cf..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ReadEventAction.ts +++ /dev/null @@ -1,42 +0,0 @@ -/* - * Copyright 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -import { IRoomEvent } from "./IRoomEvent"; -import { Symbols } from "../Symbols"; - -export interface IReadEventFromWidgetRequestData extends IWidgetApiRequestData { - state_key?: string | boolean; // eslint-disable-line camelcase - msgtype?: string; - type: string; - limit?: number; - room_ids?: Symbols.AnyRoom | string[]; // eslint-disable-line camelcase -} - -export interface IReadEventFromWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.MSC2876ReadEvents; - data: IReadEventFromWidgetRequestData; -} - -export interface IReadEventFromWidgetResponseData extends IWidgetApiResponseData { - events: IRoomEvent[]; -} - -export interface IReadEventFromWidgetActionResponse extends IReadEventFromWidgetActionRequest { - response: IReadEventFromWidgetResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ReadRelationsAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ReadRelationsAction.ts deleted file mode 100644 index 76a041a..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ReadRelationsAction.ts +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright 2022 Nordeck IT + Consulting GmbH. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IRoomEvent } from "./IRoomEvent"; -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; - -export interface IReadRelationsFromWidgetRequestData extends IWidgetApiRequestData { - event_id: string; // eslint-disable-line camelcase - rel_type?: string; // eslint-disable-line camelcase - event_type?: string; // eslint-disable-line camelcase - room_id?: string; // eslint-disable-line camelcase - - limit?: number; - from?: string; - to?: string; - direction?: 'f' | 'b'; -} - -export interface IReadRelationsFromWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.MSC3869ReadRelations; - data: IReadRelationsFromWidgetRequestData; -} - -export interface IReadRelationsFromWidgetResponseData extends IWidgetApiResponseData { - chunk: IRoomEvent[]; - - next_batch?: string; // eslint-disable-line camelcase - prev_batch?: string; // eslint-disable-line camelcase -} - -export interface IReadRelationsFromWidgetActionResponse extends IReadRelationsFromWidgetActionRequest { - response: IReadRelationsFromWidgetResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ScreenshotAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ScreenshotAction.ts deleted file mode 100644 index f9ec315..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/ScreenshotAction.ts +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestEmptyData } from "./IWidgetApiRequest"; -import { WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; - -export interface IScreenshotActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.TakeScreenshot; - data: IWidgetApiRequestEmptyData; -} - -export interface IScreenshotActionResponseData extends IWidgetApiResponseData { - screenshot: Blob; -} - -export interface IScreenshotActionResponse extends IScreenshotActionRequest { - response: IScreenshotActionResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SendEventAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SendEventAction.ts deleted file mode 100644 index 8fe6da0..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SendEventAction.ts +++ /dev/null @@ -1,57 +0,0 @@ -/* - * Copyright 2020 - 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -import { IRoomEvent } from "./IRoomEvent"; - -export interface ISendEventFromWidgetRequestData extends IWidgetApiRequestData { - state_key?: string; // eslint-disable-line camelcase - type: string; - content: unknown; - room_id?: string; // eslint-disable-line camelcase -} - -export interface ISendEventFromWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.SendEvent; - data: ISendEventFromWidgetRequestData; -} - -export interface ISendEventFromWidgetResponseData extends IWidgetApiResponseData { - room_id: string; // eslint-disable-line camelcase - event_id: string; // eslint-disable-line camelcase -} - -export interface ISendEventFromWidgetActionResponse extends ISendEventFromWidgetActionRequest { - response: ISendEventFromWidgetResponseData; -} - -export interface ISendEventToWidgetRequestData extends IWidgetApiRequestData, IRoomEvent { -} - -export interface ISendEventToWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.SendEvent; - data: ISendEventToWidgetRequestData; -} - -export interface ISendEventToWidgetResponseData extends IWidgetApiResponseData { - // nothing -} - -export interface ISendEventToWidgetActionResponse extends ISendEventToWidgetActionRequest { - response: ISendEventToWidgetResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SendToDeviceAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SendToDeviceAction.ts deleted file mode 100644 index e7507b3..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SendToDeviceAction.ts +++ /dev/null @@ -1,56 +0,0 @@ -/* - * Copyright 2022 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -import { IRoomEvent } from "./IRoomEvent"; - -export interface ISendToDeviceFromWidgetRequestData extends IWidgetApiRequestData { - type: string; - encrypted: boolean; - messages: { [userId: string]: { [deviceId: string]: object } }; -} - -export interface ISendToDeviceFromWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.SendToDevice; - data: ISendToDeviceFromWidgetRequestData; -} - -export interface ISendToDeviceFromWidgetResponseData extends IWidgetApiResponseData { - // nothing -} - -export interface ISendToDeviceFromWidgetActionResponse extends ISendToDeviceFromWidgetActionRequest { - response: ISendToDeviceFromWidgetResponseData; -} - -export interface ISendToDeviceToWidgetRequestData extends IWidgetApiRequestData, IRoomEvent { - encrypted: boolean; -} - -export interface ISendToDeviceToWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.SendToDevice; - data: ISendToDeviceToWidgetRequestData; -} - -export interface ISendToDeviceToWidgetResponseData extends IWidgetApiResponseData { - // nothing -} - -export interface ISendToDeviceToWidgetActionResponse extends ISendToDeviceToWidgetActionRequest { - response: ISendToDeviceToWidgetResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SetModalButtonEnabledAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SetModalButtonEnabledAction.ts deleted file mode 100644 index 5702e8c..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SetModalButtonEnabledAction.ts +++ /dev/null @@ -1,34 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData } from "./IWidgetApiResponse"; -import { ModalButtonID } from "./ModalWidgetActions"; - -export interface ISetModalButtonEnabledActionRequestData extends IWidgetApiRequestData { - enabled: boolean; - button: ModalButtonID; -} - -export interface ISetModalButtonEnabledActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.SetModalButtonEnabled; - data: ISetModalButtonEnabledActionRequestData; -} - -export interface ISetModalButtonEnabledActionResponse extends ISetModalButtonEnabledActionRequest { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/StickerAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/StickerAction.ts deleted file mode 100644 index 13cb94a..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/StickerAction.ts +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData } from "./IWidgetApiResponse"; - -export interface IStickerActionRequestData extends IWidgetApiRequestData { - name: string; - description?: string; - content: { - url: string; - info?: { - h?: number; - w?: number; - mimetype?: string; - size?: number; - thumbnail_info?: { // eslint-disable-line camelcase - h?: number; - w?: number; - mimetype?: string; - size?: number; - }; - }; - }; -} - -export interface IStickerActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.SendSticker; - data: IStickerActionRequestData; -} - -export interface IStickerActionResponse extends IStickerActionRequest { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/StickyAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/StickyAction.ts deleted file mode 100644 index 7d49f02..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/StickyAction.ts +++ /dev/null @@ -1,36 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; - -export interface IStickyActionRequestData extends IWidgetApiRequestData { - value: boolean; -} - -export interface IStickyActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.UpdateAlwaysOnScreen; - data: IStickyActionRequestData; -} - -export interface IStickyActionResponseData extends IWidgetApiResponseData { - success: boolean; -} - -export interface IStickyActionResponse extends IStickyActionRequest { - response: IStickyActionResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SupportedVersionsAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SupportedVersionsAction.ts deleted file mode 100644 index 8486ebc..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/SupportedVersionsAction.ts +++ /dev/null @@ -1,33 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestEmptyData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { ApiVersion } from "./ApiVersion"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; - -export interface ISupportedVersionsActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.SupportedApiVersions | WidgetApiToWidgetAction.SupportedApiVersions; - data: IWidgetApiRequestEmptyData; -} - -export interface ISupportedVersionsActionResponseData extends IWidgetApiResponseData { - supported_versions: ApiVersion[]; // eslint-disable-line camelcase -} - -export interface ISupportedVersionsActionResponse extends ISupportedVersionsActionRequest { - response: ISupportedVersionsActionResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/TurnServerActions.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/TurnServerActions.ts deleted file mode 100644 index 3a9bd29..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/TurnServerActions.ts +++ /dev/null @@ -1,55 +0,0 @@ -/* - * Copyright 2022 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData, IWidgetApiRequestEmptyData } from "./IWidgetApiRequest"; -import { WidgetApiFromWidgetAction, WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData, IWidgetApiResponse } from "./IWidgetApiResponse"; - -export interface ITurnServer { - uris: string[]; - username: string; - password: string; -} - -export interface IWatchTurnServersRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.WatchTurnServers; - data: IWidgetApiRequestEmptyData; -} - -export interface IWatchTurnServersResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} - -export interface IUnwatchTurnServersRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.UnwatchTurnServers; - data: IWidgetApiRequestEmptyData; -} - -export interface IUnwatchTurnServersResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} - -export interface IUpdateTurnServersRequestData extends IWidgetApiRequestData, ITurnServer { -} - -export interface IUpdateTurnServersRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.UpdateTurnServers; - data: IUpdateTurnServersRequestData; -} - -export interface IUpdateTurnServersResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/UserDirectorySearchAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/UserDirectorySearchAction.ts deleted file mode 100644 index fb900cc..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/UserDirectorySearchAction.ts +++ /dev/null @@ -1,42 +0,0 @@ -/* - * Copyright 2023 Nordeck IT + Consulting GmbH. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { IWidgetApiResponseData } from "./IWidgetApiResponse"; -import { WidgetApiFromWidgetAction } from "./WidgetApiAction"; - -export interface IUserDirectorySearchFromWidgetRequestData extends IWidgetApiRequestData { - search_term: string; // eslint-disable-line camelcase - limit?: number; -} - -export interface IUserDirectorySearchFromWidgetActionRequest extends IWidgetApiRequest { - action: WidgetApiFromWidgetAction.MSC3973UserDirectorySearch; - data: IUserDirectorySearchFromWidgetRequestData; -} - -export interface IUserDirectorySearchFromWidgetResponseData extends IWidgetApiResponseData { - limited: boolean; - results: Array<{ - user_id: string; // eslint-disable-line camelcase - display_name?: string; // eslint-disable-line camelcase - avatar_url?: string; // eslint-disable-line camelcase - }>; -} - -export interface IUserDirectorySearchFromWidgetActionResponse extends IUserDirectorySearchFromWidgetActionRequest { - response: IUserDirectorySearchFromWidgetResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/VisibilityAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/VisibilityAction.ts deleted file mode 100644 index 55aa53f..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/VisibilityAction.ts +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest, IWidgetApiRequestData } from "./IWidgetApiRequest"; -import { WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData } from "./IWidgetApiResponse"; - -export interface IVisibilityActionRequestData extends IWidgetApiRequestData { - visible: boolean; -} - -export interface IVisibilityActionRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.UpdateVisibility; - data: IVisibilityActionRequestData; -} - -export interface IVisibilityActionResponse extends IVisibilityActionRequest { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetApiAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetApiAction.ts deleted file mode 100644 index 34c8aa3..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetApiAction.ts +++ /dev/null @@ -1,72 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -export enum WidgetApiToWidgetAction { - SupportedApiVersions = "supported_api_versions", - Capabilities = "capabilities", - NotifyCapabilities = "notify_capabilities", - TakeScreenshot = "screenshot", - UpdateVisibility = "visibility", - OpenIDCredentials = "openid_credentials", - WidgetConfig = "widget_config", - CloseModalWidget = "close_modal", - ButtonClicked = "button_clicked", - SendEvent = "send_event", - SendToDevice = "send_to_device", - UpdateTurnServers = "update_turn_servers", -} - -export enum WidgetApiFromWidgetAction { - SupportedApiVersions = "supported_api_versions", - ContentLoaded = "content_loaded", - SendSticker = "m.sticker", - UpdateAlwaysOnScreen = "set_always_on_screen", - GetOpenIDCredentials = "get_openid", - CloseModalWidget = "close_modal", - OpenModalWidget = "open_modal", - SetModalButtonEnabled = "set_button_enabled", - SendEvent = "send_event", - SendToDevice = "send_to_device", - WatchTurnServers = "watch_turn_servers", - UnwatchTurnServers = "unwatch_turn_servers", - - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC2876ReadEvents = "org.matrix.msc2876.read_events", - - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC2931Navigate = "org.matrix.msc2931.navigate", - - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC2974RenegotiateCapabilities = "org.matrix.msc2974.request_capabilities", - - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC3869ReadRelations = "org.matrix.msc3869.read_relations", - - /** - * @deprecated It is not recommended to rely on this existing - it can be removed without notice. - */ - MSC3973UserDirectorySearch = "org.matrix.msc3973.user_directory_search", -} - -export type WidgetApiAction = WidgetApiToWidgetAction | WidgetApiFromWidgetAction | string; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetApiDirection.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetApiDirection.ts deleted file mode 100644 index e11e144..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetApiDirection.ts +++ /dev/null @@ -1,30 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -export enum WidgetApiDirection { - ToWidget = "toWidget", - FromWidget = "fromWidget", -} - -export function invertedDirection(dir: WidgetApiDirection): WidgetApiDirection { - if (dir === WidgetApiDirection.ToWidget) { - return WidgetApiDirection.FromWidget; - } else if (dir === WidgetApiDirection.FromWidget) { - return WidgetApiDirection.ToWidget; - } else { - throw new Error("Invalid direction"); - } -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetConfigAction.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetConfigAction.ts deleted file mode 100644 index b10314c..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetConfigAction.ts +++ /dev/null @@ -1,29 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidgetApiRequest } from "./IWidgetApiRequest"; -import { WidgetApiToWidgetAction } from "./WidgetApiAction"; -import { IWidgetApiAcknowledgeResponseData, IWidgetApiResponse } from "./IWidgetApiResponse"; -import { IModalWidgetOpenRequestData } from "./ModalWidgetActions"; - -export interface IWidgetConfigRequest extends IWidgetApiRequest { - action: WidgetApiToWidgetAction.WidgetConfig; - data: IModalWidgetOpenRequestData; -} - -export interface IWidgetConfigResponse extends IWidgetApiResponse { - response: IWidgetApiAcknowledgeResponseData; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetKind.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetKind.ts deleted file mode 100644 index 374e198..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetKind.ts +++ /dev/null @@ -1,21 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -export enum WidgetKind { - Room = "room", - Account = "account", - Modal = "modal", -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetType.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetType.ts deleted file mode 100644 index d6b3e33..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/interfaces/WidgetType.ts +++ /dev/null @@ -1,23 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -export enum MatrixWidgetType { - Custom = "m.custom", - JitsiMeet = "m.jitsi", - Stickerpicker = "m.stickerpicker", -} - -export type WidgetType = MatrixWidgetType | string; diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/models/Widget.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/models/Widget.ts deleted file mode 100644 index 0b66452..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/models/Widget.ts +++ /dev/null @@ -1,109 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidget, IWidgetData, WidgetType } from ".."; -import { assertPresent } from "./validation/utils"; -import { ITemplateParams, runTemplate } from ".."; - -/** - * Represents the barest form of widget. - */ -export class Widget { - public constructor(private definition: IWidget) { - if (!this.definition) throw new Error("Definition is required"); - - assertPresent(definition, "id"); - assertPresent(definition, "creatorUserId"); - assertPresent(definition, "type"); - assertPresent(definition, "url"); - } - - /** - * The user ID who created the widget. - */ - public get creatorUserId(): string { - return this.definition.creatorUserId; - } - - /** - * The type of widget. - */ - public get type(): WidgetType { - return this.definition.type; - } - - /** - * The ID of the widget. - */ - public get id(): string { - return this.definition.id; - } - - /** - * The name of the widget, or null if not set. - */ - public get name(): string | null { - return this.definition.name || null; - } - - /** - * The title for the widget, or null if not set. - */ - public get title(): string | null { - return this.rawData.title || null; - } - - /** - * The templated URL for the widget. - */ - public get templateUrl(): string { - return this.definition.url; - } - - /** - * The origin for this widget. - */ - public get origin(): string { - return new URL(this.templateUrl).origin; - } - - /** - * Whether or not the client should wait for the iframe to load. Defaults - * to true. - */ - public get waitForIframeLoad(): boolean { - if (this.definition.waitForIframeLoad === false) return false; - if (this.definition.waitForIframeLoad === true) return true; - return true; // default true - } - - /** - * The raw data for the widget. This will always be defined, though - * may be empty. - */ - public get rawData(): IWidgetData { - return this.definition.data || {}; - } - - /** - * Gets a complete widget URL for the client to render. - * @param {ITemplateParams} params The template parameters. - * @returns {string} A templated URL. - */ - public getCompleteUrl(params: ITemplateParams): string { - return runTemplate(this.templateUrl, this.definition, params); - } -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/models/WidgetEventCapability.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/models/WidgetEventCapability.ts deleted file mode 100644 index 16d933e..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/models/WidgetEventCapability.ts +++ /dev/null @@ -1,204 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { Capability } from ".."; - -export enum EventKind { - Event = "event", - State = "state_event", - ToDevice = "to_device", -} - -export enum EventDirection { - Send = "send", - Receive = "receive", -} - -export class WidgetEventCapability { - private constructor( - public readonly direction: EventDirection, - public readonly eventType: string, - public readonly kind: EventKind, - public readonly keyStr: string | null, - public readonly raw: string, - ) { - } - - public matchesAsStateEvent(direction: EventDirection, eventType: string, stateKey: string | null): boolean { - if (this.kind !== EventKind.State) return false; // not a state event - if (this.direction !== direction) return false; // direction mismatch - if (this.eventType !== eventType) return false; // event type mismatch - if (this.keyStr === null) return true; // all state keys are allowed - if (this.keyStr === stateKey) return true; // this state key is allowed - - // Default not allowed - return false; - } - - public matchesAsToDeviceEvent(direction: EventDirection, eventType: string): boolean { - if (this.kind !== EventKind.ToDevice) return false; // not a to-device event - if (this.direction !== direction) return false; // direction mismatch - if (this.eventType !== eventType) return false; // event type mismatch - - // Checks passed, the event is allowed - return true; - } - - public matchesAsRoomEvent(direction: EventDirection, eventType: string, msgtype: string | null = null): boolean { - if (this.kind !== EventKind.Event) return false; // not a room event - if (this.direction !== direction) return false; // direction mismatch - if (this.eventType !== eventType) return false; // event type mismatch - - if (this.eventType === "m.room.message") { - if (this.keyStr === null) return true; // all message types are allowed - if (this.keyStr === msgtype) return true; // this message type is allowed - } else { - return true; // already passed the check for if the event is allowed - } - - // Default not allowed - return false; - } - - public static forStateEvent( - direction: EventDirection, - eventType: string, - stateKey?: string, - ): WidgetEventCapability { - // TODO: Enable support for m.* namespace once the MSC lands. - // https://github.com/matrix-org/matrix-widget-api/issues/22 - eventType = eventType.replace(/#/g, '\\#'); - stateKey = stateKey !== null && stateKey !== undefined ? `#${stateKey}` : ''; - const str = `org.matrix.msc2762.${direction}.state_event:${eventType}${stateKey}`; - - // cheat by sending it through the processor - return WidgetEventCapability.findEventCapabilities([str])[0]; - } - - public static forToDeviceEvent(direction: EventDirection, eventType: string): WidgetEventCapability { - // TODO: Enable support for m.* namespace once the MSC lands. - // https://github.com/matrix-org/matrix-widget-api/issues/56 - const str = `org.matrix.msc3819.${direction}.to_device:${eventType}`; - - // cheat by sending it through the processor - return WidgetEventCapability.findEventCapabilities([str])[0]; - } - - public static forRoomEvent(direction: EventDirection, eventType: string): WidgetEventCapability { - // TODO: Enable support for m.* namespace once the MSC lands. - // https://github.com/matrix-org/matrix-widget-api/issues/22 - const str = `org.matrix.msc2762.${direction}.event:${eventType}`; - - // cheat by sending it through the processor - return WidgetEventCapability.findEventCapabilities([str])[0]; - } - - public static forRoomMessageEvent(direction: EventDirection, msgtype?: string): WidgetEventCapability { - // TODO: Enable support for m.* namespace once the MSC lands. - // https://github.com/matrix-org/matrix-widget-api/issues/22 - msgtype = msgtype === null || msgtype === undefined ? '' : msgtype; - const str = `org.matrix.msc2762.${direction}.event:m.room.message#${msgtype}`; - - // cheat by sending it through the processor - return WidgetEventCapability.findEventCapabilities([str])[0]; - } - - /** - * Parses a capabilities request to find all the event capability requests. - * @param {Iterable} capabilities The capabilities requested/to parse. - * @returns {WidgetEventCapability[]} An array of event capability requests. May be empty, but never null. - */ - public static findEventCapabilities(capabilities: Iterable): WidgetEventCapability[] { - const parsed: WidgetEventCapability[] = []; - for (const cap of capabilities) { - let direction: EventDirection | null = null; - let eventSegment: string | undefined; - let kind: EventKind | null = null; - - // TODO: Enable support for m.* namespace once the MSCs land. - // https://github.com/matrix-org/matrix-widget-api/issues/22 - // https://github.com/matrix-org/matrix-widget-api/issues/56 - - if (cap.startsWith("org.matrix.msc2762.send.event:")) { - direction = EventDirection.Send; - kind = EventKind.Event; - eventSegment = cap.substring("org.matrix.msc2762.send.event:".length); - } else if (cap.startsWith("org.matrix.msc2762.send.state_event:")) { - direction = EventDirection.Send; - kind = EventKind.State; - eventSegment = cap.substring("org.matrix.msc2762.send.state_event:".length); - } else if (cap.startsWith("org.matrix.msc3819.send.to_device:")) { - direction = EventDirection.Send; - kind = EventKind.ToDevice; - eventSegment = cap.substring("org.matrix.msc3819.send.to_device:".length); - } else if (cap.startsWith("org.matrix.msc2762.receive.event:")) { - direction = EventDirection.Receive; - kind = EventKind.Event; - eventSegment = cap.substring("org.matrix.msc2762.receive.event:".length); - } else if (cap.startsWith("org.matrix.msc2762.receive.state_event:")) { - direction = EventDirection.Receive; - kind = EventKind.State; - eventSegment = cap.substring("org.matrix.msc2762.receive.state_event:".length); - } else if (cap.startsWith("org.matrix.msc3819.receive.to_device:")) { - direction = EventDirection.Receive; - kind = EventKind.ToDevice; - eventSegment = cap.substring("org.matrix.msc3819.receive.to_device:".length); - } - - if (direction === null || kind === null || eventSegment === undefined) continue; - - // The capability uses `#` as a separator between event type and state key/msgtype, - // so we split on that. However, a # is also valid in either one of those so we - // join accordingly. - // Eg: `m.room.message##m.text` is "m.room.message" event with msgtype "#m.text". - const expectingKeyStr = eventSegment.startsWith("m.room.message#") || kind === EventKind.State; - let keyStr: string | null = null; - if (eventSegment.includes('#') && expectingKeyStr) { - // Dev note: regex is difficult to write, so instead the rules are manually written - // out. This is probably just as understandable as a boring regex though, so win-win? - - // Test cases: - // str eventSegment keyStr - // ------------------------------------------------------------- - // m.room.message# m.room.message - // m.room.message#test m.room.message test - // m.room.message\# m.room.message# test - // m.room.message##test m.room.message #test - // m.room.message\##test m.room.message# test - // m.room.message\\##test m.room.message\# test - // m.room.message\\###test m.room.message\# #test - - // First step: explode the string - const parts = eventSegment.split('#'); - - // To form the eventSegment, we'll keep finding parts of the exploded string until - // there's one that doesn't end with the escape character (\). We'll then join those - // segments together with the exploding character. We have to remember to consume the - // escape character as well. - const idx = parts.findIndex(p => !p.endsWith("\\")); - eventSegment = parts.slice(0, idx + 1) - .map(p => p.endsWith('\\') ? p.substring(0, p.length - 1) : p) - .join('#'); - - // The keyStr is whatever is left over. - keyStr = parts.slice(idx + 1).join('#'); - } - - parsed.push(new WidgetEventCapability(direction, eventSegment, kind, keyStr, cap)); - } - return parsed; - } -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/models/WidgetParser.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/models/WidgetParser.ts deleted file mode 100644 index f93c077..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/models/WidgetParser.ts +++ /dev/null @@ -1,147 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { Widget } from "./Widget"; -import { IWidget } from ".."; -import { isValidUrl } from "./validation/url"; - -export interface IStateEvent { - event_id: string; // eslint-disable-line camelcase - room_id: string; // eslint-disable-line camelcase - type: string; - sender: string; - origin_server_ts: number; // eslint-disable-line camelcase - unsigned?: unknown; - content: unknown; - state_key: string; // eslint-disable-line camelcase -} - -export interface IAccountDataWidgets { - [widgetId: string]: { - type: "m.widget"; - // the state_key is also the widget's ID - state_key: string; // eslint-disable-line camelcase - sender: string; // current user's ID - content: IWidget; - id?: string; // off-spec, but possible - }; -} - -export class WidgetParser { - private constructor() { - // private constructor because this is a util class - } - - /** - * Parses widgets from the "m.widgets" account data event. This will always - * return an array, though may be empty if no valid widgets were found. - * @param {IAccountDataWidgets} content The content of the "m.widgets" account data. - * @returns {Widget[]} The widgets in account data, or an empty array. - */ - public static parseAccountData(content: IAccountDataWidgets): Widget[] { - if (!content) return []; - - const result: Widget[] = []; - for (const widgetId of Object.keys(content)) { - const roughWidget = content[widgetId]; - if (!roughWidget) continue; - if (roughWidget.type !== "m.widget" && roughWidget.type !== "im.vector.modular.widgets") continue; - if (!roughWidget.sender) continue; - - const probableWidgetId = roughWidget.state_key || roughWidget.id; - if (probableWidgetId !== widgetId) continue; - - const asStateEvent: IStateEvent = { - content: roughWidget.content, - sender: roughWidget.sender, - type: "m.widget", - state_key: widgetId, - event_id: "$example", - room_id: "!example", - origin_server_ts: 1, - }; - - const widget = WidgetParser.parseRoomWidget(asStateEvent); - if (widget) result.push(widget); - } - - return result; - } - - /** - * Parses all the widgets possible in the given array. This will always return - * an array, though may be empty if no widgets could be parsed. - * @param {IStateEvent[]} currentState The room state to parse. - * @returns {Widget[]} The widgets in the state, or an empty array. - */ - public static parseWidgetsFromRoomState(currentState: IStateEvent[]): Widget[] { - if (!currentState) return []; - const result: Widget[] = []; - for (const state of currentState) { - const widget = WidgetParser.parseRoomWidget(state); - if (widget) result.push(widget); - } - return result; - } - - /** - * Parses a state event into a widget. If the state event does not represent - * a widget (wrong event type, invalid widget, etc) then null is returned. - * @param {IStateEvent} stateEvent The state event. - * @returns {Widget|null} The widget, or null if invalid - */ - public static parseRoomWidget(stateEvent: IStateEvent): Widget | null { - if (!stateEvent) return null; - - // TODO: [Legacy] Remove legacy support - if (stateEvent.type !== "m.widget" && stateEvent.type !== "im.vector.modular.widgets") { - return null; - } - - // Dev note: Throughout this function we have null safety to ensure that - // if the caller did not supply something useful that we don't error. This - // is done against the requirements of the interface because not everyone - // will have an interface to validate against. - - const content = stateEvent.content as IWidget || {}; - - // Form our best approximation of a widget with the information we have - const estimatedWidget: IWidget = { - id: stateEvent.state_key, - creatorUserId: content['creatorUserId'] || stateEvent.sender, - name: content['name'], - type: content['type'], - url: content['url'], - waitForIframeLoad: content['waitForIframeLoad'], - data: content['data'], - }; - - // Finally, process that widget - return WidgetParser.processEstimatedWidget(estimatedWidget); - } - - private static processEstimatedWidget(widget: IWidget): Widget | null { - // Validate that the widget has the best chance of passing as a widget - if (!widget.id || !widget.creatorUserId || !widget.type) { - return null; - } - if (!isValidUrl(widget.url)) { - return null; - } - // TODO: Validate data for known widget types - return new Widget(widget); - } -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/models/validation/url.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/models/validation/url.ts deleted file mode 100644 index c56a9c6..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/models/validation/url.ts +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -export function isValidUrl(val: string): boolean { - if (!val) return false; // easy: not valid if not present - - try { - const parsed = new URL(val); - if (parsed.protocol !== "http" && parsed.protocol !== "https") { - return false; - } - return true; - } catch (e) { - if (e instanceof TypeError) { - return false; - } - throw e; - } -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/models/validation/utils.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/models/validation/utils.ts deleted file mode 100644 index b9c8761..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/models/validation/utils.ts +++ /dev/null @@ -1,21 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -export function assertPresent(obj: O, key: keyof O) { - if (!obj[key]) { - throw new Error(`${key} is required`); - } -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/templating/url-template.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/templating/url-template.ts deleted file mode 100644 index 901f131..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/templating/url-template.ts +++ /dev/null @@ -1,62 +0,0 @@ -/* - * Copyright 2020, 2021 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { IWidget } from ".."; - -export interface ITemplateParams { - widgetRoomId?: string; - currentUserId: string; - userDisplayName?: string; - userHttpAvatarUrl?: string; - clientId?: string; - clientTheme?: string; - clientLanguage?: string; -} - -export function runTemplate(url: string, widget: IWidget, params: ITemplateParams): string { - // Always apply the supplied params over top of data to ensure the data can't lie about them. - const variables = Object.assign({}, widget.data, { - 'matrix_room_id': params.widgetRoomId || "", - 'matrix_user_id': params.currentUserId, - 'matrix_display_name': params.userDisplayName || params.currentUserId, - 'matrix_avatar_url': params.userHttpAvatarUrl || "", - 'matrix_widget_id': widget.id, - - // TODO: Convert to stable (https://github.com/matrix-org/matrix-doc/pull/2873) - 'org.matrix.msc2873.client_id': params.clientId || "", - 'org.matrix.msc2873.client_theme': params.clientTheme || "", - 'org.matrix.msc2873.client_language': params.clientLanguage || "", - }); - let result = url; - for (const key of Object.keys(variables)) { - // Regex escape from https://stackoverflow.com/a/6969486/7037379 - const pattern = `$${key}`.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'); // $& means the whole matched string - const rexp = new RegExp(pattern, 'g'); - - // This is technically not what we're supposed to do for a couple of reasons: - // 1. We are assuming that there won't later be a $key match after we replace a variable. - // 2. We are assuming that the variable is in a place where it can be escaped (eg: path or query string). - result = result.replace(rexp, encodeURIComponent(toString(variables[key]))); - } - return result; -} - -export function toString(a: unknown): string { - if (a === null || a === undefined) { - return `${a}`; - } - return String(a); -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/transport/ITransport.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/transport/ITransport.ts deleted file mode 100644 index b3b2e9a..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/transport/ITransport.ts +++ /dev/null @@ -1,104 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { EventEmitter } from "events"; -import { - IWidgetApiAcknowledgeResponseData, - IWidgetApiRequest, - IWidgetApiRequestData, - IWidgetApiResponse, - IWidgetApiResponseData, - WidgetApiAction, -} from ".."; - -/** - * A transport for widget requests/responses. All actions - * get raised through a "message" CustomEvent with detail - * of the IWidgetApiRequest. - */ -export interface ITransport extends EventEmitter { - /** - * True if the transport is ready to start sending, false otherwise. - */ - readonly ready: boolean; - - /** - * The widget ID, if known. If not known, null. - */ - readonly widgetId: string | null; - - /** - * If true, the transport will refuse requests from origins other than the - * widget's current origin. This is intended to be used only by widgets which - * need excess security. - */ - strictOriginCheck: boolean; - - /** - * The origin the transport should be replying/sending to. If not known, leave - * null. - */ - targetOrigin: string | null; - - /** - * The number of seconds an outbound request is allowed to take before it - * times out. - */ - timeoutSeconds: number; - - /** - * Starts the transport for listening - */ - start(): void; - - /** - * Stops the transport. It cannot be re-started. - */ - stop(): void; - - /** - * Sends a request to the remote end. - * @param {WidgetApiAction} action The action to send. - * @param {IWidgetApiRequestData} data The request data. - * @returns {Promise} A promise which resolves - * to the remote end's response, or throws with an Error if the request - * failed. - */ - send( - action: WidgetApiAction, - data: T - ): Promise; - - /** - * Sends a request to the remote end. This is similar to the send() function - * however this version returns the full response rather than just the response - * data. - * @param {WidgetApiAction} action The action to send. - * @param {IWidgetApiRequestData} data The request data. - * @returns {Promise} A promise which resolves - * to the remote end's response, or throws with an Error if the request - * failed. - */ - sendComplete(action: WidgetApiAction, data: T) - : Promise; - - /** - * Replies to a request. - * @param {IWidgetApiRequest} request The request to reply to. - * @param {IWidgetApiResponseData} responseData The response data to reply with. - */ - reply(request: IWidgetApiRequest, responseData: T): void; -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/transport/PostmessageTransport.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/transport/PostmessageTransport.ts deleted file mode 100644 index 9f86aa5..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/transport/PostmessageTransport.ts +++ /dev/null @@ -1,203 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import { EventEmitter } from "events"; -import { ITransport } from "./ITransport"; -import { - invertedDirection, - isErrorResponse, - IWidgetApiErrorResponseData, - IWidgetApiRequest, - IWidgetApiRequestData, - IWidgetApiResponse, - IWidgetApiResponseData, - WidgetApiAction, - WidgetApiDirection, - WidgetApiToWidgetAction, -} from ".."; - -interface IOutboundRequest { - request: IWidgetApiRequest; - resolve: (response: IWidgetApiResponse) => void; - reject: (err: Error) => void; -} - -/** - * Transport for the Widget API over postMessage. - */ -export class PostmessageTransport extends EventEmitter implements ITransport { - public strictOriginCheck = false; - public targetOrigin = "*"; - public timeoutSeconds = 10; - - private _ready = false; - private _widgetId: string | null = null; - private outboundRequests = new Map(); - private stopController = new AbortController(); - - public get ready(): boolean { - return this._ready; - } - - public get widgetId(): string | null { - return this._widgetId || null; - } - - public constructor( - private sendDirection: WidgetApiDirection, - private initialWidgetId: string | null, - private transportWindow: Window, - private inboundWindow: Window, - ) { - super(); - this._widgetId = initialWidgetId; - } - - private get nextRequestId(): string { - const idBase = `widgetapi-${Date.now()}`; - let index = 0; - let id = idBase; - while (this.outboundRequests.has(id)) { - id = `${idBase}-${index++}`; - } - - // reserve the ID - this.outboundRequests.set(id, null); - - return id; - } - - private sendInternal(message: IWidgetApiRequest | IWidgetApiResponse) { - console.log(`[PostmessageTransport] Sending object to ${this.targetOrigin}: `, message); - this.transportWindow.postMessage(message, this.targetOrigin); - } - - public reply(request: IWidgetApiRequest, responseData: T) { - return this.sendInternal({ - ...request, - response: responseData, - }); - } - - public send( - action: WidgetApiAction, data: T, - ): Promise { - return this.sendComplete(action, data).then(r => r.response); - } - - public sendComplete( - action: WidgetApiAction, data: T, - ): Promise { - if (!this.ready || !this.widgetId) { - return Promise.reject(new Error("Not ready or unknown widget ID")); - } - const request: IWidgetApiRequest = { - api: this.sendDirection, - widgetId: this.widgetId, - requestId: this.nextRequestId, - action: action, - data: data, - }; - if (action === WidgetApiToWidgetAction.UpdateVisibility) { - request['visible'] = data['visible']; - } - return new Promise((prResolve, prReject) => { - const resolve = (response: IWidgetApiResponse) => { - cleanUp(); - prResolve(response); - }; - const reject = (err: Error) => { - cleanUp(); - prReject(err); - }; - - const timerId = setTimeout( - () => reject(new Error("Request timed out")), - (this.timeoutSeconds || 1) * 1000, - ); - - const onStop = () => reject(new Error("Transport stopped")); - this.stopController.signal.addEventListener("abort", onStop); - - const cleanUp = () => { - this.outboundRequests.delete(request.requestId); - clearTimeout(timerId); - this.stopController.signal.removeEventListener("abort", onStop); - }; - - this.outboundRequests.set(request.requestId, { request, resolve, reject }); - this.sendInternal(request); - }); - } - - public start() { - this.inboundWindow.addEventListener("message", (ev: MessageEvent) => { - this.handleMessage(ev); - }); - this._ready = true; - } - - public stop() { - this._ready = false; - this.stopController.abort(); - } - - private handleMessage(ev: MessageEvent) { - if (this.stopController.signal.aborted) return; - if (!ev.data) return; // invalid event - - if (this.strictOriginCheck && ev.origin !== window.origin) return; // bad origin - - // treat the message as a response first, then downgrade to a request - const response = ev.data; - if (!response.action || !response.requestId || !response.widgetId) return; // invalid request/response - - if (!response.response) { - // it's a request - const request = response; - if (request.api !== invertedDirection(this.sendDirection)) return; // wrong direction - this.handleRequest(request); - } else { - // it's a response - if (response.api !== this.sendDirection) return; // wrong direction - this.handleResponse(response); - } - } - - private handleRequest(request: IWidgetApiRequest) { - if (this.widgetId) { - if (this.widgetId !== request.widgetId) return; // wrong widget - } else { - this._widgetId = request.widgetId; - } - - this.emit("message", new CustomEvent("message", {detail: request})); - } - - private handleResponse(response: IWidgetApiResponse) { - if (response.widgetId !== this.widgetId) return; // wrong widget - - const req = this.outboundRequests.get(response.requestId); - if (!req) return; // response to an unknown request - - if (isErrorResponse(response.response)) { - const err = response.response; - req.reject(new Error(err.error.message)); - } else { - req.resolve(response); - } - } -} diff --git a/includes/external/matrix/node_modules/matrix-widget-api/src/util/SimpleObservable.ts b/includes/external/matrix/node_modules/matrix-widget-api/src/util/SimpleObservable.ts deleted file mode 100644 index 77b2080..0000000 --- a/includes/external/matrix/node_modules/matrix-widget-api/src/util/SimpleObservable.ts +++ /dev/null @@ -1,39 +0,0 @@ -/* - * Copyright 2020 The Matrix.org Foundation C.I.C. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -export type ObservableFunction = (val: T) => void; - -export class SimpleObservable { - private listeners: ObservableFunction[] = []; - - public constructor(initialFn?: ObservableFunction) { - if (initialFn) this.listeners.push(initialFn); - } - - public onUpdate(fn: ObservableFunction) { - this.listeners.push(fn); - } - - public update(val: T) { - for (const listener of this.listeners) { - listener(val); - } - } - - public close() { - this.listeners = []; // reset - } -} -- cgit