@spider-mesh/core 1.0.9965 → 2.0.2
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/build/const.d.ts +1 -0
- package/build/const.js +2 -0
- package/build/const.js.map +1 -0
- package/build/src/SpiderMesh.d.ts +27 -41
- package/build/src/SpiderMesh.js +314 -381
- package/build/src/SpiderMesh.js.map +1 -1
- package/build/src/decorators/BeforeMicroserviceOnline.d.ts +4 -0
- package/build/src/decorators/BeforeMicroserviceOnline.js +10 -0
- package/build/src/decorators/BeforeMicroserviceOnline.js.map +1 -0
- package/build/src/decorators/LimitConcurrentRunning.d.ts +2 -3
- package/build/src/decorators/LimitConcurrentRunning.js +2 -22
- package/build/src/decorators/LimitConcurrentRunning.js.map +1 -1
- package/build/src/decorators/Microservice.d.ts +10 -24
- package/build/src/decorators/Microservice.js +12 -31
- package/build/src/decorators/Microservice.js.map +1 -1
- package/build/src/decorators/NestJSExposeMicroservice.d.ts +5 -0
- package/build/src/decorators/NestJSExposeMicroservice.js +14 -0
- package/build/src/decorators/NestJSExposeMicroservice.js.map +1 -0
- package/build/src/decorators/NestJSLinkEvent.d.ts +9 -0
- package/build/src/decorators/NestJSLinkEvent.js +7 -0
- package/build/src/decorators/NestJSLinkEvent.js.map +1 -0
- package/build/src/decorators/NestJSLinkMicroservice.d.ts +6 -0
- package/build/src/decorators/NestJSLinkMicroservice.js +7 -0
- package/build/src/decorators/NestJSLinkMicroservice.js.map +1 -0
- package/build/src/helpers/LimitConcurrency.d.ts +3 -0
- package/build/src/helpers/LimitConcurrency.js +34 -0
- package/build/src/helpers/LimitConcurrency.js.map +1 -0
- package/build/src/helpers/MicroserviceException.d.ts +8 -0
- package/build/src/helpers/MicroserviceException.js +9 -0
- package/build/src/helpers/MicroserviceException.js.map +1 -0
- package/build/src/helpers/MicroserviceNotFound copy.d.ts +5 -0
- package/build/src/helpers/MicroserviceNotFound copy.js +8 -0
- package/build/src/helpers/MicroserviceNotFound copy.js.map +1 -0
- package/build/src/helpers/MicroserviceNotFound.d.ts +5 -0
- package/build/src/helpers/MicroserviceNotFound.js +8 -0
- package/build/src/helpers/MicroserviceNotFound.js.map +1 -0
- package/build/src/helpers/MicroserviceOfflineException.d.ts +5 -0
- package/build/src/helpers/MicroserviceOfflineException.js +8 -0
- package/build/src/helpers/MicroserviceOfflineException.js.map +1 -0
- package/build/src/helpers/MicroserviceRpcTimeout.d.ts +5 -0
- package/build/src/helpers/MicroserviceRpcTimeout.js +8 -0
- package/build/src/helpers/MicroserviceRpcTimeout.js.map +1 -0
- package/build/src/helpers/randomUUID.d.ts +1 -0
- package/build/src/helpers/randomUUID.js +13 -0
- package/build/src/helpers/randomUUID.js.map +1 -0
- package/build/src/helpers/sleep.js +1 -1
- package/build/src/helpers/sleep.js.map +1 -1
- package/build/src/index.d.ts +16 -12
- package/build/src/index.js +16 -9
- package/build/src/index.js.map +1 -1
- package/build/src/interfaces/DiscoveryTransporter.d.ts +5 -0
- package/build/src/interfaces/DiscoveryTransporter.js +3 -0
- package/build/src/interfaces/DiscoveryTransporter.js.map +1 -0
- package/build/src/interfaces/PubsubTransporter.d.ts +10 -0
- package/build/src/interfaces/PubsubTransporter.js +3 -0
- package/build/src/interfaces/PubsubTransporter.js.map +1 -0
- package/build/src/interfaces/RemoteService.d.ts +12 -18
- package/build/src/interfaces/RpcTransporter.d.ts +30 -0
- package/build/src/interfaces/RpcTransporter.js +3 -0
- package/build/src/interfaces/RpcTransporter.js.map +1 -0
- package/build/src/interfaces/SpiderMeshNode.d.ts +14 -18
- package/build/tsconfig.tsbuildinfo +1 -0
- package/package.json +14 -9
- package/tsconfig.json +7 -3
- package/build/src/Encoder.d.ts +0 -5
- package/build/src/Encoder.js +0 -42
- package/build/src/Encoder.js.map +0 -1
- package/build/src/RPCOptions.d.ts +0 -11
- package/build/src/RPCOptions.js +0 -13
- package/build/src/RPCOptions.js.map +0 -1
- package/build/src/builtin-transporter/BuiltinTransporter.d.ts +0 -15
- package/build/src/builtin-transporter/BuiltinTransporter.js +0 -157
- package/build/src/builtin-transporter/BuiltinTransporter.js.map +0 -1
- package/build/src/builtin-transporter/RxjsTcpServer.d.ts +0 -11
- package/build/src/builtin-transporter/RxjsTcpServer.js +0 -31
- package/build/src/builtin-transporter/RxjsTcpServer.js.map +0 -1
- package/build/src/builtin-transporter/RxjsTcpSocket.d.ts +0 -18
- package/build/src/builtin-transporter/RxjsTcpSocket.js +0 -65
- package/build/src/builtin-transporter/RxjsTcpSocket.js.map +0 -1
- package/build/src/builtin-transporter/RxjsUdpBroadcaster.d.ts +0 -19
- package/build/src/builtin-transporter/RxjsUdpBroadcaster.js +0 -48
- package/build/src/builtin-transporter/RxjsUdpBroadcaster.js.map +0 -1
- package/build/src/const.d.ts +0 -6
- package/build/src/const.js +0 -8
- package/build/src/const.js.map +0 -1
- package/build/src/decorators/DeepProxy.d.ts +0 -7
- package/build/src/decorators/DeepProxy.js +0 -24
- package/build/src/decorators/DeepProxy.js.map +0 -1
- package/build/src/decorators/ListenEvent.d.ts +0 -17
- package/build/src/decorators/ListenEvent.js +0 -23
- package/build/src/decorators/ListenEvent.js.map +0 -1
- package/build/src/decorators/OnMicroserviceReady.d.ts +0 -6
- package/build/src/decorators/OnMicroserviceReady.js +0 -14
- package/build/src/decorators/OnMicroserviceReady.js.map +0 -1
- package/build/src/helpers/waitFirstEvent.d.ts +0 -3
- package/build/src/helpers/waitFirstEvent.js +0 -5
- package/build/src/helpers/waitFirstEvent.js.map +0 -1
- package/build/src/interfaces/SpiderMeshTransporter.d.ts +0 -24
- package/build/src/interfaces/SpiderMeshTransporter.js +0 -2
- package/build/src/interfaces/SpiderMeshTransporter.js.map +0 -1
- package/yarn.lock +0 -134
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PubsubTransporter.js","sourceRoot":"","sources":["../../../src/interfaces/PubsubTransporter.ts"],"names":[],"mappings":"AASA,MAAM,OAAgB,iBAAiB;CAItC"}
|
|
@@ -1,27 +1,21 @@
|
|
|
1
|
-
import { Observable } from "rxjs";
|
|
2
|
-
import { RPCOptions } from "../RPCOptions.js";
|
|
1
|
+
import { Observable, Subject } from "rxjs";
|
|
3
2
|
import { SpiderMeshNode } from "./SpiderMeshNode.js";
|
|
3
|
+
import { RpcOptions } from "./RpcTransporter.js";
|
|
4
4
|
export type RemoteService<T = {
|
|
5
5
|
[key: string]: any;
|
|
6
|
-
}> = ({
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
Awaited<ReturnType<T[K]>> | null
|
|
12
|
-
]) : null;
|
|
13
|
-
};
|
|
6
|
+
}, Fallback = null> = ({
|
|
7
|
+
wait$: (fn?: (nodes: SpiderMeshNode[]) => boolean | Promise<boolean>) => Promise<void>;
|
|
8
|
+
set: <F>(options: Partial<RpcOptions<F>>) => RemoteService<T, F>;
|
|
9
|
+
nodes: SpiderMeshNode[];
|
|
10
|
+
watch$: () => Subject<void>;
|
|
14
11
|
} & {
|
|
15
|
-
[K in keyof T as (T[K] extends (...args: any) => any ? K : '')]: T[K] extends (...args: any) => any ? ((...args: Parameters<T[K]>) => Promise<Awaited<ReturnType<T[K]
|
|
12
|
+
[K in keyof T as (T[K] extends (...args: any) => any ? K : '')]: T[K] extends (...args: any) => any ? ((...args: Parameters<T[K]>) => ReturnType<T[K]> extends (Observable<any> | Promise<Observable<any>>) ? Awaited<ReturnType<T[K]> | Fallback> : Promise<Awaited<ReturnType<T[K]> | Fallback>>) : null;
|
|
16
13
|
} & {
|
|
17
|
-
[key in keyof
|
|
18
|
-
} & {
|
|
19
|
-
$list_nodes: () => SpiderMeshNode[];
|
|
20
|
-
} & {
|
|
21
|
-
[key in keyof T as (key extends string ? `$batch_${key}` : string)]: T[key] extends ((...args: any) => any) ? ((...args: Parameters<T[key]>) => Observable<{
|
|
14
|
+
[key in keyof T as (key extends string ? `__batch__${key}` : string)]: T[key] extends ((...args: any) => any) ? ((...args: Parameters<T[key]>) => Observable<{
|
|
22
15
|
node: SpiderMeshNode;
|
|
23
16
|
data: Awaited<ReturnType<T[key]>>;
|
|
17
|
+
} | {
|
|
18
|
+
node: SpiderMeshNode;
|
|
19
|
+
error: Error;
|
|
24
20
|
}>) : T[key];
|
|
25
|
-
} & {
|
|
26
|
-
$watch: () => Observable<SpiderMeshNode>;
|
|
27
21
|
});
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { Observable } from "rxjs";
|
|
2
|
+
import { SpiderMeshNode } from "./SpiderMeshNode.js";
|
|
3
|
+
export type RpcRoutingOptions = {
|
|
4
|
+
[key: string]: string | number | boolean;
|
|
5
|
+
};
|
|
6
|
+
export type RpcOptions<T = any> = {
|
|
7
|
+
service: string;
|
|
8
|
+
method: string;
|
|
9
|
+
args: any[];
|
|
10
|
+
fallback?: T;
|
|
11
|
+
timeout?: number;
|
|
12
|
+
retry?: number;
|
|
13
|
+
node_id?: string;
|
|
14
|
+
ip?: string;
|
|
15
|
+
};
|
|
16
|
+
export type RpcEvent = Partial<{
|
|
17
|
+
rpc: RpcOptions<any> & {
|
|
18
|
+
callback: (o: any | Promise<any> | Observable<any>) => void;
|
|
19
|
+
};
|
|
20
|
+
online: string;
|
|
21
|
+
offline: string;
|
|
22
|
+
metadata: Record<string, string | boolean | number>;
|
|
23
|
+
}>;
|
|
24
|
+
export declare abstract class RpcTransporter {
|
|
25
|
+
abstract link(nodes$: Observable<{
|
|
26
|
+
nodes: Map<string, SpiderMeshNode>;
|
|
27
|
+
last_updated_node_id: string;
|
|
28
|
+
}>): Observable<RpcEvent>;
|
|
29
|
+
abstract rpc<T>(r: RpcOptions<T>, node: SpiderMeshNode, force: boolean): Observable<T>;
|
|
30
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RpcTransporter.js","sourceRoot":"","sources":["../../../src/interfaces/RpcTransporter.ts"],"names":[],"mappings":"AA0BA,MAAM,OAAgB,cAAc;CAMnC"}
|
|
@@ -1,22 +1,18 @@
|
|
|
1
|
-
export type
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
export type SpiderMeshNodeMetadata = {
|
|
5
|
-
id: string;
|
|
1
|
+
export type SpiderMeshNode = {
|
|
2
|
+
ips: string[];
|
|
3
|
+
host: string;
|
|
6
4
|
namespace: string;
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
online: boolean;
|
|
5
|
+
version: number;
|
|
6
|
+
node_id: string;
|
|
7
|
+
online?: boolean;
|
|
8
|
+
topics: string[];
|
|
12
9
|
services: {
|
|
13
|
-
[
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
10
|
+
[name: string]: any;
|
|
11
|
+
};
|
|
12
|
+
nodes: {
|
|
13
|
+
[node_id: string]: number;
|
|
14
|
+
};
|
|
15
|
+
transporters: {
|
|
16
|
+
[name: string]: any;
|
|
17
17
|
};
|
|
18
|
-
linked: string[];
|
|
19
|
-
isolate: boolean;
|
|
20
|
-
revalidate_on_join?: boolean;
|
|
21
18
|
};
|
|
22
|
-
export type SpiderMeshNode = SpiderMeshNodeMetadata;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"root":["../const.ts","../env.d.ts","../src/spidermesh.ts","../src/index.ts","../src/decorators/beforemicroserviceonline.ts","../src/decorators/limitconcurrentrunning.ts","../src/decorators/microservice.ts","../src/decorators/nestjsexposemicroservice.ts","../src/decorators/nestjslinkevent.ts","../src/decorators/nestjslinkmicroservice.ts","../src/helpers/limitconcurrency.ts","../src/helpers/microserviceexception.ts","../src/helpers/microservicenotfound.ts","../src/helpers/microserviceofflineexception.ts","../src/helpers/microservicerpctimeout.ts","../src/helpers/randomuuid.ts","../src/helpers/sleep.ts","../src/interfaces/discoverytransporter.ts","../src/interfaces/pubsubtransporter.ts","../src/interfaces/remoteservice.ts","../src/interfaces/rpctransporter.ts","../src/interfaces/spidermeshnode.ts"],"version":"5.8.2"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@spider-mesh/core",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "
|
|
4
|
+
"version": "2.0.2",
|
|
5
5
|
"description": "Lightweight microservice framework for typescript, auto discovery, load-balancing, fault-torrent, multiple transporters",
|
|
6
6
|
"main": "./build/src/index.js",
|
|
7
7
|
"types": "./build/src/index.d.ts",
|
|
@@ -14,9 +14,10 @@
|
|
|
14
14
|
"yarn.lock"
|
|
15
15
|
],
|
|
16
16
|
"devDependencies": {
|
|
17
|
-
"@types/node": "^
|
|
18
|
-
"
|
|
19
|
-
"
|
|
17
|
+
"@types/node": "^22.10.3",
|
|
18
|
+
"@types/reflect-metadata": "^0.1.0",
|
|
19
|
+
"@types/uuid": "^10.0.0",
|
|
20
|
+
"typescript": "^5.7.2"
|
|
20
21
|
},
|
|
21
22
|
"exports": {
|
|
22
23
|
".": {
|
|
@@ -27,13 +28,17 @@
|
|
|
27
28
|
}
|
|
28
29
|
},
|
|
29
30
|
"scripts": {
|
|
30
|
-
"
|
|
31
|
-
"build": "tsc -v; rm -rf build && tsc -b tsconfig.json"
|
|
31
|
+
"build": "tsc -v && tsc -b tsconfig.json"
|
|
32
32
|
},
|
|
33
33
|
"author": "Duong Van Ba",
|
|
34
34
|
"license": "ISC",
|
|
35
35
|
"dependencies": {
|
|
36
|
-
"
|
|
37
|
-
"
|
|
36
|
+
"buffer": "^6.0.3",
|
|
37
|
+
"react-native-uuid": "^2.0.2",
|
|
38
|
+
"rxjs": "^7.8.2",
|
|
39
|
+
"uuid": "^10.0.0"
|
|
40
|
+
},
|
|
41
|
+
"browser": {
|
|
42
|
+
"crypto": false
|
|
38
43
|
}
|
|
39
|
-
}
|
|
44
|
+
}
|
package/tsconfig.json
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"compilerOptions": {
|
|
3
|
+
"strict": true,
|
|
3
4
|
"module": "NodeNext",
|
|
4
5
|
"declaration": true,
|
|
5
6
|
"removeComments": true,
|
|
@@ -9,7 +10,9 @@
|
|
|
9
10
|
"target": "ESNext",
|
|
10
11
|
"sourceMap": true,
|
|
11
12
|
"baseUrl": ".",
|
|
12
|
-
"moduleResolution": "NodeNext",
|
|
13
|
+
"moduleResolution": "NodeNext",
|
|
14
|
+
"strictPropertyInitialization": false ,
|
|
15
|
+
"allowImportingTsExtensions": false,
|
|
13
16
|
"outDir": "./build",
|
|
14
17
|
"incremental": false,
|
|
15
18
|
"useDefineForClassFields": true,
|
|
@@ -22,13 +25,14 @@
|
|
|
22
25
|
"ESNext"
|
|
23
26
|
],
|
|
24
27
|
"esModuleInterop": true,
|
|
25
|
-
"importHelpers": true
|
|
28
|
+
"importHelpers": true,
|
|
29
|
+
"strictNullChecks": true
|
|
26
30
|
},
|
|
27
31
|
"exclude": [
|
|
28
32
|
"node_modules",
|
|
29
33
|
"out",
|
|
30
34
|
"src/schema.ts",
|
|
31
35
|
"bin",
|
|
32
|
-
"./build/**/*"
|
|
36
|
+
"./build/**/*"
|
|
33
37
|
]
|
|
34
38
|
}
|
package/build/src/Encoder.d.ts
DELETED
package/build/src/Encoder.js
DELETED
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
function replacer(key, value) {
|
|
2
|
-
const originalObject = this[key];
|
|
3
|
-
if (originalObject instanceof Map)
|
|
4
|
-
return {
|
|
5
|
-
__dataType: 'Map',
|
|
6
|
-
value: Array.from(originalObject.entries()),
|
|
7
|
-
};
|
|
8
|
-
if (originalObject instanceof Set)
|
|
9
|
-
return {
|
|
10
|
-
__dataType: 'Set',
|
|
11
|
-
value: Array.from(originalObject.values()),
|
|
12
|
-
};
|
|
13
|
-
if (typeof originalObject == 'function')
|
|
14
|
-
return {
|
|
15
|
-
__dataType: 'Function'
|
|
16
|
-
};
|
|
17
|
-
return value;
|
|
18
|
-
}
|
|
19
|
-
function receiver(key, value) {
|
|
20
|
-
if (typeof value === 'object' && value !== null) {
|
|
21
|
-
if (value.__dataType === 'Map') {
|
|
22
|
-
return new Map(value.value);
|
|
23
|
-
}
|
|
24
|
-
if (value.__dataType === 'Set') {
|
|
25
|
-
return new Set(value.value);
|
|
26
|
-
}
|
|
27
|
-
if (value.__dataType == 'Function')
|
|
28
|
-
return () => { };
|
|
29
|
-
}
|
|
30
|
-
return value;
|
|
31
|
-
}
|
|
32
|
-
export const Encoder = {
|
|
33
|
-
encode: (data) => Buffer.from(JSON.stringify(data, replacer)),
|
|
34
|
-
decode: (data) => {
|
|
35
|
-
try {
|
|
36
|
-
return JSON.parse(typeof data == 'string' ? data : data.toString('utf8'), receiver);
|
|
37
|
-
}
|
|
38
|
-
catch (e) {
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
};
|
|
42
|
-
//# sourceMappingURL=Encoder.js.map
|
package/build/src/Encoder.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Encoder.js","sourceRoot":"","sources":["../../src/Encoder.ts"],"names":[],"mappings":"AAAA,SAAS,QAAQ,CAAC,GAAG,EAAE,KAAK;IACxB,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,CAAA;IAEhC,IAAI,cAAc,YAAY,GAAG;QAAE,OAAO;YACtC,UAAU,EAAE,KAAK;YACjB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;SAC9C,CAAA;IAED,IAAI,cAAc,YAAY,GAAG;QAAE,OAAO;YACtC,UAAU,EAAE,KAAK;YACjB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC;SAC7C,CAAA;IAED,IAAI,OAAO,cAAc,IAAI,UAAU;QAAE,OAAO;YAC5C,UAAU,EAAE,UAAU;SACzB,CAAA;IAED,OAAO,KAAK,CAAA;AAChB,CAAC;AAGD,SAAS,QAAQ,CAAC,GAAG,EAAE,KAAK;IACxB,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,EAAE;QAC7C,IAAI,KAAK,CAAC,UAAU,KAAK,KAAK,EAAE;YAC5B,OAAO,IAAI,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;SAC/B;QAED,IAAI,KAAK,CAAC,UAAU,KAAK,KAAK,EAAE;YAC5B,OAAO,IAAI,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;SAC/B;QAED,IAAI,KAAK,CAAC,UAAU,IAAI,UAAU;YAAE,OAAO,GAAG,EAAE,GAAG,CAAC,CAAA;KACvD;IAED,OAAO,KAAK,CAAC;AACjB,CAAC;AAED,MAAM,CAAC,MAAM,OAAO,GAAG;IACnB,MAAM,EAAE,CAAU,IAAO,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IACzE,MAAM,EAAE,CAAU,IAAqB,EAAE,EAAE;QACvC,IAAI;YACA,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,IAAI,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,QAAQ,CAAM,CAAA;SAC3F;QAAC,OAAO,CAAC,EAAE;SAEX;IACL,CAAC;CACJ,CAAA"}
|
package/build/src/RPCOptions.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"RPCOptions.js","sourceRoot":"","sources":["../../src/RPCOptions.ts"],"names":[],"mappings":"AAWA,MAAM,CAAC,MAAM,cAAc,GAAG,IAAI,GAAG,CAAC;IAClC,UAAU;IACV,KAAK;IACL,oBAAoB;IACpB,UAAU;IACV,YAAY;IACZ,WAAW;IACX,QAAQ;IACR,cAAc;IACd,YAAY;IACZ,KAAK;CACR,CAAC,CAAA"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { PublishMetadata, SpiderMeshTransporter, SpiderMeshTransporterEvent } from "../interfaces/SpiderMeshTransporter.js";
|
|
2
|
-
import { Observable, Subject } from 'rxjs';
|
|
3
|
-
export declare class BuiltinTransporter implements SpiderMeshTransporter {
|
|
4
|
-
#private;
|
|
5
|
-
readonly node_id: string;
|
|
6
|
-
readonly namespace: string;
|
|
7
|
-
readonly $nodes_status: Subject<{
|
|
8
|
-
node_id: string;
|
|
9
|
-
online: boolean;
|
|
10
|
-
}>;
|
|
11
|
-
constructor(node_id: string, namespace: string);
|
|
12
|
-
start(): Promise<void>;
|
|
13
|
-
listen<T = any>(topic: string): Observable<SpiderMeshTransporterEvent<T>>;
|
|
14
|
-
publish<T = any>({ data, event, node_id }: PublishMetadata<T>): Promise<void>;
|
|
15
|
-
}
|
|
@@ -1,157 +0,0 @@
|
|
|
1
|
-
import { randomUUID } from "crypto";
|
|
2
|
-
import { Observable, Subject, debounceTime, filter, finalize, from, map, merge, mergeAll, mergeMap, takeUntil, tap } from 'rxjs';
|
|
3
|
-
import { RxjsTcpSocket } from "./RxjsTcpSocket.js";
|
|
4
|
-
import { RxjsTcpServer } from "./RxjsTcpServer.js";
|
|
5
|
-
import { RxjsUdpBroadcaster } from "./RxjsUdpBroadcaster.js";
|
|
6
|
-
import { UDP_BROADCAST_PORT, UDP_BROADCAST_ADDRESS, PEERS, DEBUG } from "../const.js";
|
|
7
|
-
import { Encoder } from "../Encoder.js";
|
|
8
|
-
export class BuiltinTransporter {
|
|
9
|
-
node_id;
|
|
10
|
-
namespace;
|
|
11
|
-
$nodes_status = new Subject();
|
|
12
|
-
#version = Date.now();
|
|
13
|
-
#listeners = new Map;
|
|
14
|
-
#nodes_map = new Map;
|
|
15
|
-
#events_map = new Map();
|
|
16
|
-
#$rebroadcast = new Subject();
|
|
17
|
-
#running_tcp_port = null;
|
|
18
|
-
constructor(node_id, namespace) {
|
|
19
|
-
this.node_id = node_id;
|
|
20
|
-
this.namespace = namespace;
|
|
21
|
-
}
|
|
22
|
-
#on_new_connection(socket) {
|
|
23
|
-
socket.$incoming_data
|
|
24
|
-
.pipe(takeUntil(socket.$status.pipe(filter(s => s == 'closed'))), map(buf => Encoder.decode(buf)), filter(Boolean), filter(msg => msg.sender_node_id != this.node_id), filter(msg => msg.namespace == this.namespace))
|
|
25
|
-
.subscribe(async (msg) => {
|
|
26
|
-
if (msg.topic == `#hello`)
|
|
27
|
-
return await this.#sync_node(socket, msg.data);
|
|
28
|
-
this.#listeners.get(msg.topic)?.forEach(cb => cb(msg.sender_node_id, msg.data));
|
|
29
|
-
});
|
|
30
|
-
!socket.opened_by_remote_side && this.#tcp_hello(socket);
|
|
31
|
-
}
|
|
32
|
-
async start() {
|
|
33
|
-
const tcp_server = await RxjsTcpServer.start();
|
|
34
|
-
const udp_broadcaster = await RxjsUdpBroadcaster.start({
|
|
35
|
-
namespace: this.namespace,
|
|
36
|
-
node_id: this.node_id,
|
|
37
|
-
udp_port: UDP_BROADCAST_PORT,
|
|
38
|
-
udp_address: UDP_BROADCAST_ADDRESS
|
|
39
|
-
});
|
|
40
|
-
const $udp_connections = udp_broadcaster.$new_node_discovered.pipe(mergeMap(node => RxjsTcpSocket.connect({
|
|
41
|
-
...node,
|
|
42
|
-
keepAlive: true,
|
|
43
|
-
retry_delay_ms: 5000,
|
|
44
|
-
retry_times: 5
|
|
45
|
-
})), filter(Boolean));
|
|
46
|
-
const $peer_connections = from(PEERS ? PEERS.split(',') : []).pipe(map(l => {
|
|
47
|
-
const [host, port] = l.trim().split(':');
|
|
48
|
-
if (host && port)
|
|
49
|
-
return { host, port: Number(port) };
|
|
50
|
-
}), filter(Boolean), mergeMap(({ host, port }) => RxjsTcpSocket.connect({ host, port, retry_delay_ms: 30000, retry_times: 10000 })), filter(Boolean));
|
|
51
|
-
tcp_server.$online.subscribe(({ port, $connection: $tcp_connections, $error }) => {
|
|
52
|
-
this.#running_tcp_port = port;
|
|
53
|
-
merge($tcp_connections, $udp_connections, $peer_connections).pipe(takeUntil($error), map(socket => this.#on_new_connection(socket))).subscribe();
|
|
54
|
-
udp_broadcaster.broadcast(port);
|
|
55
|
-
this.#$rebroadcast.pipe(debounceTime(1000), takeUntil($error), map(() => [...this.#nodes_map.values()]), mergeAll(), mergeMap(node => this.#tcp_hello(node.socket))).subscribe();
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
async #sync_node(node_socket, new_node) {
|
|
59
|
-
const host = node_socket.rawSocket.remoteAddress;
|
|
60
|
-
if (!host)
|
|
61
|
-
return;
|
|
62
|
-
const new_node_id = new_node.node_id;
|
|
63
|
-
const remote_info = new_node.peers.find(p => p.node_id == this.node_id);
|
|
64
|
-
const peer_updated = remote_info ? remote_info.version == this.#version : false;
|
|
65
|
-
for (const event of new_node.listening) {
|
|
66
|
-
!this.#events_map.has(event) && this.#events_map.set(event, new Set());
|
|
67
|
-
this.#events_map.get(event)?.add(new_node_id);
|
|
68
|
-
}
|
|
69
|
-
if (this.#nodes_map.has(new_node_id))
|
|
70
|
-
return;
|
|
71
|
-
const socket = node_socket.opened_by_remote_side ? (await RxjsTcpSocket.connect({
|
|
72
|
-
host,
|
|
73
|
-
port: new_node.port,
|
|
74
|
-
keepAlive: true,
|
|
75
|
-
retry_delay_ms: 200,
|
|
76
|
-
retry_times: 5
|
|
77
|
-
}) || node_socket) : node_socket;
|
|
78
|
-
const cleaner = () => {
|
|
79
|
-
const node = this.#nodes_map.get(new_node_id);
|
|
80
|
-
node && node.listening.map(evt => {
|
|
81
|
-
this.#events_map.get(evt)?.delete(node.node_id);
|
|
82
|
-
});
|
|
83
|
-
this.#nodes_map.delete(new_node_id);
|
|
84
|
-
this.$nodes_status.next({ node_id: new_node_id, online: false });
|
|
85
|
-
};
|
|
86
|
-
socket.$status.pipe(takeUntil(socket.$status.pipe(filter(s => s == 'closed'))), tap(status => {
|
|
87
|
-
if (status == 'ready') {
|
|
88
|
-
const nn = {
|
|
89
|
-
...new_node,
|
|
90
|
-
host,
|
|
91
|
-
socket,
|
|
92
|
-
peers: new_node.peers.map(p => ({ ...p, peers: [] }))
|
|
93
|
-
};
|
|
94
|
-
this.#nodes_map.set(new_node_id, nn);
|
|
95
|
-
DEBUG && console.log({ TCP_NEW_NODE: nn });
|
|
96
|
-
this.$nodes_status.next({ node_id: new_node_id, online: true });
|
|
97
|
-
}
|
|
98
|
-
else {
|
|
99
|
-
cleaner();
|
|
100
|
-
}
|
|
101
|
-
}), finalize(cleaner)).subscribe();
|
|
102
|
-
!peer_updated && this.#tcp_hello(node_socket);
|
|
103
|
-
}
|
|
104
|
-
async #tcp_hello(tcp_socket) {
|
|
105
|
-
if (!this.#running_tcp_port)
|
|
106
|
-
return;
|
|
107
|
-
const msg = {
|
|
108
|
-
data: {
|
|
109
|
-
node_id: this.node_id,
|
|
110
|
-
port: this.#running_tcp_port,
|
|
111
|
-
listening: ['#hello', ...this.#listeners.keys()],
|
|
112
|
-
peers: [...this.#nodes_map.values()].map(({ socket, ...node }) => node),
|
|
113
|
-
version: this.#version
|
|
114
|
-
},
|
|
115
|
-
namespace: this.namespace,
|
|
116
|
-
sender_node_id: this.node_id,
|
|
117
|
-
topic: '#hello'
|
|
118
|
-
};
|
|
119
|
-
tcp_socket.write(Encoder.encode(msg));
|
|
120
|
-
}
|
|
121
|
-
listen(topic) {
|
|
122
|
-
return new Observable(o => {
|
|
123
|
-
this.#version = Date.now();
|
|
124
|
-
!this.#listeners.has(topic) && this.#listeners.set(topic, new Map());
|
|
125
|
-
const id = randomUUID();
|
|
126
|
-
this.#listeners.get(topic)?.set(id, (sender_node_id, data) => o.next({
|
|
127
|
-
sender_node_id,
|
|
128
|
-
data
|
|
129
|
-
}));
|
|
130
|
-
this.#$rebroadcast.next();
|
|
131
|
-
return () => {
|
|
132
|
-
this.#version = Date.now();
|
|
133
|
-
this.#listeners.get(topic)?.delete(id);
|
|
134
|
-
this.#listeners.get(topic)?.size == 0 && this.#listeners.delete(topic);
|
|
135
|
-
this.#$rebroadcast.next();
|
|
136
|
-
};
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
async publish({ data, event, node_id }) {
|
|
140
|
-
const msg = {
|
|
141
|
-
data,
|
|
142
|
-
namespace: this.namespace,
|
|
143
|
-
sender_node_id: this.node_id,
|
|
144
|
-
topic: event || node_id || '#'
|
|
145
|
-
};
|
|
146
|
-
const buf = Encoder.encode(msg);
|
|
147
|
-
if (node_id == 'all' || !node_id) {
|
|
148
|
-
for (const node_id of this.#events_map.get(event) || []) {
|
|
149
|
-
const node = this.#nodes_map.get(node_id);
|
|
150
|
-
await node?.socket?.write(buf);
|
|
151
|
-
}
|
|
152
|
-
return;
|
|
153
|
-
}
|
|
154
|
-
node_id && await this.#nodes_map.get(node_id)?.socket?.write(buf);
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
//# sourceMappingURL=BuiltinTransporter.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"BuiltinTransporter.js","sourceRoot":"","sources":["../../../src/builtin-transporter/BuiltinTransporter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Observable, Subject } from "rxjs";
|
|
2
|
-
import { RxjsTcpSocket } from "./RxjsTcpSocket.js";
|
|
3
|
-
export declare class RxjsTcpServer {
|
|
4
|
-
static start<T = object>(start_port?: number): {
|
|
5
|
-
$online: Subject<{
|
|
6
|
-
port: number;
|
|
7
|
-
$connection: Subject<RxjsTcpSocket<T>>;
|
|
8
|
-
$error: Observable<Error>;
|
|
9
|
-
}>;
|
|
10
|
-
};
|
|
11
|
-
}
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
import { createServer } from "net";
|
|
2
|
-
import { Subject, firstValueFrom, fromEvent } from "rxjs";
|
|
3
|
-
import { RxjsTcpSocket } from "./RxjsTcpSocket.js";
|
|
4
|
-
export class RxjsTcpServer {
|
|
5
|
-
static start(start_port = 10001) {
|
|
6
|
-
const $online = new Subject();
|
|
7
|
-
setTimeout(async () => {
|
|
8
|
-
for (let port = start_port; true; port++) {
|
|
9
|
-
const $connection = new Subject();
|
|
10
|
-
const server = createServer();
|
|
11
|
-
const success = await new Promise(s => {
|
|
12
|
-
server.once('listening', () => s(true));
|
|
13
|
-
server.once('error', () => s(false));
|
|
14
|
-
server.listen(port);
|
|
15
|
-
});
|
|
16
|
-
if (!success)
|
|
17
|
-
continue;
|
|
18
|
-
server.on('connection', async (socket) => {
|
|
19
|
-
const stable_socket = await RxjsTcpSocket.join(socket);
|
|
20
|
-
$connection.next(stable_socket);
|
|
21
|
-
});
|
|
22
|
-
const $error = fromEvent(server, 'error');
|
|
23
|
-
$online.next({ port, $connection, $error });
|
|
24
|
-
await firstValueFrom($error);
|
|
25
|
-
server.removeAllListeners();
|
|
26
|
-
}
|
|
27
|
-
});
|
|
28
|
-
return { $online };
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
//# sourceMappingURL=RxjsTcpServer.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"RxjsTcpServer.js","sourceRoot":"","sources":["../../../src/builtin-transporter/RxjsTcpServer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,KAAK,CAAA;AAClC,OAAO,EAAc,OAAO,EAAE,cAAc,EAAE,SAAS,EAAO,MAAM,MAAM,CAAA;AAC1E,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAGlD,MAAM,OAAO,aAAa;IAGtB,MAAM,CAAC,KAAK,CAAa,aAAqB,KAAK;QAC/C,MAAM,OAAO,GAAG,IAAI,OAAO,EAIvB,CAAA;QAGJ,UAAU,CAAC,KAAK,IAAI,EAAE;YAClB,KAAK,IAAI,IAAI,GAAG,UAAU,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE;gBACtC,MAAM,WAAW,GAAG,IAAI,OAAO,EAAoB,CAAA;gBACnD,MAAM,MAAM,GAAG,YAAY,EAAE,CAAA;gBAC7B,MAAM,OAAO,GAAG,MAAM,IAAI,OAAO,CAAU,CAAC,CAAC,EAAE;oBAC3C,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAA;oBACvC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAA;oBACpC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;gBACvB,CAAC,CAAC,CAAA;gBACF,IAAI,CAAC,OAAO;oBAAE,SAAQ;gBACtB,MAAM,CAAC,EAAE,CAAC,YAAY,EAAE,KAAK,EAAC,MAAM,EAAC,EAAE;oBACnC,MAAM,aAAa,GAAG,MAAM,aAAa,CAAC,IAAI,CAAI,MAAM,CAAC,CAAA;oBACzD,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA;gBACnC,CAAC,CAAC,CAAA;gBACF,MAAM,MAAM,GAAG,SAAS,CAAC,MAAM,EAAE,OAAO,CAAsB,CAAA;gBAC9D,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,CAAC,CAAA;gBAC3C,MAAM,cAAc,CAAC,MAAM,CAAC,CAAA;gBAC5B,MAAM,CAAC,kBAAkB,EAAE,CAAA;aAC9B;QACL,CAAC,CAAC,CAAA;QACF,OAAO,EAAE,OAAO,EAAE,CAAA;IACtB,CAAC;CAEJ"}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
-
/// <reference types="node" resolution-mode="require"/>
|
|
3
|
-
import { TcpNetConnectOpts, Socket } from "net";
|
|
4
|
-
import { BehaviorSubject, Subject } from "rxjs";
|
|
5
|
-
export declare class RxjsTcpSocket<T = any> {
|
|
6
|
-
#private;
|
|
7
|
-
readonly opened_by_remote_side: boolean;
|
|
8
|
-
$incoming_data: Subject<Buffer>;
|
|
9
|
-
$status: BehaviorSubject<"connecting" | "ready" | "closed" | "error">;
|
|
10
|
-
rawSocket: Socket;
|
|
11
|
-
constructor(opened_by_remote_side: boolean);
|
|
12
|
-
static connect<T = any>({ retry_times, retry_delay_ms, ...options }: TcpNetConnectOpts & {
|
|
13
|
-
retry_times?: number;
|
|
14
|
-
retry_delay_ms?: number;
|
|
15
|
-
}): Promise<RxjsTcpSocket<T>>;
|
|
16
|
-
static join<T = any>(socket: Socket): Promise<RxjsTcpSocket<T>>;
|
|
17
|
-
write(data: Buffer): Promise<void>;
|
|
18
|
-
}
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
import { createConnection } from "net";
|
|
2
|
-
import { BehaviorSubject, Subject, finalize, firstValueFrom, fromEvent, map, merge, takeUntil, tap, timer } from "rxjs";
|
|
3
|
-
import frame from 'frame-stream';
|
|
4
|
-
import { sleep } from "../../src/helpers/sleep.js";
|
|
5
|
-
export class RxjsTcpSocket {
|
|
6
|
-
opened_by_remote_side;
|
|
7
|
-
#$outgoing_data = new Subject();
|
|
8
|
-
$incoming_data = new Subject();
|
|
9
|
-
$status = new BehaviorSubject('connecting');
|
|
10
|
-
rawSocket;
|
|
11
|
-
constructor(opened_by_remote_side) {
|
|
12
|
-
this.opened_by_remote_side = opened_by_remote_side;
|
|
13
|
-
opened_by_remote_side && this.$status.next('ready');
|
|
14
|
-
}
|
|
15
|
-
static connect({ retry_times = 5, retry_delay_ms = 5000, ...options }) {
|
|
16
|
-
const $this = new this(false);
|
|
17
|
-
return new Promise(async (s) => {
|
|
18
|
-
for (let i = 1; i <= retry_times; i++) {
|
|
19
|
-
const socket = createConnection({ ...options, autoSelectFamily: true });
|
|
20
|
-
console.log(`Connect to ${options.host}:${options.port}`);
|
|
21
|
-
const connected = await firstValueFrom(merge(fromEvent(socket, 'connect').pipe(map(() => true)), fromEvent(socket, 'error').pipe(map(() => false)), timer(1000).pipe(map(() => false))));
|
|
22
|
-
console.log({ connected });
|
|
23
|
-
if (!connected) {
|
|
24
|
-
await sleep(retry_delay_ms);
|
|
25
|
-
continue;
|
|
26
|
-
}
|
|
27
|
-
$this.$status.next('ready');
|
|
28
|
-
const $error = $this.#join_util_error(socket);
|
|
29
|
-
s($this);
|
|
30
|
-
i = 0;
|
|
31
|
-
const status = await $error;
|
|
32
|
-
if (status == 'closed')
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
s(null);
|
|
36
|
-
$this.$status.next('error');
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
static async join(socket) {
|
|
40
|
-
const $this = new this(true);
|
|
41
|
-
$this.#join_util_error(socket);
|
|
42
|
-
return $this;
|
|
43
|
-
}
|
|
44
|
-
async #join_util_error(socket) {
|
|
45
|
-
const $error = merge(fromEvent(socket, 'error').pipe(map(() => 'error')), fromEvent(socket, 'close').pipe(map(() => 'closed')), fromEvent(socket, 'timeout').pipe(map(() => 'error')), fromEvent(socket, 'end').pipe(map(() => 'closed'))).pipe(tap(status => this.$status.next(status)));
|
|
46
|
-
this.rawSocket = socket;
|
|
47
|
-
const encoder = frame.encode();
|
|
48
|
-
const decoder = frame.decode();
|
|
49
|
-
decoder.on('data', (msg) => {
|
|
50
|
-
this.$incoming_data.next(msg);
|
|
51
|
-
});
|
|
52
|
-
socket.on('data', data => decoder.write(data));
|
|
53
|
-
encoder.on('data', buffer => socket.writable && socket.write(buffer));
|
|
54
|
-
this.#$outgoing_data.pipe(takeUntil($error), finalize(() => {
|
|
55
|
-
socket.removeAllListeners();
|
|
56
|
-
decoder.removeAllListeners();
|
|
57
|
-
encoder.removeAllListeners();
|
|
58
|
-
}), map(data => encoder.write(data), 1)).subscribe();
|
|
59
|
-
return firstValueFrom($error);
|
|
60
|
-
}
|
|
61
|
-
async write(data) {
|
|
62
|
-
this.#$outgoing_data.next(data);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
//# sourceMappingURL=RxjsTcpSocket.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"RxjsTcpSocket.js","sourceRoot":"","sources":["../../../src/builtin-transporter/RxjsTcpSocket.ts"],"names":[],"mappings":"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"}
|