@replit/river 0.9.3 → 0.10.1

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.
Files changed (129) hide show
  1. package/dist/{router/builder.d.ts → builder-3c4485f0.d.ts} +82 -28
  2. package/dist/chunk-7WJ6YLE5.js +683 -0
  3. package/dist/chunk-AJQU4AZG.js +284 -0
  4. package/dist/chunk-ORAG7IAU.js +0 -0
  5. package/dist/chunk-PC65ZFWJ.js +29 -0
  6. package/dist/chunk-R6H2BIMC.js +49 -0
  7. package/dist/chunk-RGMHF6PF.js +65 -0
  8. package/dist/chunk-SLUSVGQH.js +30 -0
  9. package/dist/chunk-UU2Z7LDR.js +113 -0
  10. package/dist/chunk-WVT5QXMZ.js +20 -0
  11. package/dist/chunk-ZE4MX7DF.js +75 -0
  12. package/dist/codec/index.cjs +94 -0
  13. package/dist/codec/index.d.cts +15 -0
  14. package/dist/codec/index.d.ts +15 -4
  15. package/dist/codec/index.js +10 -2
  16. package/dist/connection-8e19874c.d.ts +11 -0
  17. package/dist/connection-f7688cc1.d.ts +11 -0
  18. package/dist/logging/index.cjs +56 -0
  19. package/dist/logging/index.d.cts +28 -0
  20. package/dist/logging/index.d.ts +6 -6
  21. package/dist/logging/index.js +9 -40
  22. package/dist/router/index.cjs +770 -0
  23. package/dist/router/index.d.cts +114 -0
  24. package/dist/router/index.d.ts +114 -10
  25. package/dist/router/index.js +24 -4
  26. package/dist/transport/impls/ws/client.cjs +505 -0
  27. package/dist/transport/impls/ws/client.d.cts +42 -0
  28. package/dist/transport/impls/ws/client.d.ts +9 -12
  29. package/dist/transport/impls/ws/client.js +10 -101
  30. package/dist/transport/impls/ws/server.cjs +457 -0
  31. package/dist/transport/impls/ws/server.d.cts +21 -0
  32. package/dist/transport/impls/ws/server.d.ts +14 -10
  33. package/dist/transport/impls/ws/server.js +11 -47
  34. package/dist/transport/index.cjs +362 -0
  35. package/dist/transport/{transport.d.ts → index.d.cts} +119 -7
  36. package/dist/transport/index.d.ts +273 -13
  37. package/dist/transport/index.js +20 -23
  38. package/dist/{codec/types.d.ts → types-3e5768ec.d.ts} +3 -2
  39. package/dist/util/testHelpers.cjs +731 -0
  40. package/dist/util/testHelpers.d.cts +79 -0
  41. package/dist/util/testHelpers.d.ts +34 -108
  42. package/dist/util/testHelpers.js +137 -320
  43. package/package.json +52 -23
  44. package/dist/__tests__/bandwidth.bench.d.ts +0 -2
  45. package/dist/__tests__/bandwidth.bench.d.ts.map +0 -1
  46. package/dist/__tests__/bandwidth.bench.js +0 -90
  47. package/dist/__tests__/e2e.test.d.ts +0 -2
  48. package/dist/__tests__/e2e.test.d.ts.map +0 -1
  49. package/dist/__tests__/e2e.test.js +0 -316
  50. package/dist/__tests__/fixtures/cleanup.d.ts +0 -12
  51. package/dist/__tests__/fixtures/cleanup.d.ts.map +0 -1
  52. package/dist/__tests__/fixtures/cleanup.js +0 -39
  53. package/dist/__tests__/fixtures/largePayload.json +0 -33
  54. package/dist/__tests__/fixtures/observable.d.ts +0 -26
  55. package/dist/__tests__/fixtures/observable.d.ts.map +0 -1
  56. package/dist/__tests__/fixtures/observable.js +0 -38
  57. package/dist/__tests__/fixtures/observable.test.d.ts +0 -2
  58. package/dist/__tests__/fixtures/observable.test.d.ts.map +0 -1
  59. package/dist/__tests__/fixtures/observable.test.js +0 -39
  60. package/dist/__tests__/fixtures/services.d.ts +0 -288
  61. package/dist/__tests__/fixtures/services.d.ts.map +0 -1
  62. package/dist/__tests__/fixtures/services.js +0 -224
  63. package/dist/__tests__/handler.test.d.ts +0 -2
  64. package/dist/__tests__/handler.test.d.ts.map +0 -1
  65. package/dist/__tests__/handler.test.js +0 -121
  66. package/dist/__tests__/invariants.test.d.ts +0 -2
  67. package/dist/__tests__/invariants.test.d.ts.map +0 -1
  68. package/dist/__tests__/invariants.test.js +0 -138
  69. package/dist/__tests__/serialize.test.d.ts +0 -2
  70. package/dist/__tests__/serialize.test.d.ts.map +0 -1
  71. package/dist/__tests__/serialize.test.js +0 -208
  72. package/dist/__tests__/typescript-stress.test.d.ts +0 -1583
  73. package/dist/__tests__/typescript-stress.test.d.ts.map +0 -1
  74. package/dist/__tests__/typescript-stress.test.js +0 -123
  75. package/dist/codec/binary.d.ts +0 -7
  76. package/dist/codec/binary.d.ts.map +0 -1
  77. package/dist/codec/binary.js +0 -20
  78. package/dist/codec/codec.test.d.ts +0 -5
  79. package/dist/codec/codec.test.d.ts.map +0 -1
  80. package/dist/codec/codec.test.js +0 -41
  81. package/dist/codec/index.d.ts.map +0 -1
  82. package/dist/codec/json.d.ts +0 -7
  83. package/dist/codec/json.d.ts.map +0 -1
  84. package/dist/codec/json.js +0 -51
  85. package/dist/codec/types.d.ts.map +0 -1
  86. package/dist/codec/types.js +0 -1
  87. package/dist/logging/index.d.ts.map +0 -1
  88. package/dist/router/builder.d.ts.map +0 -1
  89. package/dist/router/builder.js +0 -91
  90. package/dist/router/client.d.ts +0 -68
  91. package/dist/router/client.d.ts.map +0 -1
  92. package/dist/router/client.js +0 -159
  93. package/dist/router/context.d.ts +0 -30
  94. package/dist/router/context.d.ts.map +0 -1
  95. package/dist/router/context.js +0 -1
  96. package/dist/router/index.d.ts.map +0 -1
  97. package/dist/router/result.d.ts +0 -25
  98. package/dist/router/result.d.ts.map +0 -1
  99. package/dist/router/result.js +0 -18
  100. package/dist/router/server.d.ts +0 -39
  101. package/dist/router/server.d.ts.map +0 -1
  102. package/dist/router/server.js +0 -217
  103. package/dist/transport/events.d.ts +0 -19
  104. package/dist/transport/events.d.ts.map +0 -1
  105. package/dist/transport/events.js +0 -26
  106. package/dist/transport/impls/stdio/stdio.d.ts +0 -33
  107. package/dist/transport/impls/stdio/stdio.d.ts.map +0 -1
  108. package/dist/transport/impls/stdio/stdio.js +0 -75
  109. package/dist/transport/impls/stdio/stdio.test.d.ts +0 -2
  110. package/dist/transport/impls/stdio/stdio.test.d.ts.map +0 -1
  111. package/dist/transport/impls/stdio/stdio.test.js +0 -25
  112. package/dist/transport/impls/ws/client.d.ts.map +0 -1
  113. package/dist/transport/impls/ws/connection.d.ts +0 -11
  114. package/dist/transport/impls/ws/connection.d.ts.map +0 -1
  115. package/dist/transport/impls/ws/connection.js +0 -23
  116. package/dist/transport/impls/ws/server.d.ts.map +0 -1
  117. package/dist/transport/impls/ws/ws.test.d.ts +0 -2
  118. package/dist/transport/impls/ws/ws.test.d.ts.map +0 -1
  119. package/dist/transport/impls/ws/ws.test.js +0 -117
  120. package/dist/transport/index.d.ts.map +0 -1
  121. package/dist/transport/message.d.ts +0 -143
  122. package/dist/transport/message.d.ts.map +0 -1
  123. package/dist/transport/message.js +0 -113
  124. package/dist/transport/message.test.d.ts +0 -2
  125. package/dist/transport/message.test.d.ts.map +0 -1
  126. package/dist/transport/message.test.js +0 -52
  127. package/dist/transport/transport.d.ts.map +0 -1
  128. package/dist/transport/transport.js +0 -281
  129. package/dist/util/testHelpers.d.ts.map +0 -1
