@streamlayer/sdk-web-api 0.24.1 → 0.24.2

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.
@@ -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) => boolean;
44
+ addListener: (name: string, listener: (response: Response) => void) => (() => void);
45
45
  removeListener: (name: string) => void;
46
46
  connect: () => void;
47
47
  disconnect: () => void;
@@ -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 false;
72
+ return () => { };
73
73
  }
74
74
  this.listeners.set(name, listener);
75
75
  this.addStateLog(`listener '${name}' added`);
76
- return true;
76
+ return () => this.removeListener(name);
77
77
  };
78
78
  removeListener = (name) => {
79
79
  this.listeners.delete(name);
@@ -43,14 +43,19 @@ export declare class Transport {
43
43
  };
44
44
  readonly transport: ReturnType<typeof createGrpcWebTransport>;
45
45
  readonly streamTransport: ReturnType<typeof createGrpcWebTransport>;
46
- readonly nanoquery: NanoqueryObjectType;
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
- constructor(host: string);
53
+ private opts?;
54
+ constructor(host: string, opts?: {
55
+ dedupeTime?: number;
56
+ refetchInterval?: number;
57
+ retryable?: boolean;
58
+ });
54
59
  addSubscription: <T extends ServiceType, Req extends Message<Req>, Res extends Message<Res>>(method: { [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; }], params: PlainMessage<Req> | Atom<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;
@@ -45,8 +45,10 @@ export class Transport {
45
45
  clients;
46
46
  streamClients;
47
47
  subscriptions;
48
- constructor(host) {
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: 1000 * 60 * 5,
60
- refetchInterval: 1000 * 60 * 5,
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
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
107
- // @ts-ignore
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.interceptors.push(retry);
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.1",
3
+ "version": "0.24.2",
4
4
  "type": "module",
5
5
  "main": "./lib/index.js",
6
6
  "typings": "./lib/index.d.ts",