@streamlayer/sdk-web-api 0.24.1 → 0.24.3
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/lib/grpc/subscription.d.ts +1 -1
- package/lib/grpc/subscription.js +2 -2
- package/lib/grpc/transport.d.ts +9 -4
- package/lib/grpc/transport.js +12 -7
- package/lib/index.js +5 -1
- package/package.json +8 -8
|
@@ -41,7 +41,7 @@ export declare class ServerStreamSubscription<T extends ServiceType, Request ext
|
|
|
41
41
|
constructor(headers: Transport['$headers'], method: Method, params: Atom<PlainMessage<Request>> | PlainMessage<Request>, options: ServerStreamSubscriptionOptions);
|
|
42
42
|
updateState: (status: ServerStreamSubscriptionStatus) => void;
|
|
43
43
|
addStateLog: (msg: string) => void;
|
|
44
|
-
addListener: (name: string, listener: (response: Response) => void) =>
|
|
44
|
+
addListener: (name: string, listener: (response: Response) => void) => (() => void);
|
|
45
45
|
removeListener: (name: string) => void;
|
|
46
46
|
connect: () => void;
|
|
47
47
|
disconnect: () => void;
|
package/lib/grpc/subscription.js
CHANGED
|
@@ -69,11 +69,11 @@ export class ServerStreamSubscription {
|
|
|
69
69
|
addListener = (name, listener) => {
|
|
70
70
|
if (this.listeners.has(name)) {
|
|
71
71
|
this.addStateLog(`listener '${name}' not added, already exists`);
|
|
72
|
-
return
|
|
72
|
+
return () => { };
|
|
73
73
|
}
|
|
74
74
|
this.listeners.set(name, listener);
|
|
75
75
|
this.addStateLog(`listener '${name}' added`);
|
|
76
|
-
return
|
|
76
|
+
return () => this.removeListener(name);
|
|
77
77
|
};
|
|
78
78
|
removeListener = (name) => {
|
|
79
79
|
this.listeners.delete(name);
|
package/lib/grpc/transport.d.ts
CHANGED
|
@@ -43,15 +43,20 @@ export declare class Transport {
|
|
|
43
43
|
};
|
|
44
44
|
readonly transport: ReturnType<typeof createGrpcWebTransport>;
|
|
45
45
|
readonly streamTransport: ReturnType<typeof createGrpcWebTransport>;
|
|
46
|
-
|
|
46
|
+
nanoquery: NanoqueryObjectType;
|
|
47
47
|
readonly host: string;
|
|
48
48
|
readonly $headers: MapStore<KnownHeaders>;
|
|
49
49
|
protected interceptors: Interceptor[];
|
|
50
50
|
private clients;
|
|
51
51
|
private streamClients;
|
|
52
52
|
private subscriptions;
|
|
53
|
-
|
|
54
|
-
|
|
53
|
+
private opts?;
|
|
54
|
+
constructor(host: string, opts?: {
|
|
55
|
+
dedupeTime?: number;
|
|
56
|
+
refetchInterval?: number;
|
|
57
|
+
retryable?: boolean;
|
|
58
|
+
});
|
|
59
|
+
addSubscription: <T extends ServiceType, Req extends Message<Req>, Res extends Message<Res>>(method: ServerStreamSubscription<T, Req, Res>['method'], params: Atom<PlainMessage<Req>> | PlainMessage<Req>, options: ServerStreamSubscriptionOptions) => ServerStreamSubscription<ServiceType, Message<import("@bufbuild/protobuf").AnyMessage>, Message<import("@bufbuild/protobuf").AnyMessage>, never, never> | ServerStreamSubscription<T, Req, Res, keyof { [P in keyof PromiseClient<T> as T["methods"][P] extends import("@bufbuild/protobuf").MethodInfoServerStreaming<any, any> ? P : never]: T["methods"][P] extends import("@bufbuild/protobuf").MethodInfoServerStreaming<any, any> ? PromiseClient<T>[P] : never; }, { [P in keyof PromiseClient<T> as T["methods"][P] extends import("@bufbuild/protobuf").MethodInfoServerStreaming<any, any> ? P : never]: T["methods"][P] extends import("@bufbuild/protobuf").MethodInfoServerStreaming<any, any> ? PromiseClient<T>[P] : never; }[keyof { [P in keyof PromiseClient<T> as T["methods"][P] extends import("@bufbuild/protobuf").MethodInfoServerStreaming<any, any> ? P : never]: T["methods"][P] extends import("@bufbuild/protobuf").MethodInfoServerStreaming<any, any> ? PromiseClient<T>[P] : never; }]>;
|
|
55
60
|
removeSubscription: (subscription: ServerStreamSubscription<ServiceType, Message, Message>) => void;
|
|
56
61
|
disconnect: () => void;
|
|
57
62
|
registerInterceptor: (interceptor: Interceptor) => void;
|
|
@@ -60,7 +65,7 @@ export declare class Transport {
|
|
|
60
65
|
getStreamClient: <T extends ServiceType>(service: T) => PromiseClient<T>;
|
|
61
66
|
createPromiseClient: <T extends ServiceType>(service: T, { params, method }: {
|
|
62
67
|
params?: KeyInput | undefined;
|
|
63
|
-
method: keyof T[
|
|
68
|
+
method: keyof T['methods'];
|
|
64
69
|
}) => {
|
|
65
70
|
client: PromiseClient<T>;
|
|
66
71
|
createRequestOptions: (options: RequestOptions) => import("@connectrpc/connect").ContextValues;
|
package/lib/grpc/transport.js
CHANGED
|
@@ -45,8 +45,10 @@ export class Transport {
|
|
|
45
45
|
clients;
|
|
46
46
|
streamClients;
|
|
47
47
|
subscriptions;
|
|
48
|
-
|
|
48
|
+
opts;
|
|
49
|
+
constructor(host, opts) {
|
|
49
50
|
this.host = host;
|
|
51
|
+
this.opts = opts;
|
|
50
52
|
this.$headers = new MapStore(createMapStore({
|
|
51
53
|
['sl-device-id']: getDeviceId(),
|
|
52
54
|
['sl-device-os']: getDeviceOs(),
|
|
@@ -56,8 +58,8 @@ export class Transport {
|
|
|
56
58
|
this.streamClients = new Map();
|
|
57
59
|
this.subscriptions = new Map();
|
|
58
60
|
const [createFetcherStore, createMutatorStore, utils] = nanoquery({
|
|
59
|
-
dedupeTime:
|
|
60
|
-
refetchInterval:
|
|
61
|
+
dedupeTime: opts?.dedupeTime,
|
|
62
|
+
refetchInterval: opts?.refetchInterval,
|
|
61
63
|
});
|
|
62
64
|
this.nanoquery = { createFetcherStore, createMutatorStore, utils };
|
|
63
65
|
this.transport = createGrpcWebTransport({
|
|
@@ -102,9 +104,10 @@ export class Transport {
|
|
|
102
104
|
this.subscriptions.clear();
|
|
103
105
|
// ToDo: reset nanoquery instance, basically we should add connect
|
|
104
106
|
// method where setup nanoquery, transports and interceptors, not in constructor
|
|
105
|
-
const [createFetcherStore, createMutatorStore, utils] = nanoquery(
|
|
106
|
-
|
|
107
|
-
|
|
107
|
+
const [createFetcherStore, createMutatorStore, utils] = nanoquery({
|
|
108
|
+
dedupeTime: 1000 * 60 * 5,
|
|
109
|
+
refetchInterval: 1000 * 60 * 5,
|
|
110
|
+
});
|
|
108
111
|
this.nanoquery = { createFetcherStore, createMutatorStore, utils };
|
|
109
112
|
};
|
|
110
113
|
registerInterceptor = (interceptor) => {
|
|
@@ -181,7 +184,9 @@ export class Transport {
|
|
|
181
184
|
if (process.env.NODE_ENV !== 'test') {
|
|
182
185
|
this.interceptors.push(__GRPC_DEVTOOLS_EXTENSION__());
|
|
183
186
|
}
|
|
184
|
-
this.
|
|
187
|
+
if (this.opts?.retryable) {
|
|
188
|
+
this.interceptors.push(retry);
|
|
189
|
+
}
|
|
185
190
|
// if (window.__GRPC_DEVTOOLS_EXTENSION__) {
|
|
186
191
|
// this.interceptors.push(window.__GRPC_DEVTOOLS_EXTENSION__())
|
|
187
192
|
// } else {
|
package/lib/index.js
CHANGED
|
@@ -2,7 +2,11 @@ export { Transport } from './grpc/transport';
|
|
|
2
2
|
import { Transport } from './grpc/transport';
|
|
3
3
|
export * as queries from './grpc/queries';
|
|
4
4
|
export const transport = (instance, opts, done) => {
|
|
5
|
-
instance.transport = new Transport(opts.host
|
|
5
|
+
instance.transport = new Transport(opts.host, {
|
|
6
|
+
dedupeTime: 1000 * 60 * 5,
|
|
7
|
+
refetchInterval: 1000 * 60 * 5,
|
|
8
|
+
retryable: true,
|
|
9
|
+
});
|
|
6
10
|
instance.analyticsTransport = new Transport(opts.analyticsHost);
|
|
7
11
|
instance.sdk.host = instance.transport.host;
|
|
8
12
|
instance.transport.setSdkKey(opts.sdkKey);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@streamlayer/sdk-web-api",
|
|
3
|
-
"version": "0.24.
|
|
3
|
+
"version": "0.24.3",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "./lib/index.js",
|
|
6
6
|
"typings": "./lib/index.d.ts",
|
|
@@ -21,16 +21,16 @@
|
|
|
21
21
|
}
|
|
22
22
|
},
|
|
23
23
|
"dependencies": {
|
|
24
|
-
"@streamlayer/sdk-web-interfaces": "^0.21.
|
|
25
|
-
"@streamlayer/sdk-web-logger": "^0.5.
|
|
24
|
+
"@streamlayer/sdk-web-interfaces": "^0.21.1",
|
|
25
|
+
"@streamlayer/sdk-web-logger": "^0.5.19"
|
|
26
26
|
},
|
|
27
27
|
"devDependencies": {
|
|
28
|
-
"@bufbuild/protobuf": "^1.
|
|
29
|
-
"@connectrpc/connect": "^1.
|
|
30
|
-
"@connectrpc/connect-web": "^1.
|
|
28
|
+
"@bufbuild/protobuf": "^1.8.0",
|
|
29
|
+
"@connectrpc/connect": "^1.4.0",
|
|
30
|
+
"@connectrpc/connect-web": "^1.4.0",
|
|
31
31
|
"@nanostores/query": "^0.2.10",
|
|
32
|
-
"@streamlayer/sl-eslib": "^5.
|
|
33
|
-
"@swc/helpers": "~0.5.
|
|
32
|
+
"@streamlayer/sl-eslib": "^5.84.0",
|
|
33
|
+
"@swc/helpers": "~0.5.6",
|
|
34
34
|
"nanoid": "3.3.7",
|
|
35
35
|
"nanostores": "^0.10.0",
|
|
36
36
|
"tslib": "^2.6.2"
|