@@ -1,20 +1,73 @@
1
- import { TObject, Static, TUnion } from '@sinclair/typebox';
2
- import type { Pushable } from 'it-pushable';
3
- import { TransportMessage } from '../transport/message';
4
- import { ServiceContextWithState } from './context';
5
- import { Result, RiverError, RiverUncaughtSchema } from './result';
1
+ import * as _sinclair_typebox from '@sinclair/typebox';
2
+ import { TObject, TLiteralString, TString, TSchema, TUnion, TNever, Static } from '@sinclair/typebox';
3
+ import { Pushable } from 'it-pushable';
4
+
5
+ /**
6
+ * The context for services/procedures. This is used only on
7
+ * the server.
8
+ *
9
+ * An important detail is that the state prop is always on
10
+ * this interface and it shouldn't be changed, removed, or
11
+ * extended. This prop is for the state of a service.
12
+ *
13
+ * You should use declaration merging to extend this interface
14
+ * with whatever you need. For example, if you need to access
15
+ * a database, you could do:
16
+ *
17
+ * ```ts
18
+ * declare module '@replit/river' {
19
+ * interface ServiceContext {
20
+ * db: Database;
21
+ * }
22
+ * }
23
+ * ```
24
+ */
25
+ interface ServiceContext {
26
+ state: object | unknown;
27
+ }
28
+ /**
29
+ * The {@link ServiceContext} with state. This is what is passed to procedures.
30
+ */
31
+ type ServiceContextWithState<State extends object | unknown> = ServiceContext & {
32
+ state: State;
33
+ };
34
+
35
+ type RiverErrorSchema = TObject<{
36
+ code: TLiteralString;
37
+ message: TLiteralString | TString;
38
+ }> | TObject<{
39
+ code: TLiteralString;
40
+ message: TLiteralString | TString;
41
+ extras: TSchema;
42
+ }>;
43
+ type RiverError = TUnion<RiverErrorSchema[]> | RiverErrorSchema | TNever;
44
+ declare const UNCAUGHT_ERROR = "UNCAUGHT_ERROR";
45
+ declare const RiverUncaughtSchema: TObject<{
46
+ code: TUnion<[_sinclair_typebox.TLiteral<"UNCAUGHT_ERROR">, _sinclair_typebox.TLiteral<"UNEXPECTED_DISCONNECT">]>;
47
+ message: TString;
48
+ }>;
49
+ type Result<T, E> = {
50
+ ok: true;
51
+ payload: T;
52
+ } | {
53
+ ok: false;
54
+ payload: E;
55
+ };
56
+ declare function Ok<T, E>(payload: T): Result<T, E>;
57
+ declare function Err<T, E>(error: E): Result<T, E>;
58
+
6
59
  /**
7
60
  * The valid {@link Procedure} types. The `stream` and `upload` types can optionally have a
8
61
  * different type for the very first initialization message. The suffixless types correspond to
9
62
  * gRPC's four combinations of stream / non-stream in each direction.
10
63
  */
