@delight-rpc/extra-websocket 0.1.0 → 0.2.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/README.md +17 -0
- package/lib/client.d.ts +4 -2
- package/lib/client.js +15 -4
- package/lib/client.js.map +1 -1
- package/lib/index.d.ts +1 -0
- package/lib/index.js +1 -0
- package/lib/index.js.map +1 -1
- package/lib/server.d.ts +11 -0
- package/lib/server.js +66 -0
- package/lib/server.js.map +1 -0
- package/package.json +4 -3
package/README.md
CHANGED
|
@@ -15,6 +15,7 @@ function createClient<IAPI extends object>(
|
|
|
15
15
|
parameterValidators?: DelightRPC.ParameterValidators<IAPI>
|
|
16
16
|
expectedVersion?: `${number}.${number}.${number}`
|
|
17
17
|
channel?: string
|
|
18
|
+
timeout?: number
|
|
18
19
|
}
|
|
19
20
|
): [client: DelightRPC.ClientProxy<IAPI>, close: () => void]
|
|
20
21
|
```
|
|
@@ -26,6 +27,22 @@ function createBatchClient(
|
|
|
26
27
|
, options?: {
|
|
27
28
|
expectedVersion?: `${number}.${number}.${number}`
|
|
28
29
|
channel?: string
|
|
30
|
+
timeout?: number
|
|
29
31
|
}
|
|
30
32
|
): [client: DelightRPC.BatchClient, close: () => void]
|
|
31
33
|
```
|
|
34
|
+
|
|
35
|
+
### createServer
|
|
36
|
+
```ts
|
|
37
|
+
function createServer<IAPI extends object>(
|
|
38
|
+
api: DelightRPC.ImplementationOf<IAPI>
|
|
39
|
+
, socket: ExtraWebSocket
|
|
40
|
+
, options?: {
|
|
41
|
+
loggerLevel?: Level = Level.None
|
|
42
|
+
parameterValidators?: DelightRPC.ParameterValidators<IAPI>
|
|
43
|
+
version?: `${number}.${number}.${number}`
|
|
44
|
+
channel?: string
|
|
45
|
+
ownPropsOnly?: boolean
|
|
46
|
+
}
|
|
47
|
+
): () => void
|
|
48
|
+
```
|
package/lib/client.d.ts
CHANGED
|
@@ -1,14 +1,16 @@
|
|
|
1
1
|
import * as DelightRPC from 'delight-rpc';
|
|
2
2
|
import { CustomError } from '@blackglory/errors';
|
|
3
3
|
import { ExtraWebSocket } from 'extra-websocket';
|
|
4
|
-
export declare function createClient<IAPI extends object>(socket: ExtraWebSocket, { parameterValidators, expectedVersion, channel }?: {
|
|
4
|
+
export declare function createClient<IAPI extends object>(socket: ExtraWebSocket, { parameterValidators, expectedVersion, channel, timeout }?: {
|
|
5
5
|
parameterValidators?: DelightRPC.ParameterValidators<IAPI>;
|
|
6
6
|
expectedVersion?: `${number}.${number}.${number}`;
|
|
7
7
|
channel?: string;
|
|
8
|
+
timeout?: number;
|
|
8
9
|
}): [client: DelightRPC.ClientProxy<IAPI>, close: () => void];
|
|
9
|
-
export declare function createBatchClient(socket: ExtraWebSocket, { expectedVersion, channel }?: {
|
|
10
|
+
export declare function createBatchClient(socket: ExtraWebSocket, { expectedVersion, channel, timeout }?: {
|
|
10
11
|
expectedVersion?: `${number}.${number}.${number}`;
|
|
11
12
|
channel?: string;
|
|
13
|
+
timeout?: number;
|
|
12
14
|
}): [client: DelightRPC.BatchClient, close: () => void];
|
|
13
15
|
export declare class ClientClosed extends CustomError {
|
|
14
16
|
}
|
package/lib/client.js
CHANGED
|
@@ -29,7 +29,8 @@ const extra_promise_1 = require("extra-promise");
|
|
|
29
29
|
const errors_1 = require("@blackglory/errors");
|
|
30
30
|
const return_style_1 = require("return-style");
|
|
31
31
|
const prelude_1 = require("@blackglory/prelude");
|
|
32
|
-
|
|
32
|
+
const extra_abort_1 = require("extra-abort");
|
|
33
|
+
function createClient(socket, { parameterValidators, expectedVersion, channel, timeout } = {}) {
|
|
33
34
|
const pendings = {};
|
|
34
35
|
socket.addEventListener('message', handler);
|
|
35
36
|
const client = DelightRPC.createClient(async function send(request) {
|
|
@@ -37,7 +38,12 @@ function createClient(socket, { parameterValidators, expectedVersion, channel }
|
|
|
37
38
|
pendings[request.id] = res;
|
|
38
39
|
try {
|
|
39
40
|
socket.send(JSON.stringify(request));
|
|
40
|
-
|
|
41
|
+
if ((0, prelude_1.isUndefined)(timeout)) {
|
|
42
|
+
return await res;
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
return await (0, extra_abort_1.withAbortSignal)((0, extra_abort_1.timeoutSignal)(timeout), () => res);
|
|
46
|
+
}
|
|
41
47
|
}
|
|
42
48
|
finally {
|
|
43
49
|
delete pendings[request.id];
|
|
@@ -66,7 +72,7 @@ function createClient(socket, { parameterValidators, expectedVersion, channel }
|
|
|
66
72
|
}
|
|
67
73
|
}
|
|
68
74
|
exports.createClient = createClient;
|
|
69
|
-
function createBatchClient(socket, { expectedVersion, channel } = {}) {
|
|
75
|
+
function createBatchClient(socket, { expectedVersion, channel, timeout } = {}) {
|
|
70
76
|
const pendings = {};
|
|
71
77
|
socket.addEventListener('message', handler);
|
|
72
78
|
const client = new DelightRPC.BatchClient(async function send(request) {
|
|
@@ -74,7 +80,12 @@ function createBatchClient(socket, { expectedVersion, channel } = {}) {
|
|
|
74
80
|
pendings[request.id] = res;
|
|
75
81
|
try {
|
|
76
82
|
socket.send(JSON.stringify(request));
|
|
77
|
-
|
|
83
|
+
if ((0, prelude_1.isUndefined)(timeout)) {
|
|
84
|
+
return await res;
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
return await (0, extra_abort_1.withAbortSignal)((0, extra_abort_1.timeoutSignal)(timeout), () => res);
|
|
88
|
+
}
|
|
78
89
|
}
|
|
79
90
|
finally {
|
|
80
91
|
delete pendings[request.id];
|
package/lib/client.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,wDAAyC;AACzC,iDAAwC;AACxC,+CAAgD;AAGhD,+CAAwC;AACxC,
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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"}
|
package/lib/index.d.ts
CHANGED
package/lib/index.js
CHANGED
|
@@ -15,4 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./client"), exports);
|
|
18
|
+
__exportStar(require("./server"), exports);
|
|
18
19
|
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAwB"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAwB;AACxB,2CAAwB"}
|
package/lib/server.d.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import * as DelightRPC from 'delight-rpc';
|
|
2
|
+
import { ExtraWebSocket } from 'extra-websocket';
|
|
3
|
+
import { Level } from 'extra-logger';
|
|
4
|
+
export { Level } from 'extra-logger';
|
|
5
|
+
export declare function createServer<IAPI extends object>(api: DelightRPC.ImplementationOf<IAPI>, socket: ExtraWebSocket, { loggerLevel, parameterValidators, version, channel, ownPropsOnly }?: {
|
|
6
|
+
loggerLevel?: Level;
|
|
7
|
+
parameterValidators?: DelightRPC.ParameterValidators<IAPI>;
|
|
8
|
+
version?: `${number}.${number}.${number}`;
|
|
9
|
+
channel?: string;
|
|
10
|
+
ownPropsOnly?: boolean;
|
|
11
|
+
}): () => void;
|
package/lib/server.js
ADDED
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.createServer = exports.Level = void 0;
|
|
27
|
+
const DelightRPC = __importStar(require("delight-rpc"));
|
|
28
|
+
const return_style_1 = require("return-style");
|
|
29
|
+
const extra_logger_1 = require("extra-logger");
|
|
30
|
+
const prelude_1 = require("@blackglory/prelude");
|
|
31
|
+
var extra_logger_2 = require("extra-logger");
|
|
32
|
+
Object.defineProperty(exports, "Level", { enumerable: true, get: function () { return extra_logger_2.Level; } });
|
|
33
|
+
function createServer(api, socket, { loggerLevel = extra_logger_1.Level.None, parameterValidators, version, channel, ownPropsOnly } = {}) {
|
|
34
|
+
const logger = new extra_logger_1.Logger({
|
|
35
|
+
level: loggerLevel,
|
|
36
|
+
transport: new extra_logger_1.TerminalTransport()
|
|
37
|
+
});
|
|
38
|
+
socket.addEventListener('message', handler);
|
|
39
|
+
return () => socket.removeEventListener('message', handler);
|
|
40
|
+
async function handler(event) {
|
|
41
|
+
const data = event.data;
|
|
42
|
+
if ((0, prelude_1.isString)(data)) {
|
|
43
|
+
const request = (0, return_style_1.getResult)(() => JSON.parse(data));
|
|
44
|
+
if (DelightRPC.isRequest(request) || DelightRPC.isBatchRequest(request)) {
|
|
45
|
+
const response = await logger.infoTime(() => {
|
|
46
|
+
if (DelightRPC.isRequest(request)) {
|
|
47
|
+
return request.method.join('.');
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
return request.requests.map(x => x.method.join('.')).join(', ');
|
|
51
|
+
}
|
|
52
|
+
}, () => DelightRPC.createResponse(api, request, {
|
|
53
|
+
parameterValidators,
|
|
54
|
+
version,
|
|
55
|
+
channel,
|
|
56
|
+
ownPropsOnly
|
|
57
|
+
}));
|
|
58
|
+
if ((0, prelude_1.isntNull)(response)) {
|
|
59
|
+
socket.send(JSON.stringify(response));
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
exports.createServer = createServer;
|
|
66
|
+
//# sourceMappingURL=server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"server.js","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,wDAAyC;AAGzC,+CAAwC;AACxC,+CAA+D;AAC/D,iDAAwD;AAExD,6CAAoC;AAA3B,qGAAA,KAAK,OAAA;AAEd,SAAgB,YAAY,CAC1B,GAAsC,EACtC,MAAsB,EACtB,EAAE,WAAW,GAAG,oBAAK,CAAC,IAAI,EAAE,mBAAmB,EAAE,OAAO,EAAE,OAAO,EAAE,YAAY,KAM3E,EAAE;IAEN,MAAM,MAAM,GAAG,IAAI,qBAAM,CAAC;QACxB,KAAK,EAAE,WAAW;QAClB,SAAS,EAAE,IAAI,gCAAiB,EAAE;KACnC,CAAC,CAAA;IAEF,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,OAAO,CAAC,CAAA;IAC3C,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,OAAO,CAAC,CAAA;IAE3D,KAAK,UAAU,OAAO,CAAC,KAAmB;QACxC,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAA;QACvB,IAAI,IAAA,kBAAQ,EAAC,IAAI,CAAC,EAAE;YAClB,MAAM,OAAO,GAAG,IAAA,wBAAS,EAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAA;YACjD,IAAI,UAAU,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,UAAU,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE;gBACvE,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,QAAQ,CACpC,GAAG,EAAE;oBACH,IAAI,UAAU,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;wBACjC,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;qBAChC;yBAAM;wBACL,OAAO,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;qBAChE;gBACH,CAAC,EACD,GAAG,EAAE,CAAC,UAAU,CAAC,cAAc,CAC7B,GAAG,EACH,OAAO,EACP;oBACE,mBAAmB;oBACnB,OAAO;oBACP,OAAO;oBACP,YAAY;iBACb,CACF,CACF,CAAA;gBAED,IAAI,IAAA,kBAAQ,EAAC,QAAQ,CAAC,EAAE;oBACtB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAA;iBACtC;aACF;SACF;IACH,CAAC;AACH,CAAC;AAlDD,oCAkDC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@delight-rpc/extra-websocket",
|
|
3
|
-
"version": "0.1
|
|
3
|
+
"version": "0.2.1",
|
|
4
4
|
"description": "",
|
|
5
5
|
"keywords": [],
|
|
6
6
|
"files": [
|
|
@@ -41,7 +41,7 @@
|
|
|
41
41
|
"cross-env": "^7.0.3",
|
|
42
42
|
"delight-rpc": "^4.1.0",
|
|
43
43
|
"eslint": "8.16.0",
|
|
44
|
-
"extra-websocket": "^0.1
|
|
44
|
+
"extra-websocket": "^0.2.1",
|
|
45
45
|
"husky": "4",
|
|
46
46
|
"jest": "^27.5.1",
|
|
47
47
|
"npm-run-all": "^4.1.5",
|
|
@@ -58,12 +58,13 @@
|
|
|
58
58
|
"@blackglory/errors": "^2.2.1",
|
|
59
59
|
"@blackglory/prelude": "^0.1.1",
|
|
60
60
|
"@delight-rpc/protocol": "^2.2.0",
|
|
61
|
+
"extra-abort": "^0.1.2",
|
|
61
62
|
"extra-logger": "^0.6.8",
|
|
62
63
|
"extra-promise": "^2.0.0",
|
|
63
64
|
"return-style": "^1.0.0"
|
|
64
65
|
},
|
|
65
66
|
"peerDependencies": {
|
|
66
67
|
"delight-rpc": "^4.1.0",
|
|
67
|
-
"extra-websocket": "^0.1
|
|
68
|
+
"extra-websocket": "^0.2.1"
|
|
68
69
|
}
|
|
69
70
|
}
|