@nxtedition/deepstream.io-client-js 32.0.9 → 32.0.11

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nxtedition/deepstream.io-client-js",
3
- "version": "32.0.9",
3
+ "version": "32.0.11",
4
4
  "description": "the javascript client for deepstream.io",
5
5
  "homepage": "http://deepstream.io",
6
6
  "type": "module",
@@ -109,6 +109,7 @@ expectAssignable<string>(await ds.record.get('p', 'p1', { signal: new AbortContr
109
109
  expectAssignable<string>(await ds.record.get('p', { path: 'p1' }))
110
110
  expectAssignable<string | undefined>(await ds.record.get('p', 'p2'))
111
111
  expectAssignable<unknown>(await ds.record.get('p', 'x1'))
112
+ expectAssignable<string | undefined>(await ds.record.get('possiblyEmpty', 'pe1'))
112
113
 
113
114
  // observe with options
114
115
  expectAssignable<Observable<{ p1: string; p2?: string; p3: { p4: string } }>>(
@@ -1,6 +1,15 @@
1
1
  import type RecordHandler from './record-handler.js'
2
- import type { Get } from 'type-fest'
3
- export type { Get, Paths } from 'type-fest'
2
+ import type { Get as _Get, AllUnionFields } from 'type-fest'
3
+ export type { Paths } from 'type-fest'
4
+
5
+ // HACK: Wrap type-fest's Get to get rid of EmptyObject from union
6
+ type RemoveSymbolKeys<T> = {
7
+ [K in keyof T as K extends symbol ? never : K]: T[K]
8
+ }
9
+ export type Get<BaseType, Path extends string | readonly string[]> = _Get<
10
+ RemoveSymbolKeys<AllUnionFields<BaseType>>,
11
+ Path
12
+ >
4
13
 
5
14
  export interface WhenOptions {
6
15
  signal?: AbortSignal
@@ -25,7 +25,7 @@ export default class RpcHandler<
25
25
  ReturnValue extends Name extends keyof Methods ? Methods[Name][1] : unknown,
26
26
  >(
27
27
  name: Name,
28
- args: Args,
28
+ args?: Args,
29
29
  ): Promise<ReturnValue>
30
30
  <
31
31
  Name extends keyof Methods | string,
@@ -33,7 +33,7 @@ export default class RpcHandler<
33
33
  ReturnValue extends Name extends keyof Methods ? Methods[Name][1] : unknown,
34
34
  >(
35
35
  name: Name,
36
- args: Args,
36
+ args: Args | undefined,
37
37
  callback: (error: unknown, response: ReturnValue) => void,
38
38
  ): void
39
39
  }
@@ -11,6 +11,10 @@ const ds = make<Record<string, unknown>, Methods>('')
11
11
  ds.rpc.provide('greet', (_args, _response) => {})
12
12
  ds.rpc.provide('greet', (_args, _response) => ({ message: 'hello' }))
13
13
  ds.rpc.provide('greet', async (_args, _response) => ({ message: 'hello' }))
14
+ // async callback that uses response.send() directly — returns Promise<void>
15
+ ds.rpc.provide('greet', async (_args, response) => {
16
+ response.send({ message: 'hello' })
17
+ })
14
18
 
15
19
  // provide: returning the wrong shape is an error
16
20
  expectError(ds.rpc.provide('greet', (_args, _response) => ({ notMessage: 'hello' })))
@@ -22,3 +26,15 @@ ds.rpc.provide('greet', (_args, response) => {
22
26
 
23
27
  // provide: return type is UnprovideFn | void
24
28
  expectAssignable<(() => void) | void>(ds.rpc.provide('greet', () => {}))
29
+
30
+ // make: args is optional (no args)
31
+ expectAssignable<Promise<{ message: string }>>(ds.rpc.make('greet'))
32
+ // make: args provided
33
+ expectAssignable<Promise<{ message: string }>>(ds.rpc.make('greet', { name: 'world' }))
34
+ // make: args explicitly undefined
35
+ expectAssignable<Promise<{ message: string }>>(ds.rpc.make('greet', undefined))
36
+ // make: callback form — args required positionally but can be undefined
37
+ ds.rpc.make('greet', undefined, (err, res) => {
38
+ expectType<unknown>(err)
39
+ expectAssignable<{ message: string } | undefined>(res)
40
+ })