11
- export type ValidProcType = 'rpc' | 'upload' | 'subscription' | 'stream';
64
+ type ValidProcType = 'rpc' | 'upload' | 'subscription' | 'stream';
12
65
  /**
13
66
  * A generic procedure listing where the keys are the names of the procedures
14
67
  * and the values are the {@link Procedure} definitions. This is not meant to
15
68
  * be constructed directly, use the {@link ServiceBuilder} class instead.
16
69
  */
17
- export type ProcListing = Record<string, AnyProcedure>;
70
+ type ProcListing = Record<string, AnyProcedure>;
18
71
  /**
19
72
  * Represents a service with a name, state, and procedures.
20
73
  * This is not meant to be constructed directly, use the {@link ServiceBuilder} class instead.
@@ -22,30 +75,30 @@ export type ProcListing = Record<string, AnyProcedure>;
22
75
  * @template State The type of the service state.
23
76
  * @template Procs The type of the service procedures.
24
77
  */
25
- export interface Service<Name extends string, State extends object, Procs extends ProcListing> {
78
+ interface Service<Name extends string, State extends object, Procs extends ProcListing> {
26
79
  name: Name;
27
80
  state: State;
28
81
  procedures: Procs;
29
82
  }
30
- export type AnyService = Service<string, object, any>;
83
+ type AnyService = Service<string, object, any>;
31
84
  /**
32
85
  * Serializes a service object into its corresponding JSON Schema Draft 7 type.
33
86
  * @param {AnyService} s - The service object to serialize.
34
87
  * @returns A plain object representing the serialized service.
35
88
  */
36
- export declare function serializeService(s: AnyService): object;
89
+ declare function serializeService(s: AnyService): object;
37
90
  /**
38
91
  * Helper to get the type definition for a specific handler of a procedure in a service.
39
92
  * @template S - The service.
40
93
  * @template ProcName - The name of the procedure.
41
94
  */
42
- export type ProcHandler<S extends AnyService, ProcName extends keyof S['procedures']> = S['procedures'][ProcName]['handler'];
95
+ type ProcHandler<S extends AnyService, ProcName extends keyof S['procedures']> = S['procedures'][ProcName]['handler'];
43
96
  /**
44
97
  * Helper to get whether the type definition for the procedure contains an init type.
45
98
  * @template S - The service.
46
99
  * @template ProcName - The name of the procedure.
47
100
  */
48
- export type ProcHasInit<S extends AnyService, ProcName extends keyof S['procedures']> = S['procedures'][ProcName] extends {
101
+ type ProcHasInit<S extends AnyService, ProcName extends keyof S['procedures']> = S['procedures'][ProcName] extends {
49
102
  init: any;
50
103
  } ? true : false;
51
104
  /**
@@ -53,32 +106,32 @@ export type ProcHasInit<S extends AnyService, ProcName extends keyof S['procedur
53
106
  * @template S - The service.
54
107
  * @template ProcName - The name of the procedure.
55
108
  */
56
- export type ProcInit<S extends AnyService, ProcName extends keyof S['procedures']> = S['procedures'][ProcName]['init'];
109
+ type ProcInit<S extends AnyService, ProcName extends keyof S['procedures']> = S['procedures'][ProcName]['init'];
57
110
  /**
58
111
  * Helper to get the type definition for the procedure input of a service.
59
112
  * @template S - The service.
60
113
  * @template ProcName - The name of the procedure.
61
114
  */
62
- export type ProcInput<S extends AnyService, ProcName extends keyof S['procedures']> = S['procedures'][ProcName]['input'];
115
+ type ProcInput<S extends AnyService, ProcName extends keyof S['procedures']> = S['procedures'][ProcName]['input'];
63
116
  /**
64
117
  * Helper to get the type definition for the procedure output of a service.
65
118
  * @template S - The service.
66
119
  * @template ProcName - The name of the procedure.
67
120
  */
68
- export type ProcOutput<S extends AnyService, ProcName extends keyof S['procedures']> = S['procedures'][ProcName]['output'];
121
+ type ProcOutput<S extends AnyService, ProcName extends keyof S['procedures']> = S['procedures'][ProcName]['output'];
69
122
  /**
70
123
  * Helper to get the type definition for the procedure errors of a service.
71
124
  * @template S - The service.
72
125
  * @template ProcName - The name of the procedure.
73
126
  */
74
- export type ProcErrors<S extends AnyService, ProcName extends keyof S['procedures']> = TUnion<[S['procedures'][ProcName]['errors'], typeof RiverUncaughtSchema]>;
127
+ type ProcErrors<S extends AnyService, ProcName extends keyof S['procedures']> = TUnion<[S['procedures'][ProcName]['errors'], typeof RiverUncaughtSchema]>;
75
128
  /**
76
129
  * Helper to get the type of procedure in a service.
77
130
  * @template S - The service.
78
131
  * @template ProcName - The name of the procedure.
79
132
  */
80
- export type ProcType<S extends AnyService, ProcName extends keyof S['procedures']> = S['procedures'][ProcName]['type'];
81
- export type PayloadType = TObject | TUnion<TObject[]>;
133
+ type ProcType<S extends AnyService, ProcName extends keyof S['procedures']> = S['procedures'][ProcName]['type'];
134
+ type PayloadType = TObject | TUnion<TObject[]>;
82
135
  /**
83
136
  * Defines a Procedure type that can be either an RPC or a stream procedure.
84
137
  * @template State - The TypeBox schema of the state object.
@@ -87,52 +140,52 @@ export type PayloadType = TObject | TUnion<TObject[]>;
87
140
  * @template O - The TypeBox schema of the output object.
88
141
  * @template Init - The TypeBox schema of the input initialization object.
89
142
  */
90
- export type Procedure<State extends object | unknown, Ty extends ValidProcType, I extends PayloadType, O extends PayloadType, E extends RiverError, Init extends PayloadType | null = null> = Ty extends 'rpc' ? Init extends null ? {
143
+ type Procedure<State extends object | unknown, Ty extends ValidProcType, I extends PayloadType, O extends PayloadType, E extends RiverError, Init extends PayloadType | null = null> = Ty extends 'rpc' ? Init extends null ? {
91
144
  input: I;
92
145
  output: O;
93
146
  errors: E;
94
- handler: (context: ServiceContextWithState<State>, input: TransportMessage<Static<I>>) => Promise<TransportMessage<Result<Static<O>, Static<E>>>>;
147
+ handler: (context: ServiceContextWithState<State>, input: Static<I>) => Promise<Result<Static<O>, Static<E>>>;
95
148
  type: Ty;
96
149
  } : never : Ty extends 'upload' ? Init extends PayloadType ? {
97
150
  init: Init;
98
151
  input: I;
99
152
  output: O;
100
153
  errors: E;
101
- handler: (context: ServiceContextWithState<State>, init: TransportMessage<Static<Init>>, input: AsyncIterable<TransportMessage<Static<I>>>) => Promise<TransportMessage<Result<Static<O>, Static<E>>>>;
154
+ handler: (context: ServiceContextWithState<State>, init: Static<Init>, input: AsyncIterableIterator<Static<I>>) => Promise<Result<Static<O>, Static<E>>>;
102
155
  type: Ty;
103
156
  } : {
104
157
  input: I;
105
158
  output: O;
106
159
  errors: E;
107
- handler: (context: ServiceContextWithState<State>, input: AsyncIterable<TransportMessage<Static<I>>>) => Promise<TransportMessage<Result<Static<O>, Static<E>>>>;
160
+ handler: (context: ServiceContextWithState<State>, input: AsyncIterableIterator<Static<I>>) => Promise<Result<Static<O>, Static<E>>>;
108
161
  type: Ty;
109
162
  } : Ty extends 'subscription' ? Init extends null ? {
110
163
  input: I;
111
164
  output: O;
112
165
  errors: E;
113
- handler: (context: ServiceContextWithState<State>, input: TransportMessage<Static<I>>, output: Pushable<TransportMessage<Result<Static<O>, Static<E>>>>) => Promise<void>;
166
+ handler: (context: ServiceContextWithState<State>, input: Static<I>, output: Pushable<Result<Static<O>, Static<E>>>) => Promise<void>;
114
167
  type: Ty;
115
168
  } : never : Ty extends 'stream' ? Init extends PayloadType ? {
116
169
  init: Init;
117
170
  input: I;
118
171
  output: O;
119
172
  errors: E;
120
- handler: (context: ServiceContextWithState<State>, init: TransportMessage<Static<Init>>, input: AsyncIterable<TransportMessage<Static<I>>>, output: Pushable<TransportMessage<Result<Static<O>, Static<E>>>>) => Promise<void>;
173
+ handler: (context: ServiceContextWithState<State>, init: Static<Init>, input: AsyncIterableIterator<Static<I>>, output: Pushable<Result<Static<O>, Static<E>>>) => Promise<void>;
121
174
  type: Ty;
122
175
  } : {
123
176
  input: I;
124
177
  output: O;
125
178
  errors: E;
126
- handler: (context: ServiceContextWithState<State>, input: AsyncIterable<TransportMessage<Static<I>>>, output: Pushable<TransportMessage<Result<Static<O>, Static<E>>>>) => Promise<void>;
179
+ handler: (context: ServiceContextWithState<State>, input: AsyncIterableIterator<Static<I>>, output: Pushable<Result<Static<O>, Static<E>>>) => Promise<void>;
127
180
  type: Ty;
128
181
  } : never;
129
- export type AnyProcedure = Procedure<object, ValidProcType, PayloadType, PayloadType, RiverError, PayloadType | null>;
182
+ type AnyProcedure = Procedure<object, ValidProcType, PayloadType, PayloadType, RiverError, PayloadType | null>;
130
183
  /**
131
184
  * A builder class for creating River Services.
132
185
  * You must call the finalize method to get the finalized schema for use in a service router.
133
186
  * @template T The type of the service.
134
187
  */
135
- export declare class ServiceBuilder<T extends Service<string, object, ProcListing>> {
188
+ declare class ServiceBuilder<T extends Service<string, object, ProcListing>> {
136
189
  private readonly schema;
137
190
  private constructor();
138
191
  /**
@@ -175,4 +228,5 @@ export declare class ServiceBuilder<T extends Service<string, object, ProcListin
175
228
  procedures: {};
176
229
  }>;
177
230
  }
178
- //# sourceMappingURL=builder.d.ts.map
231
+
232
+ export { AnyService as A, Err as E, Ok as O, PayloadType as P, RiverError as R, ServiceContext as S, UNCAUGHT_ERROR as U, ValidProcType as V, Procedure as a, Result as b, RiverUncaughtSchema as c, AnyProcedure as d, ProcType as e, ProcInput as f, ProcOutput as g, ProcErrors as h, ProcHasInit as i, ProcInit as j, ServiceBuilder as k, ProcListing as l, Service as m, ProcHandler as n, ServiceContextWithState as o, RiverErrorSchema as p, serializeService as s };