@spider-mesh/core 1.0.9965 → 2.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (101) hide show
  1. package/build/const.d.ts +1 -0
  2. package/build/const.js +2 -0
  3. package/build/const.js.map +1 -0
  4. package/build/src/SpiderMesh.d.ts +27 -41
  5. package/build/src/SpiderMesh.js +314 -381
  6. package/build/src/SpiderMesh.js.map +1 -1
  7. package/build/src/decorators/BeforeMicroserviceOnline.d.ts +4 -0
  8. package/build/src/decorators/BeforeMicroserviceOnline.js +10 -0
  9. package/build/src/decorators/BeforeMicroserviceOnline.js.map +1 -0
  10. package/build/src/decorators/LimitConcurrentRunning.d.ts +2 -3
  11. package/build/src/decorators/LimitConcurrentRunning.js +2 -22
  12. package/build/src/decorators/LimitConcurrentRunning.js.map +1 -1
  13. package/build/src/decorators/Microservice.d.ts +10 -24
  14. package/build/src/decorators/Microservice.js +12 -31
  15. package/build/src/decorators/Microservice.js.map +1 -1
  16. package/build/src/decorators/NestJSExposeMicroservice.d.ts +5 -0
  17. package/build/src/decorators/NestJSExposeMicroservice.js +14 -0
  18. package/build/src/decorators/NestJSExposeMicroservice.js.map +1 -0
  19. package/build/src/decorators/NestJSLinkEvent.d.ts +9 -0
  20. package/build/src/decorators/NestJSLinkEvent.js +7 -0
  21. package/build/src/decorators/NestJSLinkEvent.js.map +1 -0
  22. package/build/src/decorators/NestJSLinkMicroservice.d.ts +6 -0
  23. package/build/src/decorators/NestJSLinkMicroservice.js +7 -0
  24. package/build/src/decorators/NestJSLinkMicroservice.js.map +1 -0
  25. package/build/src/helpers/LimitConcurrency.d.ts +3 -0
  26. package/build/src/helpers/LimitConcurrency.js +34 -0
  27. package/build/src/helpers/LimitConcurrency.js.map +1 -0
  28. package/build/src/helpers/MicroserviceException.d.ts +8 -0
  29. package/build/src/helpers/MicroserviceException.js +9 -0
  30. package/build/src/helpers/MicroserviceException.js.map +1 -0
  31. package/build/src/helpers/MicroserviceNotFound copy.d.ts +5 -0
  32. package/build/src/helpers/MicroserviceNotFound copy.js +8 -0
  33. package/build/src/helpers/MicroserviceNotFound copy.js.map +1 -0
  34. package/build/src/helpers/MicroserviceNotFound.d.ts +5 -0
  35. package/build/src/helpers/MicroserviceNotFound.js +8 -0
  36. package/build/src/helpers/MicroserviceNotFound.js.map +1 -0
  37. package/build/src/helpers/MicroserviceOfflineException.d.ts +5 -0
  38. package/build/src/helpers/MicroserviceOfflineException.js +8 -0
  39. package/build/src/helpers/MicroserviceOfflineException.js.map +1 -0
  40. package/build/src/helpers/MicroserviceRpcTimeout.d.ts +5 -0
  41. package/build/src/helpers/MicroserviceRpcTimeout.js +8 -0
  42. package/build/src/helpers/MicroserviceRpcTimeout.js.map +1 -0
  43. package/build/src/helpers/randomUUID.d.ts +1 -0
  44. package/build/src/helpers/randomUUID.js +13 -0
  45. package/build/src/helpers/randomUUID.js.map +1 -0
  46. package/build/src/helpers/sleep.js +1 -1
  47. package/build/src/helpers/sleep.js.map +1 -1
  48. package/build/src/index.d.ts +16 -12
  49. package/build/src/index.js +16 -9
  50. package/build/src/index.js.map +1 -1
  51. package/build/src/interfaces/DiscoveryTransporter.d.ts +5 -0
  52. package/build/src/interfaces/DiscoveryTransporter.js +3 -0
  53. package/build/src/interfaces/DiscoveryTransporter.js.map +1 -0
  54. package/build/src/interfaces/PubsubTransporter.d.ts +10 -0
  55. package/build/src/interfaces/PubsubTransporter.js +3 -0
  56. package/build/src/interfaces/PubsubTransporter.js.map +1 -0
  57. package/build/src/interfaces/RemoteService.d.ts +12 -18
  58. package/build/src/interfaces/RpcTransporter.d.ts +30 -0
  59. package/build/src/interfaces/RpcTransporter.js +3 -0
  60. package/build/src/interfaces/RpcTransporter.js.map +1 -0
  61. package/build/src/interfaces/SpiderMeshNode.d.ts +14 -18
  62. package/build/tsconfig.tsbuildinfo +1 -0
  63. package/package.json +15 -7
  64. package/tsconfig.json +7 -3
  65. package/build/src/Encoder.d.ts +0 -5
  66. package/build/src/Encoder.js +0 -42
  67. package/build/src/Encoder.js.map +0 -1
  68. package/build/src/RPCOptions.d.ts +0 -11
  69. package/build/src/RPCOptions.js +0 -13
  70. package/build/src/RPCOptions.js.map +0 -1
  71. package/build/src/builtin-transporter/BuiltinTransporter.d.ts +0 -15
  72. package/build/src/builtin-transporter/BuiltinTransporter.js +0 -157
  73. package/build/src/builtin-transporter/BuiltinTransporter.js.map +0 -1
  74. package/build/src/builtin-transporter/RxjsTcpServer.d.ts +0 -11
  75. package/build/src/builtin-transporter/RxjsTcpServer.js +0 -31
  76. package/build/src/builtin-transporter/RxjsTcpServer.js.map +0 -1
  77. package/build/src/builtin-transporter/RxjsTcpSocket.d.ts +0 -18
  78. package/build/src/builtin-transporter/RxjsTcpSocket.js +0 -65
  79. package/build/src/builtin-transporter/RxjsTcpSocket.js.map +0 -1
  80. package/build/src/builtin-transporter/RxjsUdpBroadcaster.d.ts +0 -19
  81. package/build/src/builtin-transporter/RxjsUdpBroadcaster.js +0 -48
  82. package/build/src/builtin-transporter/RxjsUdpBroadcaster.js.map +0 -1
  83. package/build/src/const.d.ts +0 -6
  84. package/build/src/const.js +0 -8
  85. package/build/src/const.js.map +0 -1
  86. package/build/src/decorators/DeepProxy.d.ts +0 -7
  87. package/build/src/decorators/DeepProxy.js +0 -24
  88. package/build/src/decorators/DeepProxy.js.map +0 -1
  89. package/build/src/decorators/ListenEvent.d.ts +0 -17
  90. package/build/src/decorators/ListenEvent.js +0 -23
  91. package/build/src/decorators/ListenEvent.js.map +0 -1
  92. package/build/src/decorators/OnMicroserviceReady.d.ts +0 -6
  93. package/build/src/decorators/OnMicroserviceReady.js +0 -14
  94. package/build/src/decorators/OnMicroserviceReady.js.map +0 -1
  95. package/build/src/helpers/waitFirstEvent.d.ts +0 -3
  96. package/build/src/helpers/waitFirstEvent.js +0 -5
  97. package/build/src/helpers/waitFirstEvent.js.map +0 -1
  98. package/build/src/interfaces/SpiderMeshTransporter.d.ts +0 -24
  99. package/build/src/interfaces/SpiderMeshTransporter.js +0 -2
  100. package/build/src/interfaces/SpiderMeshTransporter.js.map +0 -1
  101. package/yarn.lock +0 -134
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PubsubTransporter.js","sourceRoot":"","sources":["../../../src/interfaces/PubsubTransporter.ts"],"names":[],"mappings":"AAUA,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
- $wait_service_online: () => Promise<void>;
8
- $safe_mode: () => {
9
- [K in keyof T as (T[K] extends (...args: any) => any ? K : '')]: T[K] extends (...args: any) => any ? ((...args: Parameters<T[K]>) => [
10
- Error | null,
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]>>>) : null;
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 RPCOptions as `${key}`]: (value: RPCOptions[key]) => RemoteService<T>;
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,3 @@
1
+ export class RpcTransporter {
2
+ }
3
+ //# sourceMappingURL=RpcTransporter.js.map
@@ -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 ServiceMetadata = {
2
- [key: string]: string | number | boolean;
3
- };
4
- export type SpiderMeshNodeMetadata = {
5
- id: string;
1
+ export type SpiderMeshNode = {
2
+ ips: string[];
3
+ host: string;
6
4
  namespace: string;
7
- public_ip: string | null;
8
- ip_addresses: string[];
9
- last_online: number;
10
- active: boolean;
11
- online: boolean;
5
+ version: number;
6
+ node_id: string;
7
+ online?: boolean;
8
+ topics: string[];
12
9
  services: {
13
- [service_id: string]: {
14
- instance: any;
15
- metadata: ServiceMetadata;
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": "1.0.9965",
4
+ "version": "2.0.1",
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,12 @@
14
14
  "yarn.lock"
15
15
  ],
16
16
  "devDependencies": {
17
- "@types/node": "^18.16.0",
17
+ "@types/node": "^22.10.3",
18
+ "@types/reflect-metadata": "^0.1.0",
19
+ "@types/uuid": "^10.0.0",
18
20
  "ts-node": "^10.9.1",
19
- "typescript": "^5.0.4"
21
+ "tsx": "^4.19.2",
22
+ "typescript": "^5.7.2"
20
23
  },
21
24
  "exports": {
22
25
  ".": {
@@ -28,12 +31,17 @@
28
31
  },
29
32
  "scripts": {
30
33
  "dev": "clear; node --no-warnings --es-module-specifier-resolution=node --experimental-specifier-resolution=node --loader ts-node/esm ",
31
- "build": "tsc -v; rm -rf build && tsc -b tsconfig.json"
34
+ "build": "tsc -v && tsc -b tsconfig.json"
32
35
  },
33
36
  "author": "Duong Van Ba",
34
37
  "license": "ISC",
35
38
  "dependencies": {
36
- "frame-stream": "^4.0.0",
37
- "rxjs": "^7.8.1"
39
+ "buffer": "^6.0.3",
40
+ "react-native-uuid": "^2.0.2",
41
+ "rxjs": "^7.8.2",
42
+ "uuid": "^10.0.0"
43
+ },
44
+ "browser": {
45
+ "crypto": false
38
46
  }
39
- }
47
+ }
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
  }
@@ -1,5 +0,0 @@
1
- /// <reference types="node" resolution-mode="require"/>
2
- export declare const Encoder: {
3
- encode: <T = any>(data: T) => Buffer;
4
- decode: <T_1 = any>(data: Buffer | string) => T_1;
5
- };
@@ -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
@@ -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"}
@@ -1,11 +0,0 @@
1
- export type RPCOptions<T = any> = {
2
- $node_id: string;
3
- $timeout: number;
4
- $nevermind: boolean;
5
- $fallback: T;
6
- $retry: number;
7
- $retry_delay: number;
8
- $safe_mode: boolean;
9
- $ip: string;
10
- };
11
- export declare const RPCOptionsList: Set<string>;
@@ -1,13 +0,0 @@
1
- export const RPCOptionsList = new Set([
2
- '$node_id',
3
- '$ip',
4
- '$load_balance_mode',
5
- '$timeout',
6
- '$nevermind',
7
- '$fallback',
8
- '$retry',
9
- '$retry_delay',
10
- '$safe_mode',
11
- '$ip'
12
- ]);
13
- //# sourceMappingURL=RPCOptions.js.map
@@ -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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"}
@@ -1,19 +0,0 @@
1
- import { Observable } from "rxjs";
2
- export type RxjsUdpBroadcasterConfig = {
3
- node_id: string;
4
- namespace: string;
5
- udp_address?: string;
6
- udp_port: any;
7
- };
8
- export declare class RxjsUdpBroadcaster {
9
- static start({ namespace, node_id, udp_port, udp_address }: RxjsUdpBroadcasterConfig): Promise<{
10
- broadcast: (port: number) => Promise<void>;
11
- $new_node_discovered: Observable<{
12
- port: number;
13
- node_id: string;
14
- namespace: string;
15
- } & {
16
- host: string;
17
- }>;
18
- }>;
19
- }