@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.
- package/dist/{router/builder.d.ts → builder-3c4485f0.d.ts} +82 -28
- package/dist/chunk-7WJ6YLE5.js +683 -0
- package/dist/chunk-AJQU4AZG.js +284 -0
- package/dist/chunk-ORAG7IAU.js +0 -0
- package/dist/chunk-PC65ZFWJ.js +29 -0
- package/dist/chunk-R6H2BIMC.js +49 -0
- package/dist/chunk-RGMHF6PF.js +65 -0
- package/dist/chunk-SLUSVGQH.js +30 -0
- package/dist/chunk-UU2Z7LDR.js +113 -0
- package/dist/chunk-WVT5QXMZ.js +20 -0
- package/dist/chunk-ZE4MX7DF.js +75 -0
- package/dist/codec/index.cjs +94 -0
- package/dist/codec/index.d.cts +15 -0
- package/dist/codec/index.d.ts +15 -4
- package/dist/codec/index.js +10 -2
- package/dist/connection-8e19874c.d.ts +11 -0
- package/dist/connection-f7688cc1.d.ts +11 -0
- package/dist/logging/index.cjs +56 -0
- package/dist/logging/index.d.cts +28 -0
- package/dist/logging/index.d.ts +6 -6
- package/dist/logging/index.js +9 -40
- package/dist/router/index.cjs +770 -0
- package/dist/router/index.d.cts +114 -0
- package/dist/router/index.d.ts +114 -10
- package/dist/router/index.js +24 -4
- package/dist/transport/impls/ws/client.cjs +505 -0
- package/dist/transport/impls/ws/client.d.cts +42 -0
- package/dist/transport/impls/ws/client.d.ts +9 -12
- package/dist/transport/impls/ws/client.js +10 -101
- package/dist/transport/impls/ws/server.cjs +457 -0
- package/dist/transport/impls/ws/server.d.cts +21 -0
- package/dist/transport/impls/ws/server.d.ts +14 -10
- package/dist/transport/impls/ws/server.js +11 -47
- package/dist/transport/index.cjs +362 -0
- package/dist/transport/{transport.d.ts → index.d.cts} +119 -7
- package/dist/transport/index.d.ts +273 -13
- package/dist/transport/index.js +20 -23
- package/dist/{codec/types.d.ts → types-3e5768ec.d.ts} +3 -2
- package/dist/util/testHelpers.cjs +731 -0
- package/dist/util/testHelpers.d.cts +79 -0
- package/dist/util/testHelpers.d.ts +34 -108
- package/dist/util/testHelpers.js +137 -320
- package/package.json +52 -23
- package/dist/__tests__/bandwidth.bench.d.ts +0 -2
- package/dist/__tests__/bandwidth.bench.d.ts.map +0 -1
- package/dist/__tests__/bandwidth.bench.js +0 -90
- package/dist/__tests__/e2e.test.d.ts +0 -2
- package/dist/__tests__/e2e.test.d.ts.map +0 -1
- package/dist/__tests__/e2e.test.js +0 -316
- package/dist/__tests__/fixtures/cleanup.d.ts +0 -12
- package/dist/__tests__/fixtures/cleanup.d.ts.map +0 -1
- package/dist/__tests__/fixtures/cleanup.js +0 -39
- package/dist/__tests__/fixtures/largePayload.json +0 -33
- package/dist/__tests__/fixtures/observable.d.ts +0 -26
- package/dist/__tests__/fixtures/observable.d.ts.map +0 -1
- package/dist/__tests__/fixtures/observable.js +0 -38
- package/dist/__tests__/fixtures/observable.test.d.ts +0 -2
- package/dist/__tests__/fixtures/observable.test.d.ts.map +0 -1
- package/dist/__tests__/fixtures/observable.test.js +0 -39
- package/dist/__tests__/fixtures/services.d.ts +0 -288
- package/dist/__tests__/fixtures/services.d.ts.map +0 -1
- package/dist/__tests__/fixtures/services.js +0 -224
- package/dist/__tests__/handler.test.d.ts +0 -2
- package/dist/__tests__/handler.test.d.ts.map +0 -1
- package/dist/__tests__/handler.test.js +0 -121
- package/dist/__tests__/invariants.test.d.ts +0 -2
- package/dist/__tests__/invariants.test.d.ts.map +0 -1
- package/dist/__tests__/invariants.test.js +0 -138
- package/dist/__tests__/serialize.test.d.ts +0 -2
- package/dist/__tests__/serialize.test.d.ts.map +0 -1
- package/dist/__tests__/serialize.test.js +0 -208
- package/dist/__tests__/typescript-stress.test.d.ts +0 -1583
- package/dist/__tests__/typescript-stress.test.d.ts.map +0 -1
- package/dist/__tests__/typescript-stress.test.js +0 -123
- package/dist/codec/binary.d.ts +0 -7
- package/dist/codec/binary.d.ts.map +0 -1
- package/dist/codec/binary.js +0 -20
- package/dist/codec/codec.test.d.ts +0 -5
- package/dist/codec/codec.test.d.ts.map +0 -1
- package/dist/codec/codec.test.js +0 -41
- package/dist/codec/index.d.ts.map +0 -1
- package/dist/codec/json.d.ts +0 -7
- package/dist/codec/json.d.ts.map +0 -1
- package/dist/codec/json.js +0 -51
- package/dist/codec/types.d.ts.map +0 -1
- package/dist/codec/types.js +0 -1
- package/dist/logging/index.d.ts.map +0 -1
- package/dist/router/builder.d.ts.map +0 -1
- package/dist/router/builder.js +0 -91
- package/dist/router/client.d.ts +0 -68
- package/dist/router/client.d.ts.map +0 -1
- package/dist/router/client.js +0 -159
- package/dist/router/context.d.ts +0 -30
- package/dist/router/context.d.ts.map +0 -1
- package/dist/router/context.js +0 -1
- package/dist/router/index.d.ts.map +0 -1
- package/dist/router/result.d.ts +0 -25
- package/dist/router/result.d.ts.map +0 -1
- package/dist/router/result.js +0 -18
- package/dist/router/server.d.ts +0 -39
- package/dist/router/server.d.ts.map +0 -1
- package/dist/router/server.js +0 -217
- package/dist/transport/events.d.ts +0 -19
- package/dist/transport/events.d.ts.map +0 -1
- package/dist/transport/events.js +0 -26
- package/dist/transport/impls/stdio/stdio.d.ts +0 -33
- package/dist/transport/impls/stdio/stdio.d.ts.map +0 -1
- package/dist/transport/impls/stdio/stdio.js +0 -75
- package/dist/transport/impls/stdio/stdio.test.d.ts +0 -2
- package/dist/transport/impls/stdio/stdio.test.d.ts.map +0 -1
- package/dist/transport/impls/stdio/stdio.test.js +0 -25
- package/dist/transport/impls/ws/client.d.ts.map +0 -1
- package/dist/transport/impls/ws/connection.d.ts +0 -11
- package/dist/transport/impls/ws/connection.d.ts.map +0 -1
- package/dist/transport/impls/ws/connection.js +0 -23
- package/dist/transport/impls/ws/server.d.ts.map +0 -1
- package/dist/transport/impls/ws/ws.test.d.ts +0 -2
- package/dist/transport/impls/ws/ws.test.d.ts.map +0 -1
- package/dist/transport/impls/ws/ws.test.js +0 -117
- package/dist/transport/index.d.ts.map +0 -1
- package/dist/transport/message.d.ts +0 -143
- package/dist/transport/message.d.ts.map +0 -1
- package/dist/transport/message.js +0 -113
- package/dist/transport/message.test.d.ts +0 -2
- package/dist/transport/message.test.d.ts.map +0 -1
- package/dist/transport/message.test.js +0 -52
- package/dist/transport/transport.d.ts.map +0 -1
- package/dist/transport/transport.js +0 -281
- package/dist/util/testHelpers.d.ts.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"typescript-stress.test.d.ts","sourceRoot":"","sources":["../../__tests__/typescript-stress.test.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAE,sBAAsB,EAAS,MAAM,sBAAsB,CAAC;AAEhF,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAsC/D,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAmDlB,CAAC;AAGhB,qBAAa,aAAc,SAAQ,SAAS,CAAC,UAAU,CAAC;gBAC1C,QAAQ,EAAE,MAAM;IAI5B,IAAI,CAAC,GAAG,EAAE,sBAAsB,GAAG,SAAS;IAK5C,8BAA8B;IACxB,mBAAmB;IACnB,KAAK;CACZ"}
|
|
@@ -1,123 +0,0 @@
|
|
|
1
|
-
import { describe, expect, test } from 'vitest';
|
|
2
|
-
import { ServiceBuilder, serializeService } from '../router/builder';
|
|
3
|
-
import { Type } from '@sinclair/typebox';
|
|
4
|
-
import { reply } from '../transport/message';
|
|
5
|
-
import { createServer } from '../router/server';
|
|
6
|
-
import { Transport } from '../transport/transport';
|
|
7
|
-
import { NaiveJsonCodec } from '../codec/json';
|
|
8
|
-
import { createClient } from '../router/client';
|
|
9
|
-
import { Ok } from '../router/result';
|
|
10
|
-
const input = Type.Union([
|
|
11
|
-
Type.Object({ a: Type.Number() }),
|
|
12
|
-
Type.Object({ c: Type.String() }),
|
|
13
|
-
]);
|
|
14
|
-
const output = Type.Object({ b: Type.Union([Type.Number(), Type.String()]) });
|
|
15
|
-
const errors = Type.Union([
|
|
16
|
-
Type.Object({
|
|
17
|
-
code: Type.Literal('ERROR1'),
|
|
18
|
-
message: Type.String(),
|
|
19
|
-
}),
|
|
20
|
-
Type.Object({
|
|
21
|
-
code: Type.Literal('ERROR2'),
|
|
22
|
-
message: Type.String(),
|
|
23
|
-
}),
|
|
24
|
-
]);
|
|
25
|
-
const fnBody = {
|
|
26
|
-
type: 'rpc',
|
|
27
|
-
input,
|
|
28
|
-
output,
|
|
29
|
-
errors,
|
|
30
|
-
async handler(_state, msg) {
|
|
31
|
-
if ('c' in msg.payload) {
|
|
32
|
-
return reply(msg, Ok({ b: msg.payload.c }));
|
|
33
|
-
}
|
|
34
|
-
else {
|
|
35
|
-
return reply(msg, Ok({ b: msg.payload.a }));
|
|
36
|
-
}
|
|
37
|
-
},
|
|
38
|
-
};
|
|
39
|
-
// typescript is limited to max 50 constraints
|
|
40
|
-
// see: https://github.com/microsoft/TypeScript/issues/33541
|
|
41
|
-
export const StupidlyLargeService = () => ServiceBuilder.create('test')
|
|
42
|
-
.defineProcedure('f1', fnBody)
|
|
43
|
-
.defineProcedure('f2', fnBody)
|
|
44
|
-
.defineProcedure('f3', fnBody)
|
|
45
|
-
.defineProcedure('f4', fnBody)
|
|
46
|
-
.defineProcedure('f5', fnBody)
|
|
47
|
-
.defineProcedure('f6', fnBody)
|
|
48
|
-
.defineProcedure('f7', fnBody)
|
|
49
|
-
.defineProcedure('f8', fnBody)
|
|
50
|
-
.defineProcedure('f9', fnBody)
|
|
51
|
-
.defineProcedure('f10', fnBody)
|
|
52
|
-
.defineProcedure('f11', fnBody)
|
|
53
|
-
.defineProcedure('f12', fnBody)
|
|
54
|
-
.defineProcedure('f13', fnBody)
|
|
55
|
-
.defineProcedure('f14', fnBody)
|
|
56
|
-
.defineProcedure('f15', fnBody)
|
|
57
|
-
.defineProcedure('f16', fnBody)
|
|
58
|
-
.defineProcedure('f17', fnBody)
|
|
59
|
-
.defineProcedure('f18', fnBody)
|
|
60
|
-
.defineProcedure('f19', fnBody)
|
|
61
|
-
.defineProcedure('f20', fnBody)
|
|
62
|
-
.defineProcedure('f21', fnBody)
|
|
63
|
-
.defineProcedure('f22', fnBody)
|
|
64
|
-
.defineProcedure('f23', fnBody)
|
|
65
|
-
.defineProcedure('f24', fnBody)
|
|
66
|
-
.defineProcedure('f25', fnBody)
|
|
67
|
-
.defineProcedure('f26', fnBody)
|
|
68
|
-
.defineProcedure('f27', fnBody)
|
|
69
|
-
.defineProcedure('f28', fnBody)
|
|
70
|
-
.defineProcedure('f29', fnBody)
|
|
71
|
-
.defineProcedure('f30', fnBody)
|
|
72
|
-
.defineProcedure('f31', fnBody)
|
|
73
|
-
.defineProcedure('f32', fnBody)
|
|
74
|
-
.defineProcedure('f33', fnBody)
|
|
75
|
-
.defineProcedure('f34', fnBody)
|
|
76
|
-
.defineProcedure('f35', fnBody)
|
|
77
|
-
.defineProcedure('f36', fnBody)
|
|
78
|
-
.defineProcedure('f37', fnBody)
|
|
79
|
-
.defineProcedure('f38', fnBody)
|
|
80
|
-
.defineProcedure('f39', fnBody)
|
|
81
|
-
.defineProcedure('f40', fnBody)
|
|
82
|
-
.defineProcedure('f41', fnBody)
|
|
83
|
-
.defineProcedure('f42', fnBody)
|
|
84
|
-
.defineProcedure('f43', fnBody)
|
|
85
|
-
.defineProcedure('f44', fnBody)
|
|
86
|
-
.defineProcedure('f45', fnBody)
|
|
87
|
-
.defineProcedure('f46', fnBody)
|
|
88
|
-
.defineProcedure('f47', fnBody)
|
|
89
|
-
.defineProcedure('f48', fnBody)
|
|
90
|
-
.defineProcedure('f49', fnBody)
|
|
91
|
-
.finalize();
|
|
92
|
-
// mock transport
|
|
93
|
-
export class MockTransport extends Transport {
|
|
94
|
-
constructor(clientId) {
|
|
95
|
-
super(NaiveJsonCodec, clientId);
|
|
96
|
-
}
|
|
97
|
-
send(msg) {
|
|
98
|
-
const id = msg.id;
|
|
99
|
-
return id;
|
|
100
|
-
}
|
|
101
|
-
setupConnectionStatusListeners() { }
|
|
102
|
-
async createNewConnection() { }
|
|
103
|
-
async close() { }
|
|
104
|
-
}
|
|
105
|
-
describe("ensure typescript doesn't give up trying to infer the types for large services", () => {
|
|
106
|
-
test('service with many procedures hits typescript limit', () => {
|
|
107
|
-
expect(serializeService(StupidlyLargeService())).toBeTruthy();
|
|
108
|
-
});
|
|
109
|
-
test('serverclient should support many services with many procedures', async () => {
|
|
110
|
-
const listing = {
|
|
111
|
-
a: StupidlyLargeService(),
|
|
112
|
-
b: StupidlyLargeService(),
|
|
113
|
-
c: StupidlyLargeService(),
|
|
114
|
-
d: StupidlyLargeService(),
|
|
115
|
-
};
|
|
116
|
-
const server = await createServer(new MockTransport('SERVER'), listing);
|
|
117
|
-
const client = createClient(new MockTransport('client'));
|
|
118
|
-
expect(client.d.f48.rpc({ a: 0 })).toBeTruthy();
|
|
119
|
-
expect(client.a.f2.rpc({ c: 'abc' })).toBeTruthy();
|
|
120
|
-
expect(server).toBeTruthy();
|
|
121
|
-
expect(client).toBeTruthy();
|
|
122
|
-
});
|
|
123
|
-
});
|
package/dist/codec/binary.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"binary.d.ts","sourceRoot":"","sources":["../../codec/binary.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAEhC;;;GAGG;AACH,eAAO,MAAM,WAAW,EAAE,KAczB,CAAC"}
|
package/dist/codec/binary.js
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { decode, encode } from '@msgpack/msgpack';
|
|
2
|
-
/**
|
|
3
|
-
* Binary codec, uses [msgpack](https://www.npmjs.com/package/@msgpack/msgpack) under the hood
|
|
4
|
-
* @type {Codec}
|
|
5
|
-
*/
|
|
6
|
-
export const BinaryCodec = {
|
|
7
|
-
toBuffer: encode,
|
|
8
|
-
fromBuffer: (buff) => {
|
|
9
|
-
try {
|
|
10
|
-
const res = decode(buff);
|
|
11
|
-
if (typeof res !== 'object') {
|
|
12
|
-
return null;
|
|
13
|
-
}
|
|
14
|
-
return res;
|
|
15
|
-
}
|
|
16
|
-
catch {
|
|
17
|
-
return null;
|
|
18
|
-
}
|
|
19
|
-
},
|
|
20
|
-
};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"codec.test.d.ts","sourceRoot":"","sources":["../../codec/codec.test.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,MAAM;;;GAGlB,CAAC"}
|
package/dist/codec/codec.test.js
DELETED
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { BinaryCodec } from './binary';
|
|
2
|
-
import { NaiveJsonCodec } from './json';
|
|
3
|
-
import { describe, test, expect } from 'vitest';
|
|
4
|
-
export const codecs = [
|
|
5
|
-
{ name: 'naive', codec: NaiveJsonCodec },
|
|
6
|
-
{ name: 'binary', codec: BinaryCodec },
|
|
7
|
-
];
|
|
8
|
-
describe.each(codecs)('codec -- $name', ({ codec }) => {
|
|
9
|
-
test('empty object', () => {
|
|
10
|
-
const msg = {};
|
|
11
|
-
expect(codec.fromBuffer(codec.toBuffer(msg))).toStrictEqual(msg);
|
|
12
|
-
});
|
|
13
|
-
test('simple test', () => {
|
|
14
|
-
const msg = { abc: 123, def: 'cool' };
|
|
15
|
-
expect(codec.fromBuffer(codec.toBuffer(msg))).toStrictEqual(msg);
|
|
16
|
-
});
|
|
17
|
-
test('deeply nested test', () => {
|
|
18
|
-
const msg = {
|
|
19
|
-
array: [{ object: true }],
|
|
20
|
-
deeply: {
|
|
21
|
-
nested: {
|
|
22
|
-
nice: null,
|
|
23
|
-
},
|
|
24
|
-
},
|
|
25
|
-
};
|
|
26
|
-
expect(codec.fromBuffer(codec.toBuffer(msg))).toStrictEqual(msg);
|
|
27
|
-
});
|
|
28
|
-
test('buffer test', () => {
|
|
29
|
-
const msg = {
|
|
30
|
-
buff: Uint8Array.from([0, 42, 100, 255]),
|
|
31
|
-
};
|
|
32
|
-
expect(codec.fromBuffer(codec.toBuffer(msg))).toStrictEqual(msg);
|
|
33
|
-
});
|
|
34
|
-
test('invalid json returns null', () => {
|
|
35
|
-
const encoder = new TextEncoder();
|
|
36
|
-
expect(codec.fromBuffer(encoder.encode(''))).toBeNull();
|
|
37
|
-
expect(codec.fromBuffer(encoder.encode('['))).toBeNull();
|
|
38
|
-
expect(codec.fromBuffer(encoder.encode('[{}'))).toBeNull();
|
|
39
|
-
expect(codec.fromBuffer(encoder.encode('{"a":1}[]'))).toBeNull();
|
|
40
|
-
});
|
|
41
|
-
});
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../codec/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AACxC,YAAY,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC"}
|
package/dist/codec/json.d.ts
DELETED
package/dist/codec/json.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"json.d.ts","sourceRoot":"","sources":["../../codec/json.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAwBhC;;;GAGG;AACH,eAAO,MAAM,cAAc,EAAE,KA0B5B,CAAC"}
|
package/dist/codec/json.js
DELETED
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
const encoder = new TextEncoder();
|
|
2
|
-
const decoder = new TextDecoder();
|
|
3
|
-
// Convert Uint8Array to base64
|
|
4
|
-
function uint8ArrayToBase64(uint8Array) {
|
|
5
|
-
let binary = '';
|
|
6
|
-
uint8Array.forEach((byte) => {
|
|
7
|
-
binary += String.fromCharCode(byte);
|
|
8
|
-
});
|
|
9
|
-
return btoa(binary);
|
|
10
|
-
}
|
|
11
|
-
// Convert base64 to Uint8Array
|
|
12
|
-
function base64ToUint8Array(base64) {
|
|
13
|
-
const binaryString = atob(base64);
|
|
14
|
-
const uint8Array = new Uint8Array(binaryString.length);
|
|
15
|
-
for (let i = 0; i < binaryString.length; i++) {
|
|
16
|
-
uint8Array[i] = binaryString.charCodeAt(i);
|
|
17
|
-
}
|
|
18
|
-
return uint8Array;
|
|
19
|
-
}
|
|
20
|
-
/**
|
|
21
|
-
* Naive JSON codec implementation using JSON.stringify and JSON.parse.
|
|
22
|
-
* @type {Codec}
|
|
23
|
-
*/
|
|
24
|
-
export const NaiveJsonCodec = {
|
|
25
|
-
toBuffer: (obj) => {
|
|
26
|
-
return encoder.encode(JSON.stringify(obj, function replacer(key) {
|
|
27
|
-
let val = this[key];
|
|
28
|
-
if (val instanceof Uint8Array) {
|
|
29
|
-
return { $t: uint8ArrayToBase64(val) };
|
|
30
|
-
}
|
|
31
|
-
else {
|
|
32
|
-
return val;
|
|
33
|
-
}
|
|
34
|
-
}));
|
|
35
|
-
},
|
|
36
|
-
fromBuffer: (buff) => {
|
|
37
|
-
try {
|
|
38
|
-
return JSON.parse(decoder.decode(buff), function reviver(_key, val) {
|
|
39
|
-
if (val?.$t) {
|
|
40
|
-
return base64ToUint8Array(val.$t);
|
|
41
|
-
}
|
|
42
|
-
else {
|
|
43
|
-
return val;
|
|
44
|
-
}
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
catch {
|
|
48
|
-
return null;
|
|
49
|
-
}
|
|
50
|
-
},
|
|
51
|
-
};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../codec/types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,MAAM,WAAW,KAAK;IACpB;;;;OAIG;IACH,QAAQ,CAAC,GAAG,EAAE,MAAM,GAAG,UAAU,CAAC;IAClC;;;;OAIG;IACH,UAAU,CAAC,GAAG,EAAE,UAAU,GAAG,MAAM,GAAG,IAAI,CAAC;CAC5C"}
|
package/dist/codec/types.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../logging/index.ts"],"names":[],"mappings":"AAAA,QAAA,MAAM,aAAa;;;;CAIT,CAAC;AAEX,KAAK,YAAY,GAAG,MAAM,OAAO,aAAa,CAAC;AAC/C,MAAM,MAAM,MAAM,GAAG;IACnB,QAAQ,EAAE,YAAY,CAAC;CACxB,GAAG;KACD,GAAG,IAAI,YAAY,GAAG,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI;CAC7C,CAAC;AAEF;;GAEG;AACH,eAAO,IAAI,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC;AAGnC;;;;GAIG;AACH,wBAAgB,UAAU,CAAC,KAAK,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,EAAE,KAAK,CAAC,EAAE,OAAO,QAoBvE;AAED;;;GAGG;AACH,wBAAgB,QAAQ,CAAC,KAAK,EAAE,YAAY,QAI3C"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"builder.d.ts","sourceRoot":"","sources":["../../router/builder.ts"],"names":[],"mappings":"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"}
|
package/dist/router/builder.js
DELETED
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
import { Type } from '@sinclair/typebox';
|
|
2
|
-
/**
|
|
3
|
-
* Serializes a service object into its corresponding JSON Schema Draft 7 type.
|
|
4
|
-
* @param {AnyService} s - The service object to serialize.
|
|
5
|
-
* @returns A plain object representing the serialized service.
|
|
6
|
-
*/
|
|
7
|
-
export function serializeService(s) {
|
|
8
|
-
return {
|
|
9
|
-
name: s.name,
|
|
10
|
-
state: s.state,
|
|
11
|
-
procedures: Object.fromEntries(Object.entries(s.procedures).map(([procName, procDef]) => [
|
|
12
|
-
procName,
|
|
13
|
-
{
|
|
14
|
-
input: Type.Strict(procDef.input),
|
|
15
|
-
output: Type.Strict(procDef.output),
|
|
16
|
-
// Only add the `errors` field if it is non-never.
|
|
17
|
-
...('errors' in procDef
|
|
18
|
-
? {
|
|
19
|
-
errors: Type.Strict(procDef.errors),
|
|
20
|
-
}
|
|
21
|
-
: {}),
|
|
22
|
-
type: procDef.type,
|
|
23
|
-
// Only add the `init` field if the type declares it.
|
|
24
|
-
...('init' in procDef
|
|
25
|
-
? {
|
|
26
|
-
init: Type.Strict(procDef.init),
|
|
27
|
-
}
|
|
28
|
-
: {}),
|
|
29
|
-
},
|
|
30
|
-
])),
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
/**
|
|
34
|
-
* A builder class for creating River Services.
|
|
35
|
-
* You must call the finalize method to get the finalized schema for use in a service router.
|
|
36
|
-
* @template T The type of the service.
|
|
37
|
-
*/
|
|
38
|
-
export class ServiceBuilder {
|
|
39
|
-
schema;
|
|
40
|
-
constructor(schema) {
|
|
41
|
-
this.schema = schema;
|
|
42
|
-
}
|
|
43
|
-
/**
|
|
44
|
-
* Finalizes the schema for the service.
|
|
45
|
-
* @returns {T} The finalized schema for the service.
|
|
46
|
-
*/
|
|
47
|
-
finalize() {
|
|
48
|
-
return this.schema;
|
|
49
|
-
}
|
|
50
|
-
/**
|
|
51
|
-
* Sets the initial state for the service.
|
|
52
|
-
* @template InitState The type of the initial state.
|
|
53
|
-
* @param {InitState} state The initial state for the service.
|
|
54
|
-
* @returns {ServiceBuilder<{ name: T['name']; state: InitState; procedures: T['procedures']; }>} A new ServiceBuilder instance with the updated schema.
|
|
55
|
-
*/
|
|
56
|
-
initialState(state) {
|
|
57
|
-
return new ServiceBuilder({
|
|
58
|
-
...this.schema,
|
|
59
|
-
state,
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
/**
|
|
63
|
-
* Defines a new procedure for the service.
|
|
64
|
-
* @param {ProcName} procName The name of the procedure.
|
|
65
|
-
* @param {Procedure<T['state'], Ty, I, O, E, Init>} procDef The definition of the procedure.
|
|
66
|
-
* @returns {ServiceBuilder<{ name: T['name']; state: T['state']; procedures: T['procedures'] & { [k in ProcName]: Procedure<T['state'], Ty, I, O, E, Init>; }; }>} A new ServiceBuilder instance with the updated schema.
|
|
67
|
-
*/
|
|
68
|
-
defineProcedure(procName, procDef) {
|
|
69
|
-
const newProcedure = { [procName]: procDef };
|
|
70
|
-
const procedures = {
|
|
71
|
-
...this.schema.procedures,
|
|
72
|
-
...newProcedure,
|
|
73
|
-
};
|
|
74
|
-
return new ServiceBuilder({
|
|
75
|
-
...this.schema,
|
|
76
|
-
procedures,
|
|
77
|
-
});
|
|
78
|
-
}
|
|
79
|
-
/**
|
|
80
|
-
* Creates a new instance of ServiceBuilder.
|
|
81
|
-
* @param {Name} name The name of the service.
|
|
82
|
-
* @returns {ServiceBuilder<{ name: Name; state: {}; procedures: {}; }>} A new instance of ServiceBuilder.
|
|
83
|
-
*/
|
|
84
|
-
static create(name) {
|
|
85
|
-
return new ServiceBuilder({
|
|
86
|
-
name,
|
|
87
|
-
state: {},
|
|
88
|
-
procedures: {},
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
}
|
package/dist/router/client.d.ts
DELETED
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
import { Connection, Transport } from '../transport/transport';
|
|
2
|
-
import { AnyService, ProcErrors, ProcHasInit, ProcInit, ProcInput, ProcOutput, ProcType } from './builder';
|
|
3
|
-
import type { Pushable } from 'it-pushable';
|
|
4
|
-
import { Server } from './server';
|
|
5
|
-
import { TransportClientId } from '../transport/message';
|
|
6
|
-
import { Static } from '@sinclair/typebox';
|
|
7
|
-
import { Result } from './result';
|
|
8
|
-
type AsyncIter<T> = AsyncGenerator<T, T, unknown>;
|
|
9
|
-
/**
|
|
10
|
-
* A helper type to transform an actual service type into a type
|
|
11
|
-
* we can case to in the proxy.
|
|
12
|
-
* @template Router - The type of the Router.
|
|
13
|
-
*/
|
|
14
|
-
type ServiceClient<Router extends AnyService> = {
|
|
15
|
-
[ProcName in keyof Router['procedures']]: ProcType<Router, ProcName> extends 'rpc' ? {
|
|
16
|
-
rpc: (input: Static<ProcInput<Router, ProcName>>) => Promise<Result<Static<ProcOutput<Router, ProcName>>, Static<ProcErrors<Router, ProcName>>>>;
|
|
17
|
-
} : ProcType<Router, ProcName> extends 'upload' ? ProcHasInit<Router, ProcName> extends true ? {
|
|
18
|
-
upload: (init: Static<ProcInit<Router, ProcName>>) => Promise<[
|
|
19
|
-
Pushable<Static<ProcInput<Router, ProcName>>>,
|
|
20
|
-
Promise<Result<Static<ProcOutput<Router, ProcName>>, Static<ProcErrors<Router, ProcName>>>>
|
|
21
|
-
]>;
|
|
22
|
-
} : {
|
|
23
|
-
upload: () => Promise<[
|
|
24
|
-
Pushable<Static<ProcInput<Router, ProcName>>>,
|
|
25
|
-
Promise<Result<Static<ProcOutput<Router, ProcName>>, Static<ProcErrors<Router, ProcName>>>>
|
|
26
|
-
]>;
|
|
27
|
-
} : ProcType<Router, ProcName> extends 'stream' ? ProcHasInit<Router, ProcName> extends true ? {
|
|
28
|
-
stream: (init: Static<ProcInit<Router, ProcName>>) => Promise<[
|
|
29
|
-
Pushable<Static<ProcInput<Router, ProcName>>>,
|
|
30
|
-
AsyncIter<Result<Static<ProcOutput<Router, ProcName>>, Static<ProcErrors<Router, ProcName>>>>,
|
|
31
|
-
() => void
|
|
32
|
-
]>;
|
|
33
|
-
} : {
|
|
34
|
-
stream: () => Promise<[
|
|
35
|
-
Pushable<Static<ProcInput<Router, ProcName>>>,
|
|
36
|
-
AsyncIter<Result<Static<ProcOutput<Router, ProcName>>, Static<ProcErrors<Router, ProcName>>>>,
|
|
37
|
-
() => void
|
|
38
|
-
]>;
|
|
39
|
-
} : ProcType<Router, ProcName> extends 'subscription' ? {
|
|
40
|
-
subscribe: (input: Static<ProcInput<Router, ProcName>>) => Promise<[
|
|
41
|
-
AsyncIter<Result<Static<ProcOutput<Router, ProcName>>, Static<ProcErrors<Router, ProcName>>>>,
|
|
42
|
-
() => void
|
|
43
|
-
]>;
|
|
44
|
-
} : never;
|
|
45
|
-
};
|
|
46
|
-
/**
|
|
47
|
-
* Defines a type that represents a client for a server with a set of services.
|
|
48
|
-
* @template Srv - The type of the server.
|
|
49
|
-
*/
|
|
50
|
-
export type ServerClient<Srv extends Server<Record<string, AnyService>>> = {
|
|
51
|
-
[SvcName in keyof Srv['services']]: ServiceClient<Srv['services'][SvcName]>;
|
|
52
|
-
};
|
|
53
|
-
/**
|
|
54
|
-
* Creates a client for a given server using the provided transport.
|
|
55
|
-
* Note that the client only needs the type of the server, not the actual
|
|
56
|
-
* server definition itself.
|
|
57
|
-
*
|
|
58
|
-
* This relies on a proxy to dynamically create the client, so the client
|
|
59
|
-
* will be typed as if it were the actual server with the appropriate services
|
|
60
|
-
* and procedures.
|
|
61
|
-
*
|
|
62
|
-
* @template Srv - The type of the server.
|
|
63
|
-
* @param {Transport} transport - The transport to use for communication.
|
|
64
|
-
* @returns The client for the server.
|
|
65
|
-
*/
|
|
66
|
-
export declare const createClient: <Srv extends Server<Record<string, AnyService>>>(transport: Transport<Connection>, serverId?: TransportClientId) => ServerClient<Srv>;
|
|
67
|
-
export {};
|
|
68
|
-
//# sourceMappingURL=client.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../router/client.ts"],"names":[],"mappings":"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"}
|
package/dist/router/client.js
DELETED
|
@@ -1,159 +0,0 @@
|
|
|
1
|
-
import { pushable } from 'it-pushable';
|
|
2
|
-
import { msg, isStreamClose, closeStream, } from '../transport/message';
|
|
3
|
-
import { waitForMessage } from '../transport';
|
|
4
|
-
import { nanoid } from 'nanoid';
|
|
5
|
-
const noop = () => { };
|
|
6
|
-
function _createRecursiveProxy(callback, path) {
|
|
7
|
-
const proxy = new Proxy(noop, {
|
|
8
|
-
// property access, recurse and add field to path
|
|
9
|
-
get(_obj, key) {
|
|
10
|
-
if (typeof key !== 'string')
|
|
11
|
-
return undefined;
|
|
12
|
-
return _createRecursiveProxy(callback, [...path, key]);
|
|
13
|
-
},
|
|
14
|
-
// hit the end, let's invoke the handler
|
|
15
|
-
apply(_target, _this, args) {
|
|
16
|
-
return callback({
|
|
17
|
-
path,
|
|
18
|
-
args,
|
|
19
|
-
});
|
|
20
|
-
},
|
|
21
|
-
});
|
|
22
|
-
return proxy;
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Creates a client for a given server using the provided transport.
|
|
26
|
-
* Note that the client only needs the type of the server, not the actual
|
|
27
|
-
* server definition itself.
|
|
28
|
-
*
|
|
29
|
-
* This relies on a proxy to dynamically create the client, so the client
|
|
30
|
-
* will be typed as if it were the actual server with the appropriate services
|
|
31
|
-
* and procedures.
|
|
32
|
-
*
|
|
33
|
-
* @template Srv - The type of the server.
|
|
34
|
-
* @param {Transport} transport - The transport to use for communication.
|
|
35
|
-
* @returns The client for the server.
|
|
36
|
-
*/
|
|
37
|
-
export const createClient = (transport, serverId = 'SERVER') => _createRecursiveProxy(async (opts) => {
|
|
38
|
-
const [serviceName, procName, procType] = [...opts.path];
|
|
39
|
-
if (!(serviceName && procName && procType)) {
|
|
40
|
-
throw new Error('invalid river call, ensure the service and procedure you are calling exists');
|
|
41
|
-
}
|
|
42
|
-
const [input] = opts.args;
|
|
43
|
-
const streamId = nanoid();
|
|
44
|
-
function belongsToSameStream(msg) {
|
|
45
|
-
return msg.streamId === streamId;
|
|
46
|
-
}
|
|
47
|
-
if (procType === 'stream') {
|
|
48
|
-
const inputStream = pushable({ objectMode: true });
|
|
49
|
-
const outputStream = pushable({ objectMode: true });
|
|
50
|
-
let firstMessage = true;
|
|
51
|
-
if (input) {
|
|
52
|
-
const m = msg(transport.clientId, serverId, streamId, input, serviceName, procName);
|
|
53
|
-
// first message needs the open bit.
|
|
54
|
-
m.controlFlags = 2 /* ControlFlags.StreamOpenBit */;
|
|
55
|
-
transport.send(m);
|
|
56
|
-
firstMessage = false;
|
|
57
|
-
}
|
|
58
|
-
// input -> transport
|
|
59
|
-
// this gets cleaned up on inputStream.end() which is called by closeHandler
|
|
60
|
-
(async () => {
|
|
61
|
-
for await (const rawIn of inputStream) {
|
|
62
|
-
const m = msg(transport.clientId, serverId, streamId, rawIn);
|
|
63
|
-
if (firstMessage) {
|
|
64
|
-
m.serviceName = serviceName;
|
|
65
|
-
m.procedureName = procName;
|
|
66
|
-
m.controlFlags |= 2 /* ControlFlags.StreamOpenBit */;
|
|
67
|
-
firstMessage = false;
|
|
68
|
-
}
|
|
69
|
-
transport.send(m);
|
|
70
|
-
}
|
|
71
|
-
transport.send(closeStream(transport.clientId, serverId, streamId));
|
|
72
|
-
})();
|
|
73
|
-
// transport -> output
|
|
74
|
-
const listener = (msg) => {
|
|
75
|
-
if (!belongsToSameStream(msg)) {
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
if (isStreamClose(msg.controlFlags)) {
|
|
79
|
-
outputStream.end();
|
|
80
|
-
transport.removeEventListener('message', listener);
|
|
81
|
-
}
|
|
82
|
-
else {
|
|
83
|
-
outputStream.push(msg.payload);
|
|
84
|
-
}
|
|
85
|
-
};
|
|
86
|
-
transport.addEventListener('message', listener);
|
|
87
|
-
const closeHandler = () => {
|
|
88
|
-
inputStream.end();
|
|
89
|
-
outputStream.end();
|
|
90
|
-
transport.send(closeStream(transport.clientId, serverId, streamId));
|
|
91
|
-
transport.removeEventListener('message', listener);
|
|
92
|
-
};
|
|
93
|
-
return [inputStream, outputStream, closeHandler];
|
|
94
|
-
}
|
|
95
|
-
else if (procType === 'rpc') {
|
|
96
|
-
const m = msg(transport.clientId, serverId, streamId, input, serviceName, procName);
|
|
97
|
-
// rpc is a stream open + close
|
|
98
|
-
m.controlFlags |=
|
|
99
|
-
2 /* ControlFlags.StreamOpenBit */ | 4 /* ControlFlags.StreamClosedBit */;
|
|
100
|
-
transport.send(m);
|
|
101
|
-
return waitForMessage(transport, belongsToSameStream);
|
|
102
|
-
}
|
|
103
|
-
else if (procType === 'subscribe') {
|
|
104
|
-
const m = msg(transport.clientId, serverId, streamId, input, serviceName, procName);
|
|
105
|
-
m.controlFlags |= 2 /* ControlFlags.StreamOpenBit */;
|
|
106
|
-
transport.send(m);
|
|
107
|
-
// transport -> output
|
|
108
|
-
const outputStream = pushable({ objectMode: true });
|
|
109
|
-
const listener = (msg) => {
|
|
110
|
-
if (!belongsToSameStream(msg)) {
|
|
111
|
-
return;
|
|
112
|
-
}
|
|
113
|
-
if (isStreamClose(msg.controlFlags)) {
|
|
114
|
-
outputStream.end();
|
|
115
|
-
transport.removeEventListener('message', listener);
|
|
116
|
-
}
|
|
117
|
-
else {
|
|
118
|
-
outputStream.push(msg.payload);
|
|
119
|
-
}
|
|
120
|
-
};
|
|
121
|
-
transport.addEventListener('message', listener);
|
|
122
|
-
const closeHandler = () => {
|
|
123
|
-
outputStream.end();
|
|
124
|
-
transport.send(closeStream(transport.clientId, serverId, streamId));
|
|
125
|
-
transport.removeEventListener('message', listener);
|
|
126
|
-
};
|
|
127
|
-
return [outputStream, closeHandler];
|
|
128
|
-
}
|
|
129
|
-
else if (procType === 'upload') {
|
|
130
|
-
const inputStream = pushable({ objectMode: true });
|
|
131
|
-
let firstMessage = true;
|
|
132
|
-
if (input) {
|
|
133
|
-
const m = msg(transport.clientId, serverId, streamId, input, serviceName, procName);
|
|
134
|
-
// first message needs the open bit.
|
|
135
|
-
m.controlFlags = 2 /* ControlFlags.StreamOpenBit */;
|
|
136
|
-
transport.send(m);
|
|
137
|
-
firstMessage = false;
|
|
138
|
-
}
|
|
139
|
-
// input -> transport
|
|
140
|
-
// this gets cleaned up on inputStream.end(), which the caller should call.
|
|
141
|
-
(async () => {
|
|
142
|
-
for await (const rawIn of inputStream) {
|
|
143
|
-
const m = msg(transport.clientId, serverId, streamId, rawIn);
|
|
144
|
-
if (firstMessage) {
|
|
145
|
-
m.controlFlags |= 2 /* ControlFlags.StreamOpenBit */;
|
|
146
|
-
m.serviceName = serviceName;
|
|
147
|
-
m.procedureName = procName;
|
|
148
|
-
firstMessage = false;
|
|
149
|
-
}
|
|
150
|
-
transport.send(m);
|
|
151
|
-
}
|
|
152
|
-
transport.send(closeStream(transport.clientId, serverId, streamId));
|
|
153
|
-
})();
|
|
154
|
-
return [inputStream, waitForMessage(transport, belongsToSameStream)];
|
|
155
|
-
}
|
|
156
|
-
else {
|
|
157
|
-
throw new Error(`invalid river call, unknown procedure type ${procType}`);
|
|
158
|
-
}
|
|
159
|
-
}, []);
|