@event-chat/rpc 0.1.28 → 0.1.30
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/core/RPCAction.d.ts +1 -0
- package/dist/core/RPCAction.d.ts.map +1 -1
- package/dist/core/RPCAction.js +4 -2
- package/dist/core/registry.d.ts +2 -3
- package/dist/core/registry.d.ts.map +1 -1
- package/dist/createCtx.d.ts +1 -1
- package/dist/createCtx.d.ts.map +1 -1
- package/dist/entry/broadcastChannel.d.ts +2 -2
- package/dist/entry/broadcastChannel.d.ts.map +1 -1
- package/dist/entry/dedicatedWorkerGlobalScope.d.ts +2 -2
- package/dist/entry/dedicatedWorkerGlobalScope.d.ts.map +1 -1
- package/dist/entry/messagePort.d.ts +36 -6
- package/dist/entry/messagePort.d.ts.map +1 -1
- package/dist/entry/messagePort.js +42 -1
- package/dist/entry/serviceWorkerGlobalScope.d.ts +2 -2
- package/dist/entry/serviceWorkerGlobalScope.d.ts.map +1 -1
- package/dist/entry/serviceWorkerRegistration.d.ts +2 -2
- package/dist/entry/serviceWorkerRegistration.d.ts.map +1 -1
- package/dist/entry/sharedWorker.d.ts +2 -2
- package/dist/entry/sharedWorker.d.ts.map +1 -1
- package/dist/entry/sharedWorkerGlobalScope.d.ts +8 -24
- package/dist/entry/sharedWorkerGlobalScope.d.ts.map +1 -1
- package/dist/entry/sharedWorkerGlobalScope.js +12 -6
- package/dist/entry/webSocket.d.ts +2 -2
- package/dist/entry/webSocket.d.ts.map +1 -1
- package/dist/entry/window.d.ts +2 -2
- package/dist/entry/window.d.ts.map +1 -1
- package/dist/entry/worker.d.ts +2 -2
- package/dist/entry/worker.d.ts.map +1 -1
- package/dist/fields.d.ts +15 -41
- package/dist/fields.d.ts.map +1 -1
- package/dist/fields.js +1 -30
- package/dist/index.d.ts +2 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -4
- package/dist/react/fields.d.ts +0 -3
- package/dist/react/fields.d.ts.map +1 -1
- package/dist/react/hooks.d.ts +2 -4
- package/dist/react/hooks.d.ts.map +1 -1
- package/dist/react/index.d.ts +0 -1
- package/dist/react/index.d.ts.map +1 -1
- package/dist/react/index.js +0 -1
- package/dist/transports/BaseTransport.d.ts +1 -5
- package/dist/transports/BaseTransport.d.ts.map +1 -1
- package/dist/transports/BroadcastChannelTransport.d.ts.map +1 -1
- package/dist/transports/BroadcastChannelTransport.js +1 -1
- package/dist/transports/DedicatedWorkerGlobalScopeTransport.d.ts.map +1 -1
- package/dist/transports/DedicatedWorkerGlobalScopeTransport.js +1 -1
- package/dist/transports/MessagePortTransport.d.ts.map +1 -1
- package/dist/transports/MessagePortTransport.js +1 -1
- package/dist/transports/ServiceWorkerGlobalScopeTransport.d.ts +3 -5
- package/dist/transports/ServiceWorkerGlobalScopeTransport.d.ts.map +1 -1
- package/dist/transports/ServiceWorkerGlobalScopeTransport.js +10 -16
- package/dist/transports/ServiceWorkerRegistrationTransport.d.ts.map +1 -1
- package/dist/transports/ServiceWorkerRegistrationTransport.js +1 -1
- package/dist/transports/SharedWorkerGlobalScopeTransport.d.ts.map +1 -1
- package/dist/transports/SharedWorkerGlobalScopeTransport.js +1 -1
- package/dist/transports/SharedWorkerTransport.d.ts.map +1 -1
- package/dist/transports/SharedWorkerTransport.js +1 -1
- package/dist/transports/WebSocketTransport.d.ts +1 -4
- package/dist/transports/WebSocketTransport.d.ts.map +1 -1
- package/dist/transports/WebSocketTransport.js +9 -14
- package/dist/transports/WindowTransport.d.ts.map +1 -1
- package/dist/transports/WindowTransport.js +1 -1
- package/dist/transports/WorkerTransport.d.ts.map +1 -1
- package/dist/transports/WorkerTransport.js +1 -1
- package/dist/utils.d.ts +6 -0
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +17 -1
- package/package.json +1 -1
- package/dist/RPCAction.d.ts +0 -43
- package/dist/RPCAction.d.ts.map +0 -1
- package/dist/RPCAction.js +0 -196
- package/dist/RPCDecorator.d.ts +0 -21
- package/dist/RPCDecorator.d.ts.map +0 -1
- package/dist/RPCDecorator.js +0 -57
- package/dist/RPCFactory.d.ts +0 -22
- package/dist/RPCFactory.d.ts.map +0 -1
- package/dist/RPCFactory.js +0 -141
- package/dist/RPCProvider.d.ts +0 -4
- package/dist/RPCProvider.d.ts.map +0 -1
- package/dist/RPCProvider.js +0 -34
- package/dist/hooks.d.ts +0 -34
- package/dist/hooks.d.ts.map +0 -1
- package/dist/hooks.js +0 -82
- package/dist/react/createCtx.d.ts +0 -13
- package/dist/react/createCtx.d.ts.map +0 -1
- package/dist/react/createCtx.js +0 -33
- package/dist/transports/fields.d.ts +0 -19
- package/dist/transports/fields.d.ts.map +0 -1
- package/dist/transports/fields.js +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../src/react/hooks.ts"],"names":[],"mappings":"AACA,OAAO,YAAY,EAAE,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAA;AACnF,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../src/react/hooks.ts"],"names":[],"mappings":"AACA,OAAO,YAAY,EAAE,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAA;AACnF,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,WAAW,CAAA;AAMnE,QAAA,MAAM,MAAM,GACV,MAAM,SAAS,UAAU,EACzB,KAAK,SAAS,YAAY,EAC1B,OAAO,SAAS,YAAY,EAE5B,KAAK,eAAe,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC,GAAG,eAAe,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;kBAiC7E,MAAM;;;EAsFhB,CAAA;AAED,eAAe,MAAM,CAAA;AAGrB,MAAM,MAAM,UAAU,GAClB,gBAAgB,GAChB,yBAAyB,GACzB,YAAY,GACZ,SAAS,GACT,MAAM,GACN,MAAM,GACN,iBAAiB,GACjB,IAAI,CAAA;AAER,UAAU,cAAc,CAAC,MAAM,SAAS,UAAU;IAChD,IAAI,EAAE,MAAM,MAAM,GAAG,IAAI,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA;IAClD,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,OAAO,CAAC,EAAE,cAAc,CAAA;IACxB,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,IAAI,CAAA;CACjC;AAED,UAAU,eAAe,CACvB,MAAM,SAAS,UAAU,EACzB,KAAK,SAAS,YAAY,EAC1B,OAAO,SAAS,YAAY,CAE5B,SAAQ,cAAc,CAAC,MAAM,CAAC,EAAE,gBAAgB,CAAC,KAAK,EAAE,OAAO,CAAC;IAChE,KAAK,EAAE,CACL,MAAM,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,YAAY,CAAC,KAAK,EAAE,OAAO,CAAC,KAClC,SAAS,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC,CAAA;CACvC;AAED,UAAU,eAAe,CACvB,MAAM,SAAS,UAAU,EACzB,KAAK,SAAS,YAAY,EAC1B,OAAO,SAAS,YAAY,CAE5B,SAAQ,cAAc,CAAC,MAAM,CAAC,EAAE,gBAAgB,CAAC,KAAK,EAAE,OAAO,CAAC;IAChE,KAAK,EAAE,CACL,MAAM,EAAE,OAAO,EACf,OAAO,CAAC,EAAE,YAAY,CAAC,KAAK,EAAE,OAAO,CAAC,KACnC,OAAO,CAAC,SAAS,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC,CAAA;CAChD;AAED,KAAK,SAAS,CACZ,MAAM,SAAS,UAAU,EACzB,KAAK,SAAS,YAAY,EAC1B,OAAO,SAAS,YAAY,IAC1B,UAAU,CACZ,OAAO,YAAY,CACjB;IAAC,MAAM;CAAC,SAAS,CAAC,IAAI,CAAC,GACnB,IAAI,GACJ,MAAM,SAAS,gBAAgB,GAC7B,SAAS,CAAC,IAAI,CAAC,GACf,SAAS,CAAC,KAAK,CAAC,EACtB,KAAK,EACL,OAAO,CACR,CACF,CAAA"}
|
package/dist/react/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/react/index.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/react/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,qBAAqB,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAA;AAC9F,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,KAAK,UAAU,EAAE,MAAM,SAAS,CAAA;AAC5D,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAA"}
|
package/dist/react/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IframeSerializeOptions, ListenerType, MessageInfo, MessageItem, Transport } from '../fields';
|
|
1
|
+
import { FactoryOptions, IframeSerializeOptions, ListenerType, MessageInfo, MessageItem, Transport } from '../fields';
|
|
2
2
|
declare abstract class BaseTransport<T extends TargetType = TargetType, ONLYBD extends boolean = false> implements Transport<ONLYBD> {
|
|
3
3
|
protected _target: T;
|
|
4
4
|
protected _options: FactoryOptions;
|
|
@@ -16,9 +16,5 @@ declare abstract class BaseTransport<T extends TargetType = TargetType, ONLYBD e
|
|
|
16
16
|
abstract postMessage(message: MessageItem, options?: IframeSerializeOptions): Promise<unknown>;
|
|
17
17
|
}
|
|
18
18
|
export default BaseTransport;
|
|
19
|
-
export interface FactoryOptions {
|
|
20
|
-
message?: boolean | AddEventListenerOptions;
|
|
21
|
-
observer?: () => unknown;
|
|
22
|
-
}
|
|
23
19
|
export type TargetType = BroadcastChannel | MessagePort | WebSocket | Window | ServiceWorkerRegistration | ServiceWorkerGlobalScope | SharedWorker | SharedWorkerGlobalScope | Worker | DedicatedWorkerGlobalScope;
|
|
24
20
|
//# sourceMappingURL=BaseTransport.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BaseTransport.d.ts","sourceRoot":"","sources":["../../src/transports/BaseTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EACtB,YAAY,EACZ,WAAW,EACX,WAAW,EACX,SAAS,EACV,MAAM,WAAW,CAAA;AAElB,uBAAe,aAAa,CAC1B,CAAC,SAAS,UAAU,GAAG,UAAU,EACjC,MAAM,SAAS,OAAO,GAAG,KAAK,CAC9B,YAAW,SAAS,CAAC,MAAM,CAAC;IAG1B,SAAS,CAAC,OAAO,EAAE,CAAC;IACpB,SAAS,CAAC,QAAQ,EAAE,cAAc;IAHpC,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;gBAEd,OAAO,EAAE,CAAC,EACV,QAAQ,GAAE,cAAmB;IAIzC,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE;IAIxC,OAAO;IAIP,EAAE,CAAC,MAAM,EAAE,WAAW,CAAC,QAAQ,CAAC;IAIhC,YAAY,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE;IAI9B,KAAK,CAAC,OAAO,EAAE,cAAc;IAM7B,QAAQ,CAAC,OAAO,IAAI,IAAI;IAIxB,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,MAAM,IAAI,GAAG,IAAI;IAC1C,QAAQ,CAAC,SAAS,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAGhD,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAC/C,QAAQ,CAAC,WAAW,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,sBAAsB,GAAG,OAAO,CAAC,OAAO,CAAC;CAC/F;AAED,eAAe,aAAa,CAAA;
|
|
1
|
+
{"version":3,"file":"BaseTransport.d.ts","sourceRoot":"","sources":["../../src/transports/BaseTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACd,sBAAsB,EACtB,YAAY,EACZ,WAAW,EACX,WAAW,EACX,SAAS,EACV,MAAM,WAAW,CAAA;AAElB,uBAAe,aAAa,CAC1B,CAAC,SAAS,UAAU,GAAG,UAAU,EACjC,MAAM,SAAS,OAAO,GAAG,KAAK,CAC9B,YAAW,SAAS,CAAC,MAAM,CAAC;IAG1B,SAAS,CAAC,OAAO,EAAE,CAAC;IACpB,SAAS,CAAC,QAAQ,EAAE,cAAc;IAHpC,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;gBAEd,OAAO,EAAE,CAAC,EACV,QAAQ,GAAE,cAAmB;IAIzC,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE;IAIxC,OAAO;IAIP,EAAE,CAAC,MAAM,EAAE,WAAW,CAAC,QAAQ,CAAC;IAIhC,YAAY,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE;IAI9B,KAAK,CAAC,OAAO,EAAE,cAAc;IAM7B,QAAQ,CAAC,OAAO,IAAI,IAAI;IAIxB,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,MAAM,IAAI,GAAG,IAAI;IAC1C,QAAQ,CAAC,SAAS,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAGhD,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAC/C,QAAQ,CAAC,WAAW,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,sBAAsB,GAAG,OAAO,CAAC,OAAO,CAAC;CAC/F;AAED,eAAe,aAAa,CAAA;AAI5B,MAAM,MAAM,UAAU,GAClB,gBAAgB,GAChB,WAAW,GACX,SAAS,GACT,MAAM,GAEN,yBAAyB,GACzB,wBAAwB,GACxB,YAAY,GACZ,uBAAuB,GACvB,MAAM,GACN,0BAA0B,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BroadcastChannelTransport.d.ts","sourceRoot":"","sources":["../../src/transports/BroadcastChannelTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"BroadcastChannelTransport.d.ts","sourceRoot":"","sources":["../../src/transports/BroadcastChannelTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAErD,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAG3C,cAAM,yBAA0B,SAAQ,aAAa,CAAC,gBAAgB,EAAE,IAAI,CAAC;IAC3E,SAAkB,QAAQ,QAAO;IAEjC,OAAO;IAKP,OAAO,IAAI,IAAI;IAEf,SAAS,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAIvC,QAAQ,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAItC,WAAW,CAAC,OAAO,EAAE,WAAW;CAGjC;AAED,eAAe,yBAAyB,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DedicatedWorkerGlobalScopeTransport.d.ts","sourceRoot":"","sources":["../../src/transports/DedicatedWorkerGlobalScopeTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"DedicatedWorkerGlobalScopeTransport.d.ts","sourceRoot":"","sources":["../../src/transports/DedicatedWorkerGlobalScopeTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAE7E,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAG3C,cAAM,mCAAoC,SAAQ,aAAa,CAAC,0BAA0B,CAAC;IAEzF,OAAO;IAKP,OAAO,IAAI,IAAI;IAEf,SAAS,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAIvC,QAAQ,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAItC,WAAW,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,sBAAsB;CAInE;AAED,eAAe,mCAAmC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MessagePortTransport.d.ts","sourceRoot":"","sources":["../../src/transports/MessagePortTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"MessagePortTransport.d.ts","sourceRoot":"","sources":["../../src/transports/MessagePortTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAE7E,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAE3C,cAAM,oBAAqB,SAAQ,aAAa,CAAC,WAAW,CAAC;IAC3D,OAAO;IAKP,OAAO,IAAI,IAAI;IAEf,SAAS,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAKvC,QAAQ,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAItC,WAAW,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,sBAAsB;CAInE;AAED,eAAe,oBAAoB,CAAA"}
|
|
@@ -1,17 +1,15 @@
|
|
|
1
1
|
import { IframeSerializeOptions, ListenerType, MessageItem } from '../fields';
|
|
2
|
-
import BaseTransport
|
|
2
|
+
import BaseTransport from './BaseTransport';
|
|
3
3
|
declare class ServiceWorkerGlobalScopeTransport extends BaseTransport<ServiceWorkerGlobalScope> {
|
|
4
|
-
|
|
5
|
-
protected _options: FactoryOptions;
|
|
4
|
+
private _source;
|
|
6
5
|
private _fetch;
|
|
7
6
|
private _onconnect;
|
|
8
|
-
private _source;
|
|
9
|
-
constructor(_target: ServiceWorkerGlobalScope, _options?: FactoryOptions);
|
|
10
7
|
destroy(): void;
|
|
11
8
|
observe(): void;
|
|
12
9
|
onmessage(listener: ListenerType): void;
|
|
13
10
|
onremove(): void;
|
|
14
11
|
postMessage(message: MessageItem, options?: IframeSerializeOptions): Promise<void[]> | Promise<void | undefined>;
|
|
12
|
+
private _fetchHandle;
|
|
15
13
|
}
|
|
16
14
|
export {};
|
|
17
15
|
export default ServiceWorkerGlobalScopeTransport;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ServiceWorkerGlobalScopeTransport.d.ts","sourceRoot":"","sources":["../../src/transports/ServiceWorkerGlobalScopeTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"ServiceWorkerGlobalScopeTransport.d.ts","sourceRoot":"","sources":["../../src/transports/ServiceWorkerGlobalScopeTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAE7E,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAG3C,cAAM,iCAAkC,SAAQ,aAAa,CAAC,wBAAwB,CAAC;IACrF,OAAO,CAAC,OAAO,CAA8C;IAC7D,OAAO,CAAC,MAAM,CAA+B;IAC7C,OAAO,CAAC,UAAU,CAAuD;IAIzE,OAAO;IAMP,OAAO,IAAI,IAAI;IAIf,SAAS,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAuBvC,QAAQ,IAAI,IAAI;IAKhB,WAAW,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,sBAAsB;IAyBlE,OAAO,CAAC,YAAY;CAQrB;AAED,OAAO,EAAE,CAAA;AAET,eAAe,iCAAiC,CAAA"}
|
|
@@ -1,23 +1,11 @@
|
|
|
1
|
-
import { ProxyPromise } from "../
|
|
1
|
+
import { ProxyPromise } from "../utils.js";
|
|
2
2
|
import BaseTransport from "./BaseTransport.js";
|
|
3
3
|
class ServiceWorkerGlobalScopeTransport extends BaseTransport {
|
|
4
|
-
_target;
|
|
5
|
-
_options;
|
|
6
|
-
_fetch;
|
|
7
|
-
_onconnect;
|
|
8
4
|
_source;
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
this._fetch = (event)=>{
|
|
12
|
-
self.clients.get(event.clientId).then((client)=>{
|
|
13
|
-
if (client) this._source = client;
|
|
14
|
-
}).catch(()=>{});
|
|
15
|
-
};
|
|
16
|
-
this._target.addEventListener('fetch', this._fetch);
|
|
17
|
-
}
|
|
5
|
+
_fetch = this._fetchHandle.bind(this);
|
|
6
|
+
_onconnect;
|
|
18
7
|
destroy() {
|
|
19
|
-
|
|
20
|
-
this._fetch = void 0;
|
|
8
|
+
this._target.removeEventListener('fetch', this._fetch);
|
|
21
9
|
this._onconnect = void 0;
|
|
22
10
|
}
|
|
23
11
|
observe() {}
|
|
@@ -35,6 +23,7 @@ class ServiceWorkerGlobalScopeTransport extends BaseTransport {
|
|
|
35
23
|
});
|
|
36
24
|
}));
|
|
37
25
|
};
|
|
26
|
+
this._target.addEventListener('fetch', this._fetch);
|
|
38
27
|
this._target.addEventListener('message', this._onconnect, this._options.message);
|
|
39
28
|
}
|
|
40
29
|
onremove() {
|
|
@@ -57,6 +46,11 @@ class ServiceWorkerGlobalScopeTransport extends BaseTransport {
|
|
|
57
46
|
transfer
|
|
58
47
|
}));
|
|
59
48
|
}
|
|
49
|
+
_fetchHandle(event) {
|
|
50
|
+
self.clients.get(event.clientId).then((client)=>{
|
|
51
|
+
if (client) this._source = client;
|
|
52
|
+
}).catch(()=>{});
|
|
53
|
+
}
|
|
60
54
|
}
|
|
61
55
|
const transports_ServiceWorkerGlobalScopeTransport = ServiceWorkerGlobalScopeTransport;
|
|
62
56
|
export { transports_ServiceWorkerGlobalScopeTransport as default };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ServiceWorkerRegistrationTransport.d.ts","sourceRoot":"","sources":["../../src/transports/ServiceWorkerRegistrationTransport.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"ServiceWorkerRegistrationTransport.d.ts","sourceRoot":"","sources":["../../src/transports/ServiceWorkerRegistrationTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAE1F,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAI3C,cAAM,kCAAmC,SAAQ,aAAa,CAAC,yBAAyB,CAAC;IACvF,OAAO;IAIP,EAAE,CAAC,MAAM,EAAE,WAAW,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC,EAAE,WAAW;IAOvD,OAAO,IAAI,IAAI;IAEf,SAAS,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAIvC,QAAQ,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAItC,WAAW,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,sBAAsB;CAenE;AAED,eAAe,kCAAkC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SharedWorkerGlobalScopeTransport.d.ts","sourceRoot":"","sources":["../../src/transports/SharedWorkerGlobalScopeTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"SharedWorkerGlobalScopeTransport.d.ts","sourceRoot":"","sources":["../../src/transports/SharedWorkerGlobalScopeTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAE7E,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAG3C,cAAM,gCAAiC,SAAQ,aAAa,CAAC,uBAAuB,CAAC;IACnF,OAAO,CAAC,UAAU,CAA4C;IAC9D,OAAO,CAAC,QAAQ,CAA6C;IAE7D,OAAO;IAOP,OAAO,IAAI,IAAI;IAEf,SAAS,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAevC,QAAQ,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAQtC,WAAW,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,sBAAsB;CAMnE;AAED,eAAe,gCAAgC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SharedWorkerTransport.d.ts","sourceRoot":"","sources":["../../src/transports/SharedWorkerTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"SharedWorkerTransport.d.ts","sourceRoot":"","sources":["../../src/transports/SharedWorkerTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAE7E,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAG3C,cAAM,qBAAsB,SAAQ,aAAa,CAAC,YAAY,CAAC;IAC7D,OAAO;IAIP,OAAO,IAAI,IAAI;IAEf,SAAS,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAKvC,QAAQ,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAItC,WAAW,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,sBAAsB;CAInE;AAED,eAAe,qBAAqB,CAAA"}
|
|
@@ -1,10 +1,7 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ListenerType, MessageItem } from '../fields';
|
|
2
2
|
import BaseTransport from './BaseTransport';
|
|
3
3
|
declare class WebSocketTransport extends BaseTransport<WebSocket> {
|
|
4
|
-
protected _target: WebSocket;
|
|
5
|
-
protected _options: FactoryOptions;
|
|
6
4
|
private _onconnect;
|
|
7
|
-
constructor(_target: WebSocket, _options?: FactoryOptions);
|
|
8
5
|
destroy(): void;
|
|
9
6
|
observe(close?: () => void): void;
|
|
10
7
|
onmessage(listener: ListenerType): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WebSocketTransport.d.ts","sourceRoot":"","sources":["../../src/transports/WebSocketTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"WebSocketTransport.d.ts","sourceRoot":"","sources":["../../src/transports/WebSocketTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAErD,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAS3C,cAAM,kBAAmB,SAAQ,aAAa,CAAC,SAAS,CAAC;IACvD,OAAO,CAAC,UAAU,CAAyB;IAC3C,OAAO;IAOP,OAAO,CAAC,KAAK,CAAC,EAAE,MAAM,IAAI,GAAG,IAAI;IAMjC,SAAS,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAavC,QAAQ,IAAI,IAAI;IAIhB,WAAW,CAAC,OAAO,EAAE,WAAW;CAajC;AAED,eAAe,kBAAkB,CAAA"}
|
|
@@ -1,20 +1,7 @@
|
|
|
1
|
-
import { ProxyPromise } from "../
|
|
1
|
+
import { ProxyPromise } from "../utils.js";
|
|
2
2
|
import BaseTransport from "./BaseTransport.js";
|
|
3
3
|
class WebSocketTransport extends BaseTransport {
|
|
4
|
-
_target;
|
|
5
|
-
_options;
|
|
6
4
|
_onconnect = Promise.resolve(false);
|
|
7
|
-
constructor(_target, _options = {}){
|
|
8
|
-
super(_target, _options), this._target = _target, this._options = _options;
|
|
9
|
-
this._onconnect = new Promise((resolve)=>{
|
|
10
|
-
this._target.onopen = ()=>{
|
|
11
|
-
resolve(true);
|
|
12
|
-
};
|
|
13
|
-
this._target.onclose = ()=>{
|
|
14
|
-
resolve(false);
|
|
15
|
-
};
|
|
16
|
-
});
|
|
17
|
-
}
|
|
18
5
|
destroy() {
|
|
19
6
|
this._target.onclose = null;
|
|
20
7
|
this._target.onopen = null;
|
|
@@ -27,6 +14,14 @@ class WebSocketTransport extends BaseTransport {
|
|
|
27
14
|
}
|
|
28
15
|
onmessage(listener) {
|
|
29
16
|
this._target.onmessage = listener;
|
|
17
|
+
this._onconnect = new Promise((resolve)=>{
|
|
18
|
+
this._target.onopen = ()=>{
|
|
19
|
+
resolve(true);
|
|
20
|
+
};
|
|
21
|
+
this._target.onclose = ()=>{
|
|
22
|
+
resolve(false);
|
|
23
|
+
};
|
|
24
|
+
});
|
|
30
25
|
}
|
|
31
26
|
onremove() {
|
|
32
27
|
this._target.onmessage = null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WindowTransport.d.ts","sourceRoot":"","sources":["../../src/transports/WindowTransport.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"WindowTransport.d.ts","sourceRoot":"","sources":["../../src/transports/WindowTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAE1F,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAM3C,cAAM,eAAgB,SAAQ,aAAa,CAAC,MAAM,CAAC;IACjD,OAAO,CAAC,YAAY,CAA4C;IAChE,OAAO;IAKP,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE;IAKxC,EAAE,CAAC,MAAM,EAAE,WAAW,CAAC,QAAQ,CAAC;IAIhC,SAAS,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAIvC,QAAQ,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAItC,YAAY,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE;IAI9B,WAAW,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,sBAAsB;IAMlE,OAAO,CAAC,KAAK,CAAC,EAAE,MAAM,IAAI;CAkB3B;AAED,eAAe,eAAe,CAAA"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ProxyPromise } from "../
|
|
1
|
+
import { ProxyPromise } from "../utils.js";
|
|
2
2
|
import BaseTransport from "./BaseTransport.js";
|
|
3
3
|
const getOrigin = (url)=>'string' == typeof self?.location?.origin ? new URL(url, self.location.origin).origin : '';
|
|
4
4
|
class WindowTransport extends BaseTransport {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WorkerTransport.d.ts","sourceRoot":"","sources":["../../src/transports/WorkerTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"WorkerTransport.d.ts","sourceRoot":"","sources":["../../src/transports/WorkerTransport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAE7E,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAG3C,cAAM,eAAgB,SAAQ,aAAa,CAAC,MAAM,CAAC;IAEjD,OAAO;IAMP,OAAO,IAAI,IAAI;IAEf,SAAS,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAIvC,QAAQ,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;IAItC,WAAW,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,sBAAsB;CAInE;AAED,eAAe,eAAe,CAAA"}
|
package/dist/utils.d.ts
CHANGED
|
@@ -1,5 +1,11 @@
|
|
|
1
|
+
export declare const getError: (error: unknown, tips?: string) => Error | DOMException;
|
|
1
2
|
export declare const isKey: <T extends Record<string, unknown>>(key: unknown, data: T) => key is keyof T;
|
|
2
3
|
export declare const isPropertyKey: (value: unknown) => value is PropertyKey;
|
|
3
4
|
export declare const objectValues: <T extends object, V = ValueOf<T>>(obj: T) => V[];
|
|
5
|
+
declare function promiseTryPolyfill<T, A extends any[]>(fn: (...args: A) => T | PromiseLike<T>, ...args: A): Promise<T>;
|
|
6
|
+
export declare const ProxyPromise: PromiseConstructor & {
|
|
7
|
+
try: typeof promiseTryPolyfill;
|
|
8
|
+
};
|
|
4
9
|
export type ValueOf<T> = T[keyof T];
|
|
10
|
+
export {};
|
|
5
11
|
//# sourceMappingURL=utils.d.ts.map
|
package/dist/utils.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,KAAK,GAAI,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,KAAK,OAAO,EAAE,MAAM,CAAC,KAAG,GAAG,IAAI,MAAM,CAC3D,CAAA;AAEnC,eAAO,MAAM,aAAa,GAAI,OAAO,OAAO,KAAG,KAAK,IAAI,WACD,CAAA;AAEvD,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,MAAM,EAAE,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,KAA2B,CAAC,EAAE,CAAA;
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,QAAQ,GAAI,OAAO,OAAO,EAAE,aAAuB,yBAU7D,CAAA;AAEH,eAAO,MAAM,KAAK,GAAI,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,KAAK,OAAO,EAAE,MAAM,CAAC,KAAG,GAAG,IAAI,MAAM,CAC3D,CAAA;AAEnC,eAAO,MAAM,aAAa,GAAI,OAAO,OAAO,KAAG,KAAK,IAAI,WACD,CAAA;AAEvD,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,MAAM,EAAE,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,KAA2B,CAAC,EAAE,CAAA;AAInG,iBAAS,kBAAkB,CAAC,CAAC,EAAE,CAAC,SAAS,GAAG,EAAE,EAC5C,EAAE,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,EACtC,GAAG,IAAI,EAAE,CAAC,GACT,OAAO,CAAC,CAAC,CAAC,CAMZ;AAED,eAAO,MAAM,YAAY,EAOnB,kBAAkB,GAAG;IACzB,GAAG,EAAE,OAAO,kBAAkB,CAAA;CAC/B,CAAA;AAED,MAAM,MAAM,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAA"}
|
package/dist/utils.js
CHANGED
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
const getError = (error, tips = 'unknown error.')=>(error instanceof Error || error instanceof DOMException ? error : void 0) ?? ('string' == typeof error ? new Error(error) : void 0) ?? new Error(error instanceof Object && 'message' in error && 'string' == typeof error.message ? error.message : tips, {
|
|
2
|
+
cause: error
|
|
3
|
+
});
|
|
1
4
|
const isKey = (key, data)=>isPropertyKey(key) && key in data;
|
|
2
5
|
const isPropertyKey = (value)=>[
|
|
3
6
|
'number',
|
|
@@ -5,4 +8,17 @@ const isPropertyKey = (value)=>[
|
|
|
5
8
|
'symbol'
|
|
6
9
|
].includes(typeof value);
|
|
7
10
|
const objectValues = (obj)=>Object.values(obj);
|
|
8
|
-
|
|
11
|
+
function promiseTryPolyfill(fn, ...args) {
|
|
12
|
+
try {
|
|
13
|
+
return Promise.resolve(fn(...args));
|
|
14
|
+
} catch (error) {
|
|
15
|
+
return Promise.reject(getError(error));
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
const ProxyPromise = new Proxy(Promise, {
|
|
19
|
+
get (target, propKey) {
|
|
20
|
+
if ('try' === propKey) return 'try' in target ? target.try : promiseTryPolyfill;
|
|
21
|
+
return target[propKey];
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
export { ProxyPromise, getError, isKey, isPropertyKey, objectValues };
|
package/package.json
CHANGED
package/dist/RPCAction.d.ts
DELETED
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
import RPCFactory, { IframeSerializeOptions } from './RPCFactory';
|
|
2
|
-
declare class RPCAction {
|
|
3
|
-
private _target;
|
|
4
|
-
private _brodcastListeners;
|
|
5
|
-
private _handlers;
|
|
6
|
-
private _heartbeatTimer;
|
|
7
|
-
private _isConnected;
|
|
8
|
-
private _lastHeartbeat;
|
|
9
|
-
private _options;
|
|
10
|
-
private _pending;
|
|
11
|
-
private _boundMessageHandler;
|
|
12
|
-
constructor(_target: RPCFactory, options?: RPCOptionsType);
|
|
13
|
-
destroy(): void;
|
|
14
|
-
broadcast<T>(options?: Omit<RequestOptions<T>, 'retry'>): void;
|
|
15
|
-
config(options: Omit<RPCOptionsType, 'onConnect' | 'onDisconnect'>): void;
|
|
16
|
-
on<T extends ActionFunType>(type: PropertyKey, handler: T): void;
|
|
17
|
-
onBrodcast(listener: BrodcastItem): void;
|
|
18
|
-
request<T = unknown>(type: PropertyKey, options?: RequestOptions<T>): Promise<unknown>;
|
|
19
|
-
private _abort;
|
|
20
|
-
private _createRequestId;
|
|
21
|
-
private _isOriginAllowed;
|
|
22
|
-
private _messageHandler;
|
|
23
|
-
private _startHeartbeat;
|
|
24
|
-
}
|
|
25
|
-
export default RPCAction;
|
|
26
|
-
export type RPCOptionsType = {
|
|
27
|
-
allowedOrigins?: string[];
|
|
28
|
-
channel?: string;
|
|
29
|
-
heartbeatInterval?: number;
|
|
30
|
-
heartbeatTimeout?: number;
|
|
31
|
-
retryTimeout?: number;
|
|
32
|
-
retryTimes?: number;
|
|
33
|
-
onConnect?: () => void;
|
|
34
|
-
onDisconnect?: () => void;
|
|
35
|
-
};
|
|
36
|
-
export type ActionFunType = (payload?: any, info?: MessageInfo) => any;
|
|
37
|
-
export type BrodcastItem = (value: unknown, origin?: string) => void;
|
|
38
|
-
export type RequestOptions<T = unknown> = IframeSerializeOptions & {
|
|
39
|
-
payload?: T;
|
|
40
|
-
retry?: number;
|
|
41
|
-
};
|
|
42
|
-
type MessageInfo = Pick<MessageEvent, 'origin' | 'ports' | 'source'>;
|
|
43
|
-
//# sourceMappingURL=RPCAction.d.ts.map
|
package/dist/RPCAction.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"RPCAction.d.ts","sourceRoot":"","sources":["../src/RPCAction.ts"],"names":[],"mappings":"AAAA,OAAO,UAAU,EAAE,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAA;AAejE,cAAM,SAAS;IAWX,OAAO,CAAC,OAAO;IAVjB,OAAO,CAAC,kBAAkB,CAAqB;IAC/C,OAAO,CAAC,SAAS,CAAqB;IACtC,OAAO,CAAC,eAAe,CAAsB;IAC7C,OAAO,CAAC,YAAY,CAAQ;IAC5B,OAAO,CAAC,cAAc,CAAa;IACnC,OAAO,CAAC,QAAQ,CAAqB;IACrC,OAAO,CAAC,QAAQ,CAAiC;IACjD,OAAO,CAAC,oBAAoB,CAAkC;gBAGpD,OAAO,EAAE,UAAU,EAC3B,OAAO,CAAC,EAAE,cAAc;IAc1B,OAAO;IAUP,SAAS,CAAC,CAAC,EAAE,OAAO,CAAC,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC;IASvD,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,cAAc,EAAE,WAAW,GAAG,cAAc,CAAC;IAIlE,EAAE,CAAC,CAAC,SAAS,aAAa,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC;IAIzD,UAAU,CAAC,QAAQ,EAAE,YAAY;IAIjC,OAAO,CAAC,CAAC,GAAG,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,cAAc,CAAC,CAAC,CAAC;IA6CnE,OAAO,CAAC,MAAM;IAWd,OAAO,CAAC,gBAAgB;IAKxB,OAAO,CAAC,gBAAgB;IASxB,OAAO,CAAC,eAAe;IA2EvB,OAAO,CAAC,eAAe;CAsBxB;AAED,eAAe,SAAS,CAAA;AAExB,MAAM,MAAM,cAAc,GAAG;IAC3B,cAAc,CAAC,EAAE,MAAM,EAAE,CAAA;IACzB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,iBAAiB,CAAC,EAAE,MAAM,CAAA;IAC1B,gBAAgB,CAAC,EAAE,MAAM,CAAA;IACzB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,SAAS,CAAC,EAAE,MAAM,IAAI,CAAA;IACtB,YAAY,CAAC,EAAE,MAAM,IAAI,CAAA;CAC1B,CAAA;AAID,MAAM,MAAM,aAAa,GAAG,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,WAAW,KAAK,GAAG,CAAA;AAEtE,MAAM,MAAM,YAAY,GAAG,CAAC,KAAK,EAAE,OAAO,EAAE,MAAM,CAAC,EAAE,MAAM,KAAK,IAAI,CAAA;AAEpE,MAAM,MAAM,cAAc,CAAC,CAAC,GAAG,OAAO,IAAI,sBAAsB,GAAG;IACjE,OAAO,CAAC,EAAE,CAAC,CAAA;IACX,KAAK,CAAC,EAAE,MAAM,CAAA;CACf,CAAA;AAID,KAAK,WAAW,GAAG,IAAI,CAAC,YAAY,EAAE,QAAQ,GAAG,OAAO,GAAG,QAAQ,CAAC,CAAA"}
|
package/dist/RPCAction.js
DELETED
|
@@ -1,196 +0,0 @@
|
|
|
1
|
-
import { isKey } from "./utils.js";
|
|
2
|
-
const RPC_SIGN = 'RPCActionSign';
|
|
3
|
-
const defaultOptions = {
|
|
4
|
-
allowedOrigins: [],
|
|
5
|
-
heartbeatInterval: 3000,
|
|
6
|
-
heartbeatTimeout: 8000,
|
|
7
|
-
retryTimeout: 5000,
|
|
8
|
-
retryTimes: 2
|
|
9
|
-
};
|
|
10
|
-
const getOrigin = (url)=>new URL(url, window.location.origin).origin;
|
|
11
|
-
class RPCAction {
|
|
12
|
-
_target;
|
|
13
|
-
_brodcastListeners = [];
|
|
14
|
-
_handlers = {};
|
|
15
|
-
_heartbeatTimer = null;
|
|
16
|
-
_isConnected = false;
|
|
17
|
-
_lastHeartbeat = Date.now();
|
|
18
|
-
_options = {};
|
|
19
|
-
_pending = new Map();
|
|
20
|
-
_boundMessageHandler = this._messageHandler.bind(this);
|
|
21
|
-
constructor(_target, options){
|
|
22
|
-
this._target = _target;
|
|
23
|
-
this._options = {
|
|
24
|
-
...defaultOptions,
|
|
25
|
-
...options,
|
|
26
|
-
allowedOrigins: options?.allowedOrigins?.map((item)=>'*' === item ? item : getOrigin(item))
|
|
27
|
-
};
|
|
28
|
-
this._target.onmessage(this._boundMessageHandler);
|
|
29
|
-
this._startHeartbeat();
|
|
30
|
-
}
|
|
31
|
-
destroy() {
|
|
32
|
-
clearInterval(this._heartbeatTimer ?? void 0);
|
|
33
|
-
this._target.onremove(this._boundMessageHandler);
|
|
34
|
-
this._abort();
|
|
35
|
-
this._brodcastListeners = [];
|
|
36
|
-
this._handlers = {};
|
|
37
|
-
this._heartbeatTimer = null;
|
|
38
|
-
}
|
|
39
|
-
broadcast(options) {
|
|
40
|
-
const { payload, ...ops } = options ?? {};
|
|
41
|
-
const { channel } = this._options;
|
|
42
|
-
this._target.postMessage({
|
|
43
|
-
__RPC__: RPC_SIGN,
|
|
44
|
-
broadcast: true,
|
|
45
|
-
kind: 'request',
|
|
46
|
-
channel,
|
|
47
|
-
payload
|
|
48
|
-
}, {
|
|
49
|
-
...ops,
|
|
50
|
-
targetOrigin: ops.targetOrigin ?? window.location.origin
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
config(options) {
|
|
54
|
-
this._options = {
|
|
55
|
-
...this._options,
|
|
56
|
-
...options
|
|
57
|
-
};
|
|
58
|
-
}
|
|
59
|
-
on(type, handler) {
|
|
60
|
-
this._handlers[type] = handler;
|
|
61
|
-
}
|
|
62
|
-
onBrodcast(listener) {
|
|
63
|
-
this._brodcastListeners.push(listener);
|
|
64
|
-
}
|
|
65
|
-
request(type, options) {
|
|
66
|
-
const { payload, retry = 0, ...ops } = options ?? {};
|
|
67
|
-
const { channel, retryTimeout = defaultOptions.retryTimeout, retryTimes = defaultOptions.retryTimes } = this._options;
|
|
68
|
-
return new Promise((resolve, reject)=>{
|
|
69
|
-
if (!this._isConnected) return void reject(new Error(`[RPC] 连接未建立,无法请求:${type.toString()}`));
|
|
70
|
-
const requestId = this._createRequestId();
|
|
71
|
-
const timer = window.setTimeout(()=>{
|
|
72
|
-
this._pending.delete(requestId);
|
|
73
|
-
if (retry < retryTimes) resolve(this.request(type, {
|
|
74
|
-
...options,
|
|
75
|
-
retry: retry + 1
|
|
76
|
-
}));
|
|
77
|
-
else reject(new Error(`[RPC] 请求超时:${type.toString()}`));
|
|
78
|
-
}, retryTimeout);
|
|
79
|
-
this._pending.set(requestId, {
|
|
80
|
-
resolve: (res)=>{
|
|
81
|
-
clearTimeout(timer);
|
|
82
|
-
resolve(res);
|
|
83
|
-
},
|
|
84
|
-
reject: (err)=>{
|
|
85
|
-
const message = err instanceof Error ? err.message : '[RPC] 处理消息时发生错误';
|
|
86
|
-
clearTimeout(timer);
|
|
87
|
-
reject(new Error(message));
|
|
88
|
-
},
|
|
89
|
-
timer
|
|
90
|
-
});
|
|
91
|
-
this._target.postMessage({
|
|
92
|
-
__RPC__: RPC_SIGN,
|
|
93
|
-
kind: 'request',
|
|
94
|
-
channel,
|
|
95
|
-
payload,
|
|
96
|
-
requestId,
|
|
97
|
-
type
|
|
98
|
-
}, {
|
|
99
|
-
...ops,
|
|
100
|
-
targetOrigin: ops.targetOrigin ?? window.location.origin
|
|
101
|
-
});
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
_abort() {
|
|
105
|
-
this._isConnected = false;
|
|
106
|
-
this._options?.onDisconnect?.();
|
|
107
|
-
this._pending.forEach(({ reject, timer })=>{
|
|
108
|
-
clearTimeout(timer);
|
|
109
|
-
reject(new Error('[RPC] 连接已断开,请求已取消'));
|
|
110
|
-
});
|
|
111
|
-
this._pending.clear();
|
|
112
|
-
}
|
|
113
|
-
_createRequestId() {
|
|
114
|
-
const requestId = Math.random().toString(36).slice(2, 10);
|
|
115
|
-
return this._pending.has(requestId) ? this._createRequestId() : requestId;
|
|
116
|
-
}
|
|
117
|
-
_isOriginAllowed(origin) {
|
|
118
|
-
return this._options?.allowedOrigins?.some((item)=>'*' === item || getOrigin(item) === getOrigin(origin)) ?? false;
|
|
119
|
-
}
|
|
120
|
-
_messageHandler(event) {
|
|
121
|
-
const { data, origin, source } = event;
|
|
122
|
-
const { __RPC__, broadcast, channel, error, heartbeat, kind, payload, requestId, type } = data ?? {};
|
|
123
|
-
if (__RPC__ !== RPC_SIGN) return;
|
|
124
|
-
if (this._options?.channel !== channel) return;
|
|
125
|
-
if (!this._target.is(source)) return;
|
|
126
|
-
if (this._target.getType() === window.toString() && !this._isOriginAllowed(origin)) return;
|
|
127
|
-
if (heartbeat) {
|
|
128
|
-
this._lastHeartbeat = Date.now();
|
|
129
|
-
if (!this._isConnected) {
|
|
130
|
-
this._isConnected = true;
|
|
131
|
-
this._options?.onConnect?.();
|
|
132
|
-
}
|
|
133
|
-
return;
|
|
134
|
-
}
|
|
135
|
-
if (broadcast) return void this._brodcastListeners.forEach((listener)=>listener(payload, origin));
|
|
136
|
-
const pending = requestId ? this._pending.get(requestId) : void 0;
|
|
137
|
-
if (requestId && pending) {
|
|
138
|
-
const { resolve, reject } = pending;
|
|
139
|
-
this._pending.delete(requestId);
|
|
140
|
-
if (void 0 !== error) reject(new Error(error));
|
|
141
|
-
else resolve(payload);
|
|
142
|
-
return;
|
|
143
|
-
}
|
|
144
|
-
if ('request' !== kind) return;
|
|
145
|
-
const handler = type && isKey(type, this._handlers) ? this._handlers[type] : void 0;
|
|
146
|
-
if (handler) Promise.resolve().then(()=>{
|
|
147
|
-
const result = handler(payload, {
|
|
148
|
-
origin,
|
|
149
|
-
ports: [],
|
|
150
|
-
source
|
|
151
|
-
});
|
|
152
|
-
return result;
|
|
153
|
-
}).then((result)=>{
|
|
154
|
-
this._target.postMessage({
|
|
155
|
-
__RPC__: RPC_SIGN,
|
|
156
|
-
kind: 'response',
|
|
157
|
-
payload: result,
|
|
158
|
-
channel,
|
|
159
|
-
requestId,
|
|
160
|
-
type
|
|
161
|
-
}, {
|
|
162
|
-
targetOrigin: origin
|
|
163
|
-
});
|
|
164
|
-
}).catch((err)=>{
|
|
165
|
-
const message = err instanceof Error ? err.message : '[RPC] 处理消息时发生错误';
|
|
166
|
-
this._target.postMessage({
|
|
167
|
-
__RPC__: RPC_SIGN,
|
|
168
|
-
error: message,
|
|
169
|
-
kind: 'response',
|
|
170
|
-
payload: '',
|
|
171
|
-
channel,
|
|
172
|
-
requestId
|
|
173
|
-
}, {
|
|
174
|
-
targetOrigin: origin
|
|
175
|
-
});
|
|
176
|
-
});
|
|
177
|
-
}
|
|
178
|
-
_startHeartbeat() {
|
|
179
|
-
const { channel, heartbeatInterval = defaultOptions.heartbeatInterval, heartbeatTimeout = defaultOptions.heartbeatTimeout } = this._options;
|
|
180
|
-
const intervalLoops = ()=>{
|
|
181
|
-
this._target.postMessage({
|
|
182
|
-
__RPC__: RPC_SIGN,
|
|
183
|
-
heartbeat: true,
|
|
184
|
-
kind: 'request',
|
|
185
|
-
channel
|
|
186
|
-
});
|
|
187
|
-
if (!this._isConnected) return;
|
|
188
|
-
if (Date.now() - this._lastHeartbeat > heartbeatTimeout) this._abort();
|
|
189
|
-
};
|
|
190
|
-
intervalLoops();
|
|
191
|
-
clearInterval(this._heartbeatTimer ?? void 0);
|
|
192
|
-
this._heartbeatTimer = window.setInterval(intervalLoops, heartbeatInterval);
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
const src_RPCAction = RPCAction;
|
|
196
|
-
export { src_RPCAction as default };
|
package/dist/RPCDecorator.d.ts
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import RPCAction, { ActionFunType, BrodcastItem, RPCOptionsType, RequestOptions } from './RPCAction';
|
|
2
|
-
import RPCFactory, { FactoryOptions, TargetType } from './RPCFactory';
|
|
3
|
-
declare const factoryKey: readonly ["getType", "upset"];
|
|
4
|
-
declare function RPCDecorator<EVENT extends ActionRecord, CONSUME extends ActionRecord>(target: TargetType | null, context?: DecoratorContext<EVENT, CONSUME>): Readonly<Omit<RPCAction, "on" | "request"> & Pick<RPCFactory, (typeof factoryKey)[number]> & {
|
|
5
|
-
request: <K extends keyof CONSUME>(...args: Parameters<CONSUME[K]> extends [] ? [keyname: K, reqops?: RequestOptionsByAction<CONSUME[K]>] : [keyname: K, reqops: RequestOptionsByAction<CONSUME[K]>]) => Promise<ReturnType<CONSUME[K]>>;
|
|
6
|
-
}>;
|
|
7
|
-
export default RPCDecorator;
|
|
8
|
-
export interface DecoratorContext<EVENT extends ActionRecord, CONSUME extends ActionRecord> {
|
|
9
|
-
brodcast?: Record<string, BrodcastItem>;
|
|
10
|
-
config?: RPCOptionsType;
|
|
11
|
-
consume?: CONSUME;
|
|
12
|
-
event?: EVENT;
|
|
13
|
-
options?: FactoryOptions;
|
|
14
|
-
}
|
|
15
|
-
export type ActionRecord = Record<string, ActionFunType>;
|
|
16
|
-
type RequestOptionsByAction<F extends ActionFunType> = Parameters<F> extends [] ? Omit<RequestOptions, 'payload'> & {
|
|
17
|
-
payload?: never;
|
|
18
|
-
} : RequestOptions<Parameters<F>[0]> & {
|
|
19
|
-
payload: Parameters<F>[0];
|
|
20
|
-
};
|
|
21
|
-
//# sourceMappingURL=RPCDecorator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"RPCDecorator.d.ts","sourceRoot":"","sources":["../src/RPCDecorator.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,EAAE,EAAE,aAAa,EAAE,YAAY,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,aAAa,CAAA;AACpG,OAAO,UAAU,EAAE,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,cAAc,CAAA;AAErE,QAAA,MAAM,UAAU,+BAAgC,CAAA;AAUhD,iBAAS,YAAY,CAAC,KAAK,SAAS,YAAY,EAAE,OAAO,SAAS,YAAY,EAC5E,MAAM,EAAE,UAAU,GAAG,IAAI,EACzB,OAAO,CAAC,EAAE,gBAAgB,CAAC,KAAK,EAAE,OAAO,CAAC,GAwDrC,QAAQ,CACX,IAAI,CAAC,SAAS,EAAE,IAAI,GAAG,SAAS,CAAC,GAC/B,IAAI,CAAC,UAAU,EAAE,CAAC,OAAO,UAAU,EAAE,MAAM,CAAC,CAAC,GAAG;IAC9C,OAAO,GArDI,CAAC,SAAS,MAAM,OAAO,WAC7B,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,GACtC,CAAC,OAAO,EAAE,CAAC,EAAE,MAAM,CAAC,EAAE,sBAAsB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,GACzD,CAAC,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,sBAAsB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,KAGjB,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CA+C/C;CACxB,CACJ,CACF;AAED,eAAe,YAAY,CAAA;AAE3B,MAAM,WAAW,gBAAgB,CAAC,KAAK,SAAS,YAAY,EAAE,OAAO,SAAS,YAAY;IACxF,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,YAAY,CAAC,CAAA;IACvC,MAAM,CAAC,EAAE,cAAc,CAAA;IACvB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,KAAK,CAAC,EAAE,KAAK,CAAA;IACb,OAAO,CAAC,EAAE,cAAc,CAAA;CACzB;AAED,MAAM,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;AAExD,KAAK,sBAAsB,CAAC,CAAC,SAAS,aAAa,IACjD,UAAU,CAAC,CAAC,CAAC,SAAS,EAAE,GACpB,IAAI,CAAC,cAAc,EAAE,SAAS,CAAC,GAAG;IAAE,OAAO,CAAC,EAAE,KAAK,CAAA;CAAE,GACrD,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG;IAAE,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;CAAE,CAAA"}
|