@mingzey/typedrpc 1.0.2 → 1.1.0
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/api.d.ts +2 -2
- package/dist/api.d.ts.map +1 -1
- package/dist/client.d.ts +1 -1
- package/dist/connection.d.ts +1 -1
- package/dist/connection.js +1 -1
- package/dist/{connecitons → connections}/basic.d.ts +1 -0
- package/dist/connections/basic.d.ts.map +1 -0
- package/dist/{connecitons → connections}/basic.js.map +1 -1
- package/dist/{connecitons → connections}/http.d.ts.map +1 -1
- package/dist/{connecitons → connections}/http.js.map +1 -1
- package/dist/{connecitons → connections}/socket.d.ts.map +1 -1
- package/dist/{connecitons → connections}/socket.js +10 -10
- package/dist/{connecitons → connections}/socket.js.map +1 -1
- package/dist/{connecitons → connections}/socketio.d.ts.map +1 -1
- package/dist/{connecitons → connections}/socketio.js +10 -10
- package/dist/{connecitons → connections}/socketio.js.map +1 -1
- package/dist/context.d.ts +1 -1
- package/dist/core.d.ts +5 -2
- package/dist/core.d.ts.map +1 -1
- package/dist/core.js +20 -13
- package/dist/core.js.map +1 -1
- package/dist/handler.d.ts +1 -1
- package/dist/index.d.ts +5 -5
- package/dist/index.js +5 -5
- package/dist/server.d.ts +6 -8
- package/dist/server.d.ts.map +1 -1
- package/dist/server.js +3 -1
- package/dist/server.js.map +1 -1
- package/package.json +28 -29
- package/dist/connecitons/basic.d.ts.map +0 -1
- package/dist/test/TestCase.d.ts +0 -6
- package/dist/test/TestCase.d.ts.map +0 -1
- package/dist/test/TestCase.js +0 -5
- package/dist/test/TestCase.js.map +0 -1
- package/dist/test/authorization.d.ts +0 -8
- package/dist/test/authorization.d.ts.map +0 -1
- package/dist/test/authorization.js +0 -169
- package/dist/test/authorization.js.map +0 -1
- package/dist/test/basic.d.ts +0 -7
- package/dist/test/basic.d.ts.map +0 -1
- package/dist/test/basic.js +0 -35
- package/dist/test/basic.js.map +0 -1
- package/dist/test/context.d.ts +0 -7
- package/dist/test/context.d.ts.map +0 -1
- package/dist/test/context.js +0 -55
- package/dist/test/context.js.map +0 -1
- package/dist/test/expressmix.d.ts +0 -7
- package/dist/test/expressmix.d.ts.map +0 -1
- package/dist/test/expressmix.js +0 -63
- package/dist/test/expressmix.js.map +0 -1
- package/dist/test/full-duplex.d.ts +0 -12
- package/dist/test/full-duplex.d.ts.map +0 -1
- package/dist/test/full-duplex.js +0 -77
- package/dist/test/full-duplex.js.map +0 -1
- package/dist/test/socket.d.ts +0 -8
- package/dist/test/socket.d.ts.map +0 -1
- package/dist/test/socket.js +0 -71
- package/dist/test/socket.js.map +0 -1
- package/dist/test/socketio.d.ts +0 -12
- package/dist/test/socketio.d.ts.map +0 -1
- package/dist/test/socketio.js +0 -77
- package/dist/test/socketio.js.map +0 -1
- package/dist/test.d.ts +0 -2
- package/dist/test.d.ts.map +0 -1
- package/dist/test.js +0 -33
- package/dist/test.js.map +0 -1
- package/src/api.ts +0 -72
- package/src/client.ts +0 -77
- package/src/connecitons/basic.ts +0 -49
- package/src/connecitons/http.ts +0 -184
- package/src/connecitons/socket.ts +0 -247
- package/src/connecitons/socketio.ts +0 -200
- package/src/connection.ts +0 -10
- package/src/context.ts +0 -18
- package/src/core.ts +0 -130
- package/src/define.ts +0 -63
- package/src/handler.ts +0 -202
- package/src/index.ts +0 -41
- package/src/packet.ts +0 -77
- package/src/server.ts +0 -82
- package/src/test/TestCase.ts +0 -6
- package/src/test/authorization.ts +0 -197
- package/src/test/basic.ts +0 -44
- package/src/test/context.ts +0 -64
- package/src/test/expressmix.ts +0 -81
- package/src/test/socket.ts +0 -90
- package/src/test/socketio.ts +0 -96
- package/src/test.ts +0 -35
- package/src/utils.ts +0 -95
- /package/dist/{connecitons → connections}/basic.js +0 -0
- /package/dist/{connecitons → connections}/http.d.ts +0 -0
- /package/dist/{connecitons → connections}/http.js +0 -0
- /package/dist/{connecitons → connections}/socket.d.ts +0 -0
- /package/dist/{connecitons → connections}/socketio.d.ts +0 -0
package/dist/test/socketio.js
DELETED
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 测试全双工通信实现双向调用
|
|
3
|
-
* TypedRPC的默认实现是基于http的,全双工必须实现自定义的Provider
|
|
4
|
-
* 这里使用socket.io作为Provider的底层通讯
|
|
5
|
-
*/
|
|
6
|
-
import { TestCase } from "./TestCase.js";
|
|
7
|
-
import { TypedRPCAPIDefine, TypedRPCConnectionProviderSocketIO } from "../index.js";
|
|
8
|
-
import { TypedRPCServer } from "../index.js";
|
|
9
|
-
import { TypedRPCClient } from "../index.js";
|
|
10
|
-
const ServerAPIDefine = new TypedRPCAPIDefine;
|
|
11
|
-
const ClientAPIDefine = new TypedRPCAPIDefine;
|
|
12
|
-
const server = new TypedRPCServer({
|
|
13
|
-
local: ServerAPIDefine,
|
|
14
|
-
remote: ClientAPIDefine,
|
|
15
|
-
connection: {
|
|
16
|
-
provider: new TypedRPCConnectionProviderSocketIO(),
|
|
17
|
-
}
|
|
18
|
-
});
|
|
19
|
-
server.hook('math', 'add', {
|
|
20
|
-
handler: (a, b) => {
|
|
21
|
-
return a + b;
|
|
22
|
-
}
|
|
23
|
-
});
|
|
24
|
-
const client = new TypedRPCClient({
|
|
25
|
-
local: ClientAPIDefine,
|
|
26
|
-
remote: ServerAPIDefine,
|
|
27
|
-
connection: {
|
|
28
|
-
provider: new TypedRPCConnectionProviderSocketIO(),
|
|
29
|
-
}
|
|
30
|
-
});
|
|
31
|
-
client.hook('status', 'time', {
|
|
32
|
-
handler: () => {
|
|
33
|
-
return Date.now();
|
|
34
|
-
}
|
|
35
|
-
});
|
|
36
|
-
export default class TestSocketIO extends TestCase {
|
|
37
|
-
name() {
|
|
38
|
-
return "SocketIO";
|
|
39
|
-
}
|
|
40
|
-
async run() {
|
|
41
|
-
let requestToServer;
|
|
42
|
-
let requestToClient;
|
|
43
|
-
requestToClient = new Promise((resolve) => {
|
|
44
|
-
server.emitter.on('connection', async (connectionToClient) => {
|
|
45
|
-
const apiToClient = server.getAPI(connectionToClient);
|
|
46
|
-
const result = await apiToClient.status.time.call();
|
|
47
|
-
if (result != null) {
|
|
48
|
-
resolve(true);
|
|
49
|
-
}
|
|
50
|
-
else {
|
|
51
|
-
resolve(false);
|
|
52
|
-
}
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
|
-
await server.listen({
|
|
56
|
-
port: 3698,
|
|
57
|
-
});
|
|
58
|
-
requestToServer = new Promise(async (resolve) => {
|
|
59
|
-
const connectionToServer = await client.connect("localhost:3698");
|
|
60
|
-
const apiToServer = client.getAPI(connectionToServer);
|
|
61
|
-
const result = await apiToServer.math.add.call(1, 2);
|
|
62
|
-
if (result == 3) {
|
|
63
|
-
resolve(true);
|
|
64
|
-
}
|
|
65
|
-
else {
|
|
66
|
-
resolve(false);
|
|
67
|
-
}
|
|
68
|
-
});
|
|
69
|
-
const resultToClient = await requestToClient;
|
|
70
|
-
const resultToServer = await requestToServer;
|
|
71
|
-
return resultToClient && resultToServer;
|
|
72
|
-
}
|
|
73
|
-
async finally() {
|
|
74
|
-
await server.close();
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
//# sourceMappingURL=socketio.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"socketio.js","sourceRoot":"","sources":["../../src/test/socketio.ts"],"names":[],"mappings":"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"}
|
package/dist/test.d.ts
DELETED
package/dist/test.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test.d.ts","sourceRoot":"","sources":["../src/test.ts"],"names":[],"mappings":""}
|
package/dist/test.js
DELETED
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
const testList = [
|
|
2
|
-
import('./test/basic.js'),
|
|
3
|
-
import('./test/context.js'),
|
|
4
|
-
import('./test/socketio.js'),
|
|
5
|
-
import('./test/authorization.js'),
|
|
6
|
-
import('./test/expressmix.js'),
|
|
7
|
-
import('./test/socket.js'),
|
|
8
|
-
];
|
|
9
|
-
async function main() {
|
|
10
|
-
for (let i of testList) {
|
|
11
|
-
let exp = await i;
|
|
12
|
-
let test = new (exp.default)();
|
|
13
|
-
let result = await test.run().catch((e) => {
|
|
14
|
-
console.log(`Test:${test.name()} failed. ${e}`);
|
|
15
|
-
throw e;
|
|
16
|
-
});
|
|
17
|
-
await test.finally();
|
|
18
|
-
if (result) {
|
|
19
|
-
console.log(`\x1b[32m[PASS]\x1b[0m ${test.name()}`);
|
|
20
|
-
}
|
|
21
|
-
else {
|
|
22
|
-
console.log(`\x1b[31m[FAIL]\x1b[0m ${test.name()}`);
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
main().then(() => {
|
|
27
|
-
console.log('TypedRPC test finished.');
|
|
28
|
-
}).catch((e) => {
|
|
29
|
-
console.log(`TypedRPC test failed. ${e}`);
|
|
30
|
-
throw e;
|
|
31
|
-
});
|
|
32
|
-
export {};
|
|
33
|
-
//# sourceMappingURL=test.js.map
|
package/dist/test.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test.js","sourceRoot":"","sources":["../src/test.ts"],"names":[],"mappings":"AAEA,MAAM,QAAQ,GAAG;IACb,MAAM,CAAC,iBAAiB,CAAC;IACzB,MAAM,CAAC,mBAAmB,CAAC;IAC3B,MAAM,CAAC,oBAAoB,CAAC;IAC5B,MAAM,CAAC,yBAAyB,CAAC;IACjC,MAAM,CAAC,sBAAsB,CAAC;IAC9B,MAAM,CAAC,kBAAkB,CAAC;CAC7B,CAAA;AAED,KAAK,UAAU,IAAI;IACf,KAAI,IAAI,CAAC,IAAI,QAAQ,EAAC;QAClB,IAAI,GAAG,GAAG,MAAM,CAAC,CAAC;QAClB,IAAI,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,EAAc,CAAC;QAC3C,IAAI,MAAM,GAAG,MAAM,IAAI,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;YACtC,OAAO,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,IAAI,EAAE,YAAY,CAAC,EAAE,CAAC,CAAC;YAChD,MAAM,CAAC,CAAC;QACZ,CAAC,CAAC,CAAA;QACF,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;QACrB,IAAG,MAAM,EAAC;YACN,OAAO,CAAC,GAAG,CAAC,yBAAyB,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;SACvD;aAAI;YACD,OAAO,CAAC,GAAG,CAAC,yBAAyB,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;SACvD;KAEJ;AACL,CAAC;AAED,IAAI,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;IACb,OAAO,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAC;AAC3C,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;IACX,OAAO,CAAC,GAAG,CAAC,yBAAyB,CAAC,EAAE,CAAC,CAAC;IAC1C,MAAM,CAAC,CAAC;AACZ,CAAC,CAAC,CAAA"}
|
package/src/api.ts
DELETED
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
import type { TypedRPCAPIDefine } from "./define.js";
|
|
2
|
-
import type { TypedRPCRequestPacket, TypedRPCResponsePacket } from "./packet.js";
|
|
3
|
-
import type { TypedRPCDefineToTypedRPCAPI } from "./utils.js";
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
class TypedRPCAPI<T extends TypedRPCAPIDefine<any>>{
|
|
7
|
-
constructor(){
|
|
8
|
-
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
interface(callback:(context:{
|
|
12
|
-
serviceName:string,methodName:string,args:any[]
|
|
13
|
-
}) => Promise<{
|
|
14
|
-
request:TypedRPCRequestPacket,
|
|
15
|
-
response:TypedRPCResponsePacket,
|
|
16
|
-
}>):TypedRPCDefineToTypedRPCAPI<T>{
|
|
17
|
-
return new Proxy({}, {
|
|
18
|
-
get(target, serviceName, receiver) {
|
|
19
|
-
if (typeof serviceName !== 'string') {
|
|
20
|
-
return Reflect.get(target, serviceName, receiver);
|
|
21
|
-
}
|
|
22
|
-
return new Proxy({}, {
|
|
23
|
-
get(target, methodName, receiver) {
|
|
24
|
-
if (typeof methodName !== 'string') {
|
|
25
|
-
return Reflect.get(target, methodName, receiver);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
const path = `${serviceName}.${methodName}`;
|
|
29
|
-
const id = `${serviceName}.${methodName}`;
|
|
30
|
-
|
|
31
|
-
return {
|
|
32
|
-
call: async (...args: any[]) => {
|
|
33
|
-
const result = await callback({
|
|
34
|
-
serviceName:serviceName,
|
|
35
|
-
methodName:methodName,
|
|
36
|
-
args:args,
|
|
37
|
-
});
|
|
38
|
-
if(result.response.error){
|
|
39
|
-
throw result.response.error;
|
|
40
|
-
}
|
|
41
|
-
return result.response.result;
|
|
42
|
-
},
|
|
43
|
-
request:async (config:{
|
|
44
|
-
args?:any[],
|
|
45
|
-
callback?:(result:any,req:TypedRPCRequestPacket,res:TypedRPCResponsePacket) => void,
|
|
46
|
-
error?:(error:any,req:TypedRPCRequestPacket,res:TypedRPCResponsePacket) => void,
|
|
47
|
-
}) => {
|
|
48
|
-
const result = await callback({
|
|
49
|
-
serviceName:serviceName,
|
|
50
|
-
methodName:methodName,
|
|
51
|
-
args:config.args || [],
|
|
52
|
-
});
|
|
53
|
-
if(result.response.error){
|
|
54
|
-
config.error?.(result.response.error,result.request,result.response);
|
|
55
|
-
}else{
|
|
56
|
-
config.callback?.(result.response.result,result.request,result.response);
|
|
57
|
-
}
|
|
58
|
-
},
|
|
59
|
-
id,
|
|
60
|
-
path
|
|
61
|
-
};
|
|
62
|
-
}
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
}) as TypedRPCDefineToTypedRPCAPI<T>;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
export {
|
|
71
|
-
TypedRPCAPI
|
|
72
|
-
}
|
package/src/client.ts
DELETED
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
import { TypedRPCAPI } from "./api.js";
|
|
2
|
-
import type { TypedRPCConnection, TypedRPCConnectionProvider } from "./connecitons/basic.js";
|
|
3
|
-
import { TypedRPCConnectionProviderDefault } from "./connection.js";
|
|
4
|
-
import { TypedRPCCore } from "./core.js";
|
|
5
|
-
import { TypedRPCAPIDefine } from "./define.js";
|
|
6
|
-
|
|
7
|
-
import { TypedEmitter, type TypedRPCDefineMethodBody, type TypedRPCDefineMethodName, type TypedRPCDefineServiceInstance, type TypedRPCDefineServiceName, type TypedRPCDefineToTypedRPCAPI } from "./utils.js";
|
|
8
|
-
|
|
9
|
-
type TypedRPCClientConfig<T extends TypedRPCAPIDefine<any>,R extends TypedRPCAPIDefine<any>> = {
|
|
10
|
-
local?:T,
|
|
11
|
-
remote?:R,
|
|
12
|
-
connection?:{
|
|
13
|
-
provider:TypedRPCConnectionProvider,
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
type TypedRPCClientEvents = {
|
|
18
|
-
// connection:(connection:TypedRPCConnection)=>void,
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
class TypedRPCClient<T extends TypedRPCAPIDefine<any>,R extends TypedRPCAPIDefine<any>> {
|
|
22
|
-
|
|
23
|
-
public emitter = new TypedEmitter<TypedRPCClientEvents>();
|
|
24
|
-
private config:TypedRPCClientConfig<T,R>;
|
|
25
|
-
public core:TypedRPCCore;
|
|
26
|
-
|
|
27
|
-
constructor(config?:TypedRPCClientConfig<T,R>){
|
|
28
|
-
const defaultConfig:TypedRPCClientConfig<T,R> = {
|
|
29
|
-
connection:{
|
|
30
|
-
provider:new TypedRPCConnectionProviderDefault(),
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
this.config = {...defaultConfig,...config};
|
|
34
|
-
this.core = new TypedRPCCore(this.config);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
hook<S extends TypedRPCDefineServiceName<T>,M extends TypedRPCDefineMethodName<T,S>>(serviceName:S,methodName:M,config:{
|
|
38
|
-
handler:TypedRPCDefineMethodBody<T,S,M>,
|
|
39
|
-
bind?:any,
|
|
40
|
-
}){
|
|
41
|
-
return this.core.hook(serviceName,methodName,config);
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
hookService<S extends TypedRPCDefineServiceName<T>>(serviceName:S,instance:TypedRPCDefineServiceInstance<T,S>){
|
|
45
|
-
const methodList = TypedRPCAPIDefine.getMethodList(instance);
|
|
46
|
-
for(let methodName of methodList){
|
|
47
|
-
this.hook(serviceName,methodName as TypedRPCDefineMethodName<T,S>,{
|
|
48
|
-
handler:instance[methodName],
|
|
49
|
-
bind:instance,
|
|
50
|
-
})
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
get use(){
|
|
55
|
-
return this.core.handler.use.bind(this.core.handler);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
get connect(){
|
|
59
|
-
return this.core.connect.bind(this.core);
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
getAPI(connection:TypedRPCConnection):TypedRPCDefineToTypedRPCAPI<R>{
|
|
63
|
-
const api = new TypedRPCAPI<R>();
|
|
64
|
-
return api.interface(async (context) => {
|
|
65
|
-
return await this.core.request({
|
|
66
|
-
connection,
|
|
67
|
-
serviceName:context.serviceName,
|
|
68
|
-
methodName:context.methodName,
|
|
69
|
-
args:context.args,
|
|
70
|
-
})
|
|
71
|
-
})
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
export {
|
|
76
|
-
TypedRPCClient,
|
|
77
|
-
}
|
package/src/connecitons/basic.ts
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { TypedEmitter } from "../utils.js";
|
|
2
|
-
|
|
3
|
-
type TypedRPCConnectionEvents = {
|
|
4
|
-
/** 有新的请求进入时,应该由Provider调起 */
|
|
5
|
-
request:(context:{
|
|
6
|
-
data:string,
|
|
7
|
-
response:(data:string) => void,
|
|
8
|
-
}) => void;
|
|
9
|
-
}
|
|
10
|
-
abstract class TypedRPCConnection{
|
|
11
|
-
public emitter = new TypedEmitter<TypedRPCConnectionEvents>();
|
|
12
|
-
abstract request(data:string):Promise<string>;
|
|
13
|
-
/** 获取连接的id */
|
|
14
|
-
abstract getId():string;
|
|
15
|
-
/** 关闭连接 */
|
|
16
|
-
abstract close():boolean;
|
|
17
|
-
/** 是否关闭 */
|
|
18
|
-
abstract isClosed():boolean;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
type TypedRPCConnectionProviderEvents = {
|
|
22
|
-
/** 新的连接建立时 */
|
|
23
|
-
connection:(connection:TypedRPCConnection) => void,
|
|
24
|
-
}
|
|
25
|
-
abstract class TypedRPCConnectionProvider{
|
|
26
|
-
public emitter = new TypedEmitter<TypedRPCConnectionProviderEvents>();
|
|
27
|
-
/**
|
|
28
|
-
* Server用,用于监听一个端口
|
|
29
|
-
*/
|
|
30
|
-
abstract listen(config:{
|
|
31
|
-
port:number,
|
|
32
|
-
hostname?:string,
|
|
33
|
-
}):Promise<boolean>;
|
|
34
|
-
|
|
35
|
-
/**
|
|
36
|
-
* Server用,用于关闭监听的端口
|
|
37
|
-
*/
|
|
38
|
-
abstract close():Promise<boolean>;
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Client用,用于建立一个连接
|
|
42
|
-
*/
|
|
43
|
-
abstract connect(target:string):Promise<TypedRPCConnection>;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
export {
|
|
47
|
-
TypedRPCConnection,
|
|
48
|
-
TypedRPCConnectionProvider,
|
|
49
|
-
}
|
package/src/connecitons/http.ts
DELETED
|
@@ -1,184 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { IdMaker } from "../utils.js";
|
|
3
|
-
import { TypedRPCConnection, TypedRPCConnectionProvider } from "./basic.js";
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
/** 基于http的connection和provider */
|
|
7
|
-
class TypedRPCConnectionHTTP extends TypedRPCConnection{
|
|
8
|
-
|
|
9
|
-
private id:string;
|
|
10
|
-
private closed:boolean = false;
|
|
11
|
-
|
|
12
|
-
constructor(private config:{
|
|
13
|
-
side:'client'|'server',
|
|
14
|
-
target?:string,
|
|
15
|
-
}){
|
|
16
|
-
super();
|
|
17
|
-
this.id = this.makeId();
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
private makeId(){
|
|
21
|
-
return IdMaker.makeId();
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
async request(data: string): Promise<string> {
|
|
25
|
-
if(this.config.side == 'server'){
|
|
26
|
-
throw new Error("The server connection cannot send RPC requests because the current connection is not bidirectional");
|
|
27
|
-
}
|
|
28
|
-
if(!this.config.target){
|
|
29
|
-
throw new Error("Client connection must have target");
|
|
30
|
-
}
|
|
31
|
-
// 发起请求
|
|
32
|
-
const response = await fetch(`http://${this.config.target}`,{
|
|
33
|
-
method:'POST',
|
|
34
|
-
body:data,
|
|
35
|
-
headers:{
|
|
36
|
-
// 必须指定typedrpc为1,否则服务器会认为这是一个普通的POST请求
|
|
37
|
-
typedrpc:'1',
|
|
38
|
-
}
|
|
39
|
-
}).then((res) => {
|
|
40
|
-
return res.text();
|
|
41
|
-
})
|
|
42
|
-
return response;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
getId(): string {
|
|
46
|
-
return this.id;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
close(): boolean {
|
|
50
|
-
this.closed = true;
|
|
51
|
-
return true;// http connection 关闭时,直接返回true
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
isClosed(): boolean {
|
|
55
|
-
return this.closed;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
type TypedRPCConnectionProviderHTTPServer = import('http').Server;
|
|
61
|
-
|
|
62
|
-
type TypedRPCConnectionProviderHTTPConfig = {
|
|
63
|
-
server?:TypedRPCConnectionProviderHTTPServer,
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
type TypedRPCConnectionProviderHTTPMiddleware = (req:any,res:any) => void;
|
|
67
|
-
|
|
68
|
-
class TypedRPCConnectionProviderHTTP extends TypedRPCConnectionProvider{
|
|
69
|
-
|
|
70
|
-
public config:TypedRPCConnectionProviderHTTPConfig;
|
|
71
|
-
public server:TypedRPCConnectionProviderHTTPServer | null = null;
|
|
72
|
-
private middlewares:TypedRPCConnectionProviderHTTPMiddleware[] = [];
|
|
73
|
-
|
|
74
|
-
constructor(config?:TypedRPCConnectionProviderHTTPConfig){
|
|
75
|
-
super();
|
|
76
|
-
const defaultConfig:TypedRPCConnectionProviderHTTPConfig = {
|
|
77
|
-
|
|
78
|
-
}
|
|
79
|
-
this.config = {...defaultConfig,...config};
|
|
80
|
-
this.server = this.config.server || null;
|
|
81
|
-
if(this.server){
|
|
82
|
-
this.initServer(this.server);
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
public use(middleware:TypedRPCConnectionProviderHTTPMiddleware){
|
|
87
|
-
this.middlewares.push(middleware);
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
private initServer(server:TypedRPCConnectionProviderHTTPServer){
|
|
91
|
-
server.on('request',(req,res) => {
|
|
92
|
-
// 如果请求是不是POST,直接忽略
|
|
93
|
-
// 如果请求头没有typedrpc=1,直接忽略
|
|
94
|
-
if(req.method !== 'POST'
|
|
95
|
-
|| req.headers['typedrpc'] !== '1'
|
|
96
|
-
){
|
|
97
|
-
// 调用中间件
|
|
98
|
-
this.middlewares.forEach((middleware) => {
|
|
99
|
-
middleware(req,res);
|
|
100
|
-
})
|
|
101
|
-
return;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
let data = '';
|
|
105
|
-
req.on('data',(chunk) => {
|
|
106
|
-
data += chunk.toString();
|
|
107
|
-
})
|
|
108
|
-
req.on('end',() => {
|
|
109
|
-
// 创建一个connection
|
|
110
|
-
const connection = new TypedRPCConnectionHTTP({
|
|
111
|
-
side:'server',
|
|
112
|
-
});
|
|
113
|
-
this.emitter.emit('connection',connection);
|
|
114
|
-
connection.emitter.emit('request',{
|
|
115
|
-
data:data,
|
|
116
|
-
response:(data) => {
|
|
117
|
-
res.end(data);
|
|
118
|
-
connection.close();
|
|
119
|
-
}
|
|
120
|
-
})
|
|
121
|
-
})
|
|
122
|
-
})
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
private async createServer():Promise<TypedRPCConnectionProviderHTTPServer>{
|
|
126
|
-
const httpSupport = await import("http").catch(() => null);
|
|
127
|
-
if(!httpSupport){
|
|
128
|
-
throw new Error("http module not found");
|
|
129
|
-
}
|
|
130
|
-
return httpSupport.default.createServer();
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
async listen(config:{
|
|
134
|
-
port:number,
|
|
135
|
-
host?:string,
|
|
136
|
-
}): Promise<boolean> {
|
|
137
|
-
if(!this.server){
|
|
138
|
-
this.server = await this.createServer();
|
|
139
|
-
this.initServer(this.server);
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
return new Promise<boolean>((resolve) => {
|
|
143
|
-
if(!this.server){
|
|
144
|
-
throw new Error("Listen before server created");
|
|
145
|
-
}
|
|
146
|
-
this.server.listen({
|
|
147
|
-
port:config.port,
|
|
148
|
-
host:config.host,
|
|
149
|
-
},() => {
|
|
150
|
-
resolve(true);
|
|
151
|
-
});
|
|
152
|
-
})
|
|
153
|
-
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
close(): Promise<boolean> {
|
|
157
|
-
return new Promise<boolean>((resolve,reject) => {
|
|
158
|
-
if(!this.server){
|
|
159
|
-
return true;
|
|
160
|
-
}
|
|
161
|
-
this.server.close((err) => {
|
|
162
|
-
if(err){
|
|
163
|
-
reject(err);
|
|
164
|
-
}
|
|
165
|
-
resolve(true);
|
|
166
|
-
})
|
|
167
|
-
this.server = null;
|
|
168
|
-
})
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
async connect(target: string): Promise<TypedRPCConnectionHTTP> {
|
|
172
|
-
const connection = new TypedRPCConnectionHTTP({
|
|
173
|
-
side:'client',
|
|
174
|
-
target,
|
|
175
|
-
});
|
|
176
|
-
this.emitter.emit('connection',connection);
|
|
177
|
-
return connection;
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
export {
|
|
182
|
-
TypedRPCConnectionHTTP,
|
|
183
|
-
TypedRPCConnectionProviderHTTP,
|
|
184
|
-
}
|