@t4h.framework/cli 0.0.0-experimental-c0d4325

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 (81) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +1 -0
  3. package/dist/bin/bin.js +57 -0
  4. package/dist/bin/bin.js.map +1 -0
  5. package/dist/commands/build/build.js +49 -0
  6. package/dist/commands/build/build.js.map +1 -0
  7. package/dist/commands/dev/dev.js +109 -0
  8. package/dist/commands/dev/dev.js.map +1 -0
  9. package/dist/commands/dev-server-up-app-process.js +84 -0
  10. package/dist/commands/dev-server-up-app-process.js.map +1 -0
  11. package/dist/commands/publish/publish.js +149 -0
  12. package/dist/commands/publish/publish.js.map +1 -0
  13. package/dist/models/CliFileSystemClaim.js +30 -0
  14. package/dist/models/CliFileSystemClaim.js.map +1 -0
  15. package/dist/models/CliHttpClientRequestClaim.js +21 -0
  16. package/dist/models/CliHttpClientRequestClaim.js.map +1 -0
  17. package/dist/models/CliORMClaim.js +37 -0
  18. package/dist/models/CliORMClaim.js.map +1 -0
  19. package/dist/models/DevServer.js +77 -0
  20. package/dist/models/DevServer.js.map +1 -0
  21. package/dist/models/DevServerFileBinary.js +27 -0
  22. package/dist/models/DevServerFileBinary.js.map +1 -0
  23. package/dist/models/DevServerFileSystemClaim.js +30 -0
  24. package/dist/models/DevServerFileSystemClaim.js.map +1 -0
  25. package/dist/models/DevServerHttpClientRequestClaim.js +21 -0
  26. package/dist/models/DevServerHttpClientRequestClaim.js.map +1 -0
  27. package/dist/models/DevServerORMClaim.js +37 -0
  28. package/dist/models/DevServerORMClaim.js.map +1 -0
  29. package/dist/models/DevServerSmtpSendEmailClaim.js +32 -0
  30. package/dist/models/DevServerSmtpSendEmailClaim.js.map +1 -0
  31. package/dist/models/FileBinary.js +28 -0
  32. package/dist/models/FileBinary.js.map +1 -0
  33. package/dist/models/InMemoryDatabase.js +86 -0
  34. package/dist/models/InMemoryDatabase.js.map +1 -0
  35. package/dist/models/JSONCodec.js +110 -0
  36. package/dist/models/JSONCodec.js.map +1 -0
  37. package/dist/models/JSONCodecKindFrameworkSerializableClass.js +7 -0
  38. package/dist/models/JSONCodecKindFrameworkSerializableClass.js.map +1 -0
  39. package/dist/models/JSONRPCClient.js +50 -0
  40. package/dist/models/JSONRPCClient.js.map +1 -0
  41. package/dist/models/JSONRPCServer.js +61 -0
  42. package/dist/models/JSONRPCServer.js.map +1 -0
  43. package/dist/models/__tests__/DevServerFileBinary.spec.js +44 -0
  44. package/dist/models/__tests__/DevServerFileBinary.spec.js.map +1 -0
  45. package/dist/models/__tests__/InMemoryDatabase.spec.js +189 -0
  46. package/dist/models/__tests__/InMemoryDatabase.spec.js.map +1 -0
  47. package/dist/models/__tests__/JSONCodec.spec.js +135 -0
  48. package/dist/models/__tests__/JSONCodec.spec.js.map +1 -0
  49. package/dist/models/__tests__/JSONCodecKindFrameworkSerializableClass.spec.js +51 -0
  50. package/dist/models/__tests__/JSONCodecKindFrameworkSerializableClass.spec.js.map +1 -0
  51. package/dist/models/__tests__/JSONRPCClient.spec.js +133 -0
  52. package/dist/models/__tests__/JSONRPCClient.spec.js.map +1 -0
  53. package/dist/models/__tests__/JSONRPCServer.spec.js +160 -0
  54. package/dist/models/__tests__/JSONRPCServer.spec.js.map +1 -0
  55. package/dist/tools/__tests__/up-app.spec.js +24 -0
  56. package/dist/tools/__tests__/up-app.spec.js.map +1 -0
  57. package/dist/tools/a.js +53 -0
  58. package/dist/tools/a.js.map +1 -0
  59. package/dist/tools/extract-workflow-jsx.js +206 -0
  60. package/dist/tools/extract-workflow-jsx.js.map +1 -0
  61. package/dist/tools/generate-rsc-entries.js +105 -0
  62. package/dist/tools/generate-rsc-entries.js.map +1 -0
  63. package/dist/tools/json-codec.js +17 -0
  64. package/dist/tools/json-codec.js.map +1 -0
  65. package/dist/tools/json-schema-to-inquirer-question.js +33 -0
  66. package/dist/tools/json-schema-to-inquirer-question.js.map +1 -0
  67. package/dist/tools/mkdir-out-dir-project-from-ts-config-path-and-json-package-path.js +11 -0
  68. package/dist/tools/mkdir-out-dir-project-from-ts-config-path-and-json-package-path.js.map +1 -0
  69. package/dist/tools/resolve-package-json-path.js +21 -0
  70. package/dist/tools/resolve-package-json-path.js.map +1 -0
  71. package/dist/tools/resolve-tsconfig-path-from-package-json-path.js +14 -0
  72. package/dist/tools/resolve-tsconfig-path-from-package-json-path.js.map +1 -0
  73. package/dist/tools/test.js +32 -0
  74. package/dist/tools/test.js.map +1 -0
  75. package/dist/tools/ts-build-watch.js +46 -0
  76. package/dist/tools/ts-build-watch.js.map +1 -0
  77. package/dist/tools/ts-build.js +37 -0
  78. package/dist/tools/ts-build.js.map +1 -0
  79. package/dist/tools/up-app.js +10 -0
  80. package/dist/tools/up-app.js.map +1 -0
  81. package/package.json +67 -0
@@ -0,0 +1,77 @@
1
+ import { ChildProcess, fork } from 'node:child_process';
2
+ import path from 'node:path';
3
+ import Type from 'typebox';
4
+ import { JSONRPCClient } from './JSONRPCClient.js';
5
+ import { JSONRPCServer, JSONRPCServerMethod } from './JSONRPCServer.js';
6
+ import { mkdirOutDirProjectFromTsConfigPathAndJsonPackagePath } from '../tools/mkdir-out-dir-project-from-ts-config-path-and-json-package-path.js';
7
+ import { resolvePackageJsonPath } from '../tools/resolve-package-json-path.js';
8
+ import { resolveTsconfigFromPackageJsonPath } from '../tools/resolve-tsconfig-path-from-package-json-path.js';
9
+ import { tsBuildWatch } from '../tools/ts-build-watch.js';
10
+ export class DevServer {
11
+ config;
12
+ onAppManifest;
13
+ tsBuildWatcher;
14
+ packageJsonPath;
15
+ tsConfigPath;
16
+ outDir;
17
+ app;
18
+ jsonRpcServer;
19
+ jsonRpcClient;
20
+ constructor(config, onAppManifest) {
21
+ this.config = config;
22
+ this.onAppManifest = onAppManifest;
23
+ this.jsonRpcServer = new JSONRPCServer([
24
+ new JSONRPCServerMethod('manifest', { schema: [Type.Any()] }, manifest => this.onAppManifest(manifest)),
25
+ ], message => {
26
+ this.app?.send(message);
27
+ });
28
+ this.jsonRpcClient = new JSONRPCClient(message => {
29
+ this.app?.send(message);
30
+ });
31
+ }
32
+ async start() {
33
+ this.packageJsonPath = await resolvePackageJsonPath(this.config.entrypoint);
34
+ this.tsConfigPath = await resolveTsconfigFromPackageJsonPath(this.packageJsonPath);
35
+ this.outDir = await mkdirOutDirProjectFromTsConfigPathAndJsonPackagePath(this.tsConfigPath, this.packageJsonPath);
36
+ this.tsBuildWatcher = tsBuildWatch(this.tsConfigPath, {
37
+ outDir: path.join(this.outDir, 'dist'),
38
+ sourceMap: true,
39
+ declaration: false,
40
+ declarationMap: false,
41
+ }, {
42
+ onSuccess: () => this.onTsBuildSuccess(),
43
+ // onFail(diagnostics) {
44
+ // // this.onTsBuildFail(diagnostics)
45
+ // },
46
+ // onStatus(status) {
47
+ // // this.onTsBuildStatus(status)
48
+ // },
49
+ });
50
+ }
51
+ async onTsBuildSuccess() {
52
+ const { default: packageJson } = await import(this.packageJsonPath, {
53
+ with: { type: 'json' },
54
+ });
55
+ if (typeof packageJson.main !== 'string')
56
+ throw new Error('Main is not a string');
57
+ const entrypoint = path.join(this.outDir, 'dist', packageJson.main);
58
+ this.app = fork(path.join(import.meta.dirname, '..', 'commands', 'dev-server-up-app-process.js'), [
59
+ entrypoint,
60
+ ...Object.entries(this.config.env).map(([name, value]) => `${name}=${value}`),
61
+ ], { stdio: ['ignore', 'inherit', 'inherit', 'ipc'] });
62
+ this.app.on('message', message => Promise.all([
63
+ this.jsonRpcServer.handle(message),
64
+ this.jsonRpcClient.handle(message),
65
+ ]));
66
+ }
67
+ async runWorkflow(workflowId, input) {
68
+ return await this.jsonRpcClient.call('workflow.run', workflowId, input);
69
+ }
70
+ async setEnv(name, value) {
71
+ return await this.jsonRpcClient.call('env.set', name, value);
72
+ }
73
+ async listEnv() {
74
+ return await this.jsonRpcClient.call('env.list');
75
+ }
76
+ }
77
+ //# sourceMappingURL=DevServer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DevServer.js","sourceRoot":"","sources":["../../src/models/DevServer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAA;AACvD,OAAO,IAAI,MAAM,WAAW,CAAA;AAG5B,OAAO,IAAI,MAAM,SAAS,CAAA;AAE1B,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAA;AACvE,OAAO,EAAE,oDAAoD,EAAE,MAAM,6EAA6E,CAAA;AAClJ,OAAO,EAAE,sBAAsB,EAAE,MAAM,uCAAuC,CAAA;AAC9E,OAAO,EAAE,kCAAkC,EAAE,MAAM,0DAA0D,CAAA;AAC7G,OAAO,EAAE,YAAY,EAAuB,MAAM,4BAA4B,CAAA;AAO9E,MAAM,OAAO,SAAS;IAUD;IACA;IAVX,cAAc,CAAiB;IAC/B,eAAe,CAAS;IACxB,YAAY,CAAS;IACrB,MAAM,CAAS;IACf,GAAG,CAAe;IAClB,aAAa,CAAgB;IAC7B,aAAa,CAAgB;IAErC,YACmB,MAAuB,EACvB,aAER;QAHQ,WAAM,GAAN,MAAM,CAAiB;QACvB,kBAAa,GAAb,aAAa,CAErB;QAET,IAAI,CAAC,aAAa,GAAG,IAAI,aAAa,CACpC;YACE,IAAI,mBAAmB,CACrB,UAAU,EACV,EAAE,MAAM,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAU,EAAE,EACjC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CACzC;SACF,EACD,OAAO,CAAC,EAAE;YACR,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;QACzB,CAAC,CACF,CAAA;QAED,IAAI,CAAC,aAAa,GAAG,IAAI,aAAa,CAAC,OAAO,CAAC,EAAE;YAC/C,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;QACzB,CAAC,CAAC,CAAA;IACJ,CAAC;IAEM,KAAK,CAAC,KAAK;QAChB,IAAI,CAAC,eAAe,GAAG,MAAM,sBAAsB,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;QAE3E,IAAI,CAAC,YAAY,GAAG,MAAM,kCAAkC,CAC1D,IAAI,CAAC,eAAe,CACrB,CAAA;QAED,IAAI,CAAC,MAAM,GAAG,MAAM,oDAAoD,CACtE,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,eAAe,CACrB,CAAA;QAED,IAAI,CAAC,cAAc,GAAG,YAAY,CAChC,IAAI,CAAC,YAAY,EACjB;YACE,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC;YACtC,SAAS,EAAE,IAAI;YACf,WAAW,EAAE,KAAK;YAClB,cAAc,EAAE,KAAK;SACtB,EACD;YACE,SAAS,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,EAAE;YACxC,wBAAwB;YACxB,uCAAuC;YACvC,KAAK;YACL,qBAAqB;YACrB,oCAAoC;YACpC,KAAK;SACN,CACF,CAAA;IACH,CAAC;IAES,KAAK,CAAC,gBAAgB;QAC9B,MAAM,EAAE,OAAO,EAAE,WAAW,EAAE,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE;YAClE,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;SACvB,CAAC,CAAA;QAEF,IAAI,OAAO,WAAW,CAAC,IAAI,KAAK,QAAQ;YACtC,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAA;QAEzC,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,CAAC,IAAI,CAAC,CAAA;QAEnE,IAAI,CAAC,GAAG,GAAG,IAAI,CACb,IAAI,CAAC,IAAI,CACP,MAAM,CAAC,IAAI,CAAC,OAAO,EACnB,IAAI,EACJ,UAAU,EACV,8BAA8B,CAC/B,EACD;YACE,UAAU;YACV,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CACpC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,IAAI,IAAI,KAAK,EAAE,CACtC;SACF,EACD,EAAE,KAAK,EAAE,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,CAAC,EAAE,CACnD,CAAA;QAED,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,SAAS,EAAE,OAAO,CAAC,EAAE,CAC/B,OAAO,CAAC,GAAG,CAAC;YACV,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,OAAO,CAAC;YAClC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,OAAO,CAAC;SACnC,CAAC,CACH,CAAA;IACH,CAAC;IAEM,KAAK,CAAC,WAAW,CAAC,UAAkB,EAAE,KAAU;QACrD,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,EAAE,UAAU,EAAE,KAAK,CAAC,CAAA;IACzE,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,IAAY,EAAE,KAAa;QAC7C,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,CAAC,CAAA;IAC9D,CAAC;IAEM,KAAK,CAAC,OAAO;QAClB,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;IAClD,CAAC;CACF"}
@@ -0,0 +1,27 @@
1
+ import fs from 'node:fs';
2
+ import { Binary } from '@t4h.framework/core';
3
+ export class DevServerFileBinary extends Binary {
4
+ path;
5
+ contentType;
6
+ contentLength;
7
+ constructor(path, contentType, contentLength) {
8
+ super();
9
+ this.path = path;
10
+ this.contentType = contentType;
11
+ this.contentLength = contentLength;
12
+ }
13
+ async stream() {
14
+ return fs.createReadStream(this.path);
15
+ }
16
+ static from(file) {
17
+ return new this(file.path, file.contentType, file.contentLength);
18
+ }
19
+ toJSON() {
20
+ return {
21
+ path: this.path,
22
+ contentType: this.contentType,
23
+ contentLength: this.contentLength,
24
+ };
25
+ }
26
+ }
27
+ //# sourceMappingURL=DevServerFileBinary.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DevServerFileBinary.js","sourceRoot":"","sources":["../../src/models/DevServerFileBinary.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,SAAS,CAAA;AAExB,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAE5C,MAAM,OAAO,mBAAoB,SAAQ,MAAM;IAE3B;IACA;IACA;IAHlB,YACkB,IAAY,EACZ,WAAmB,EACnB,aAAqB;QAErC,KAAK,EAAE,CAAA;QAJS,SAAI,GAAJ,IAAI,CAAQ;QACZ,gBAAW,GAAX,WAAW,CAAQ;QACnB,kBAAa,GAAb,aAAa,CAAQ;IAGvC,CAAC;IAEM,KAAK,CAAC,MAAM;QACjB,OAAO,EAAE,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACvC,CAAC;IAEM,MAAM,CAAC,IAAI,CAAC,IAA+C;QAChE,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,aAAa,CAAC,CAAA;IAClE,CAAC;IAEM,MAAM;QACX,OAAO;YACL,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,aAAa,EAAE,IAAI,CAAC,aAAa;SAClC,CAAA;IACH,CAAC;CACF"}
@@ -0,0 +1,30 @@
1
+ import fs from 'node:fs';
2
+ import os from 'node:os';
3
+ import path from 'node:path';
4
+ import { Readable } from 'node:stream';
5
+ import { FileSystemClaim } from '@t4h.framework/fs';
6
+ import mime from 'mime-types';
7
+ import { DevServerFileBinary } from './DevServerFileBinary.js';
8
+ export class DevServerFileSystemClaim extends FileSystemClaim {
9
+ async write(filepath, readable) {
10
+ const { base } = path.parse(filepath);
11
+ const tempDir = await fs.promises.mkdtemp(path.join(os.tmpdir(), 'fs-'));
12
+ const _filepath = path.join(tempDir, filepath);
13
+ await fs.promises.writeFile(_filepath, readable);
14
+ const stat = await fs.promises.stat(_filepath);
15
+ return DevServerFileBinary.from({
16
+ path: _filepath,
17
+ contentType: mime.lookup(base) || 'application/octet-stream',
18
+ contentLength: stat.size,
19
+ });
20
+ }
21
+ async read(filepath) {
22
+ const stat = await fs.promises.stat(filepath);
23
+ return DevServerFileBinary.from({
24
+ path: filepath,
25
+ contentType: mime.lookup(path.extname(filepath)) || 'application/octet-stream',
26
+ contentLength: stat.size,
27
+ });
28
+ }
29
+ }
30
+ //# sourceMappingURL=DevServerFileSystemClaim.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DevServerFileSystemClaim.js","sourceRoot":"","sources":["../../src/models/DevServerFileSystemClaim.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,SAAS,CAAA;AACxB,OAAO,EAAE,MAAM,SAAS,CAAA;AACxB,OAAO,IAAI,MAAM,WAAW,CAAA;AAC5B,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAA;AAEtC,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,IAAI,MAAM,YAAY,CAAA;AAE7B,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAA;AAE9D,MAAM,OAAO,wBAAyB,SAAQ,eAAe;IACpD,KAAK,CAAC,KAAK,CAChB,QAAgB,EAChB,QAAkB;QAElB,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QAErC,MAAM,OAAO,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,EAAE,EAAE,KAAK,CAAC,CAAC,CAAA;QAExE,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;QAE9C,MAAM,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAA;QAEhD,MAAM,IAAI,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QAE9C,OAAO,mBAAmB,CAAC,IAAI,CAAC;YAC9B,IAAI,EAAE,SAAS;YACf,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,0BAA0B;YAC5D,aAAa,EAAE,IAAI,CAAC,IAAI;SACzB,CAAC,CAAA;IACJ,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,QAAgB;QAChC,MAAM,IAAI,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAE7C,OAAO,mBAAmB,CAAC,IAAI,CAAC;YAC9B,IAAI,EAAE,QAAQ;YACd,WAAW,EACT,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,IAAI,0BAA0B;YACnE,aAAa,EAAE,IAAI,CAAC,IAAI;SACzB,CAAC,CAAA;IACJ,CAAC;CACF"}
@@ -0,0 +1,21 @@
1
+ import { HttpClientRequestClaim, } from '@t4h.framework/http';
2
+ import { Agent, request, interceptors } from 'undici';
3
+ export class DevServerHttpClientRequestClaim extends HttpClientRequestClaim {
4
+ async request(input) {
5
+ if (input.body instanceof URLSearchParams)
6
+ input.body = Buffer.from(input.body.toString());
7
+ const response = await request(input.url, {
8
+ method: input.method,
9
+ body: input.body,
10
+ headers: input.headers,
11
+ dispatcher: new Agent().compose(interceptors.redirect({ maxRedirections: 5 })),
12
+ });
13
+ const res = {
14
+ status: response.statusCode,
15
+ headers: response.headers,
16
+ body: response.body,
17
+ };
18
+ return res;
19
+ }
20
+ }
21
+ //# sourceMappingURL=DevServerHttpClientRequestClaim.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DevServerHttpClientRequestClaim.js","sourceRoot":"","sources":["../../src/models/DevServerHttpClientRequestClaim.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,GAGvB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAA;AAErD,MAAM,OAAO,+BAAgC,SAAQ,sBAAsB;IAClE,KAAK,CAAC,OAAO,CAClB,KAAkC;QAElC,IAAI,KAAK,CAAC,IAAI,YAAY,eAAe;YACvC,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAA;QAEjD,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE;YACxC,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,UAAU,EAAE,IAAI,KAAK,EAAE,CAAC,OAAO,CAC7B,YAAY,CAAC,QAAQ,CAAC,EAAE,eAAe,EAAE,CAAC,EAAE,CAAC,CAC9C;SACF,CAAC,CAAA;QAEF,MAAM,GAAG,GAAG;YACV,MAAM,EAAE,QAAQ,CAAC,UAAU;YAC3B,OAAO,EAAE,QAAQ,CAAC,OAAO;YACzB,IAAI,EAAE,QAAQ,CAAC,IAAI;SACpB,CAAA;QAED,OAAO,GAAG,CAAA;IACZ,CAAC;CACF"}
@@ -0,0 +1,37 @@
1
+ import fs from 'node:fs';
2
+ import path from 'node:path';
3
+ import { ORMClaim, } from '@t4h.framework/orm';
4
+ import { InMemoryDatabase } from './InMemoryDatabase.js';
5
+ import { jsonCodec } from '../tools/json-codec.js';
6
+ const dbPath = path.join(process.cwd(), 'db.json');
7
+ const initial = fs.existsSync(dbPath) ? fs.readFileSync(dbPath, 'utf8') : '{}';
8
+ const json = await jsonCodec.parse(initial, {});
9
+ const db = new InMemoryDatabase(json);
10
+ db.on('change', async () => {
11
+ fs.writeFileSync(dbPath, await jsonCodec.stringify(db.toJSON(), {}));
12
+ });
13
+ export class DevServerORMClaim extends ORMClaim {
14
+ find(input) {
15
+ return db
16
+ .table(input.table)
17
+ .find(input)
18
+ .map(row => row.id);
19
+ }
20
+ create(input) {
21
+ return db.table(input.table).insert(input.data);
22
+ }
23
+ getSnapshot(input) {
24
+ const [row] = db.table(input.table).find({
25
+ where: { id: input.ref },
26
+ limit: 1,
27
+ });
28
+ return row;
29
+ }
30
+ update(input) {
31
+ db.table(input.table).update({ id: input.ref }, input.data);
32
+ }
33
+ remove(input) {
34
+ db.table(input.table).delete({ id: input.ref });
35
+ }
36
+ }
37
+ //# sourceMappingURL=DevServerORMClaim.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DevServerORMClaim.js","sourceRoot":"","sources":["../../src/models/DevServerORMClaim.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,SAAS,CAAA;AACxB,OAAO,IAAI,MAAM,WAAW,CAAA;AAE5B,OAAO,EACL,QAAQ,GAOT,MAAM,oBAAoB,CAAA;AAE3B,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAA;AAElD,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAA;AAElD,MAAM,OAAO,GAAG,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;AAE9E,MAAM,IAAI,GAAG,MAAM,SAAS,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;AAE/C,MAAM,EAAE,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,CAAA;AAErC,EAAE,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,IAAI,EAAE;IACzB,EAAE,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC,CAAA;AACtE,CAAC,CAAC,CAAA;AAEF,MAAM,OAAO,iBAAkB,SAAQ,QAAgB;IAC9C,IAAI,CAAC,KAA4B;QACtC,OAAO,EAAE;aACN,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC;aAClB,IAAI,CAAC,KAAK,CAAC;aACX,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IACvB,CAAC;IAEM,MAAM,CAAC,KAA8B;QAC1C,OAAO,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IACjD,CAAC;IAEM,WAAW,CAChB,KAA2C;QAE3C,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC;YACvC,KAAK,EAAE,EAAE,EAAE,EAAE,KAAK,CAAC,GAAG,EAAE;YACxB,KAAK,EAAE,CAAC;SACT,CAAC,CAAA;QAEF,OAAO,GAAI,CAAA;IACb,CAAC;IAEM,MAAM,CAAC,KAAsC;QAClD,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,GAAG,EAAE,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;IAC7D,CAAC;IAEM,MAAM,CAAC,KAAsC;QAClD,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,GAAG,EAAE,CAAC,CAAA;IACjD,CAAC;CACF"}
@@ -0,0 +1,32 @@
1
+ import { SmtpSendEmailClaim, } from '@t4h.framework/smtp';
2
+ import nodemailer from 'nodemailer';
3
+ export class DevServerSmtpSendEmailClaim extends SmtpSendEmailClaim {
4
+ getTransport(input) {
5
+ const url = new URL(input.connectionString);
6
+ const secure = url.protocol === 'smtps:';
7
+ const port = url.port ? Number(url.port) : secure ? 465 : 587;
8
+ return nodemailer.createTransport({
9
+ host: url.hostname,
10
+ port,
11
+ secure,
12
+ auth: { user: url.username, pass: url.password },
13
+ });
14
+ }
15
+ async send(input) {
16
+ return await this.getTransport(input).sendMail({
17
+ from: input.from,
18
+ to: input.to.slice(),
19
+ cc: input.cc?.slice(),
20
+ bcc: input.bcc?.slice(),
21
+ subject: input.subject,
22
+ html: input.html,
23
+ attachments: await Promise.all(input.attachments?.map(async (attachment) => ({
24
+ filename: attachment.filename,
25
+ content: await attachment.content.stream(),
26
+ contentType: attachment.content.contentType,
27
+ contentDisposition: 'attachment',
28
+ })) ?? []),
29
+ });
30
+ }
31
+ }
32
+ //# sourceMappingURL=DevServerSmtpSendEmailClaim.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DevServerSmtpSendEmailClaim.js","sourceRoot":"","sources":["../../src/models/DevServerSmtpSendEmailClaim.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,GAEnB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,UAAU,MAAM,YAAY,CAAA;AAGnC,MAAM,OAAO,2BAA4B,SAAQ,kBAAkB;IACvD,YAAY,CAAC,KAAiC;QACtD,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAA;QAE3C,MAAM,MAAM,GAAG,GAAG,CAAC,QAAQ,KAAK,QAAQ,CAAA;QAExC,MAAM,IAAI,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAA;QAE7D,OAAO,UAAU,CAAC,eAAe,CAAC;YAChC,IAAI,EAAE,GAAG,CAAC,QAAQ;YAClB,IAAI;YACJ,MAAM;YACN,IAAI,EAAE,EAAE,IAAI,EAAE,GAAG,CAAC,QAAQ,EAAE,IAAI,EAAE,GAAG,CAAC,QAAQ,EAAE;SACjD,CAAC,CAAA;IACJ,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,KAAiC;QACjD,OAAO,MAAM,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC;YAC7C,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,EAAE,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE;YACpB,EAAE,EAAE,KAAK,CAAC,EAAE,EAAE,KAAK,EAAE;YACrB,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE,KAAK,EAAE;YACvB,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,WAAW,EAAE,MAAM,OAAO,CAAC,GAAG,CAC5B,KAAK,CAAC,WAAW,EAAE,GAAG,CACpB,KAAK,EAAE,UAAU,EAAuB,EAAE,CAAC,CAAC;gBAC1C,QAAQ,EAAE,UAAU,CAAC,QAAQ;gBAC7B,OAAO,EAAE,MAAM,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE;gBAC1C,WAAW,EAAE,UAAU,CAAC,OAAO,CAAC,WAAW;gBAC3C,kBAAkB,EAAE,YAAY;aACjC,CAAC,CACH,IAAI,EAAE,CACR;SACF,CAAC,CAAA;IACJ,CAAC;CACF"}
@@ -0,0 +1,28 @@
1
+ import fs from 'node:fs';
2
+ import { Binary } from '@t4h.framework/core';
3
+ export class FileBinary extends Binary {
4
+ path;
5
+ contentType;
6
+ contentLength;
7
+ stream;
8
+ constructor(path, contentType, contentLength, stream) {
9
+ super();
10
+ this.path = path;
11
+ this.contentType = contentType;
12
+ this.contentLength = contentLength;
13
+ this.stream = stream;
14
+ }
15
+ static from(file) {
16
+ return new this(file.path, file.contentType, file.contentLength, function () {
17
+ return fs.createReadStream(this.path);
18
+ });
19
+ }
20
+ toJSON() {
21
+ return {
22
+ path: this.path,
23
+ contentType: this.contentType,
24
+ contentLength: this.contentLength,
25
+ };
26
+ }
27
+ }
28
+ //# sourceMappingURL=FileBinary.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FileBinary.js","sourceRoot":"","sources":["../../src/models/FileBinary.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,SAAS,CAAA;AAGxB,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAE5C,MAAM,OAAO,UAAW,SAAQ,MAAM;IAElB;IACA;IACA;IACA;IAJlB,YACkB,IAAY,EACZ,WAAmB,EACnB,aAAqB,EACrB,MAA0D;QAE1E,KAAK,EAAE,CAAA;QALS,SAAI,GAAJ,IAAI,CAAQ;QACZ,gBAAW,GAAX,WAAW,CAAQ;QACnB,kBAAa,GAAb,aAAa,CAAQ;QACrB,WAAM,GAAN,MAAM,CAAoD;IAG5E,CAAC;IAEM,MAAM,CAAC,IAAI,CAAC,IAAsC;QACvD,OAAO,IAAI,IAAI,CACb,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,aAAa,EAClB;YACE,OAAO,EAAE,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACvC,CAAC,CACF,CAAA;IACH,CAAC;IAEM,MAAM;QACX,OAAO;YACL,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,aAAa,EAAE,IAAI,CAAC,aAAa;SAClC,CAAA;IACH,CAAC;CACF"}
@@ -0,0 +1,86 @@
1
+ import EventEmitter from 'node:events';
2
+ import sift from 'sift';
3
+ import { uuidv7 } from 'uuidv7';
4
+ export class InMemoryDatabaseTable extends EventEmitter {
5
+ rows = [];
6
+ _sort(rows, orderBy) {
7
+ const entries = Object.entries(orderBy);
8
+ return rows.toSorted((rowA, rowB) => {
9
+ for (const [key, dir] of entries) {
10
+ const rowAPropertyValue = rowA[key];
11
+ const rowBPropertyValue = rowB[key];
12
+ if (rowAPropertyValue === rowBPropertyValue)
13
+ continue;
14
+ if (rowAPropertyValue == null)
15
+ return dir === 'asc' ? -1 : 1;
16
+ if (rowBPropertyValue == null)
17
+ return dir === 'asc' ? 1 : -1;
18
+ const cmp = rowAPropertyValue < rowBPropertyValue ? -1 : 1;
19
+ return dir === 'asc' ? cmp : -cmp;
20
+ }
21
+ return 0;
22
+ });
23
+ }
24
+ find(options) {
25
+ // @ts-expect-error: todo
26
+ let rows = this.rows.filter(sift(options.where));
27
+ if (options.orderBy)
28
+ rows = this._sort(rows, options.orderBy);
29
+ if (options.offset)
30
+ rows = rows.slice(options.offset);
31
+ if (options.limit)
32
+ rows = rows.slice(0, options.limit);
33
+ return rows;
34
+ }
35
+ insert(rows) {
36
+ const ids = rows.map(row => {
37
+ const id = uuidv7();
38
+ this.rows.push({ id, ...row });
39
+ return id;
40
+ });
41
+ this.emit('change');
42
+ return ids;
43
+ }
44
+ update(where, row) {
45
+ const rows = this.find({ where });
46
+ for (const inMemoryRow of rows)
47
+ this.rows.splice(this.rows.indexOf(inMemoryRow), 1, {
48
+ ...inMemoryRow,
49
+ ...row,
50
+ });
51
+ this.emit('change');
52
+ return rows.length;
53
+ }
54
+ delete(where) {
55
+ const rows = this.find({ where });
56
+ for (const inMemoryRow of rows)
57
+ this.rows.splice(this.rows.indexOf(inMemoryRow), 1);
58
+ this.emit('change');
59
+ }
60
+ toJSON() {
61
+ return this.rows;
62
+ }
63
+ }
64
+ export class InMemoryDatabase extends EventEmitter {
65
+ tables = new Map();
66
+ constructor(initial = {}) {
67
+ super();
68
+ for (const [name, rows] of Object.entries(initial))
69
+ this.table(name).insert(rows);
70
+ }
71
+ table(name) {
72
+ if (!this.tables.has(name)) {
73
+ const table = new InMemoryDatabaseTable();
74
+ this.tables.set(name, table);
75
+ table.on('change', () => this.emit('change', table));
76
+ }
77
+ return this.tables.get(name);
78
+ }
79
+ toJSON() {
80
+ return Object.fromEntries(Array.from(this.tables.entries()).map(([name, table]) => [
81
+ name,
82
+ table.toJSON(),
83
+ ]));
84
+ }
85
+ }
86
+ //# sourceMappingURL=InMemoryDatabase.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InMemoryDatabase.js","sourceRoot":"","sources":["../../src/models/InMemoryDatabase.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,110 @@
1
+ export class JSONCodecKind {
2
+ kind;
3
+ test;
4
+ serialize;
5
+ parse;
6
+ constructor(kind, test, serialize, parse) {
7
+ this.kind = kind;
8
+ this.test = test;
9
+ this.serialize = serialize;
10
+ this.parse = parse;
11
+ }
12
+ }
13
+ export class JSONCodec {
14
+ kinds = new Map();
15
+ constructor(...kinds) {
16
+ for (const kind of kinds) {
17
+ if (this.kinds.has(kind.kind))
18
+ throw new Error(`Kind ${kind.kind} already registered`);
19
+ this.kinds.set(kind.kind, kind);
20
+ }
21
+ }
22
+ _isKind(value) {
23
+ if (typeof value !== 'object')
24
+ return false;
25
+ if (value === null)
26
+ return false;
27
+ if (!('~kind' in value))
28
+ return false;
29
+ if (typeof value['~kind'] !== 'string')
30
+ return false;
31
+ return this.kinds.has(value['~kind']);
32
+ }
33
+ _getKind(value) {
34
+ if (!this._isKind(value))
35
+ throw new Error('Invalid kind');
36
+ return this.kinds.get(value['~kind']);
37
+ }
38
+ async transform(value, config) {
39
+ if (value === null)
40
+ return null;
41
+ if (typeof value !== 'object')
42
+ return value;
43
+ if (Array.isArray(value)) {
44
+ const out = new Array(value.length);
45
+ for (let i = 0; i < value.length; i++) {
46
+ const transformedValue = await this.transform(value[i], config);
47
+ out[i] = transformedValue === undefined ? null : transformedValue;
48
+ }
49
+ return out;
50
+ }
51
+ const { seen, cache, get, mapper } = config;
52
+ const kind = get(value);
53
+ if (kind) {
54
+ if (!cache.has(value))
55
+ cache.set(value, mapper(value, kind));
56
+ return cache.get(value);
57
+ }
58
+ const previous = seen.get(value);
59
+ if (previous)
60
+ return previous;
61
+ const out = {};
62
+ seen.set(value, out);
63
+ for (const [key, v] of Object.entries(value)) {
64
+ const tv = await this.transform(v, config);
65
+ if (tv !== undefined)
66
+ out[key] = tv;
67
+ }
68
+ return out;
69
+ }
70
+ async _parse(value, options) {
71
+ const seen = new WeakMap();
72
+ const cache = new WeakMap();
73
+ const get = (value) => this._isKind(value) && this._getKind(value);
74
+ return await this.transform(value, {
75
+ seen,
76
+ cache,
77
+ get,
78
+ mapper: (value, kind) => {
79
+ if ('~value' in value)
80
+ value = value['~value'];
81
+ return kind.parse(value, options, value => this._parse(value, options));
82
+ },
83
+ });
84
+ }
85
+ async parse(text, options) {
86
+ return await this._parse(JSON.parse(text), options);
87
+ }
88
+ async _stringify(value, options) {
89
+ const seen = new WeakMap();
90
+ const cache = new WeakMap();
91
+ return await this.transform(value, {
92
+ seen,
93
+ cache,
94
+ get: value => this.kinds.values().find(kind => kind.test(value)),
95
+ mapper: async (value, kind) => {
96
+ const serializedValue = await kind.serialize(value, options, value => this._stringify(value, options));
97
+ if (typeof serializedValue === 'string')
98
+ return {
99
+ '~kind': kind.kind,
100
+ '~value': serializedValue,
101
+ };
102
+ return { '~kind': kind.kind, ...serializedValue };
103
+ },
104
+ });
105
+ }
106
+ async stringify(value, options) {
107
+ return JSON.stringify(await this._stringify(value, options));
108
+ }
109
+ }
110
+ //# sourceMappingURL=JSONCodec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JSONCodec.js","sourceRoot":"","sources":["../../src/models/JSONCodec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import { JSONCodecKind } from './JSONCodec.js';
2
+ export class JSONCodecKindFrameworkSerializableClass extends JSONCodecKind {
3
+ constructor(kind, constructor) {
4
+ super(kind, (value) => value instanceof constructor, (value, options, serializer) => value.toSerializable(serializer), (value, options, deserializer) => constructor.fromSerializable(value, deserializer));
5
+ }
6
+ }
7
+ //# sourceMappingURL=JSONCodecKindFrameworkSerializableClass.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JSONCodecKindFrameworkSerializableClass.js","sourceRoot":"","sources":["../../src/models/JSONCodecKindFrameworkSerializableClass.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAA;AAE9C,MAAM,OAAO,uCAGX,SAAQ,aAQT;IACC,YACE,IAAW,EACX,WAMC;QAED,KAAK,CACH,IAAI,EACJ,CAAC,KAAK,EAAc,EAAE,CAAC,KAAK,YAAY,WAAW,EACnD,CAAC,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,CAC7B,KAAK,CAAC,cAAc,CAAC,UAAU,CAE9B,EACH,CAAC,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,EAAE,CAC/B,WAAW,CAAC,gBAAgB,CAAC,KAAK,EAAE,YAAY,CAAC,CACpD,CAAA;IACH,CAAC;CACF"}
@@ -0,0 +1,50 @@
1
+ import { uuidv7 } from 'uuidv7';
2
+ export class JSONRPCClient {
3
+ send;
4
+ listeners = [];
5
+ constructor(send) {
6
+ this.send = send;
7
+ }
8
+ addListener(listener) {
9
+ this.listeners.push(listener);
10
+ return () => {
11
+ this.listeners.splice(this.listeners.indexOf(listener), 1);
12
+ };
13
+ }
14
+ async call(method, ...params) {
15
+ const id = uuidv7();
16
+ const message = { jsonrpc: '2.0', id, method, params };
17
+ const promise = new Promise((resolve, reject) => {
18
+ const off = this.addListener(response => {
19
+ if (response.id !== id)
20
+ return;
21
+ off();
22
+ if ('result' in response)
23
+ resolve(response.result);
24
+ else
25
+ reject(new Error(response.error.message));
26
+ });
27
+ });
28
+ await this.send(JSON.stringify(message));
29
+ return promise;
30
+ }
31
+ async notify(method, ...params) {
32
+ const message = { jsonrpc: '2.0', method, params };
33
+ await this.send(JSON.stringify(message));
34
+ }
35
+ async handle(message) {
36
+ if (typeof message === 'string')
37
+ return this.handle(JSON.parse(message));
38
+ if (Buffer.isBuffer(message))
39
+ return this.handle(message.toString());
40
+ const json = message;
41
+ if (json.jsonrpc !== '2.0')
42
+ throw new Error('Invalid JSON-RPC message');
43
+ if (!('id' in json))
44
+ return;
45
+ if (json.id === undefined)
46
+ return;
47
+ this.listeners.forEach(listener => listener(json));
48
+ }
49
+ }
50
+ //# sourceMappingURL=JSONRPCClient.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JSONRPCClient.js","sourceRoot":"","sources":["../../src/models/JSONRPCClient.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAU/B,MAAM,OAAO,aAAa;IAKK;IAJZ,SAAS,GAEX,EAAE,CAAA;IAEjB,YAA6B,IAAuB;QAAvB,SAAI,GAAJ,IAAI,CAAmB;IAAG,CAAC;IAEjD,WAAW,CAChB,QAES;QAET,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAE7B,OAAO,GAAG,EAAE;YACV,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAA;QAC5D,CAAC,CAAA;IACH,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,MAAc,EAAE,GAAG,MAAa;QAChD,MAAM,EAAE,GAAG,MAAM,EAAE,CAAA;QAEnB,MAAM,OAAO,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,EAAW,CAAA;QAE/D,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE;gBACtC,IAAI,QAAQ,CAAC,EAAE,KAAK,EAAE;oBAAE,OAAM;gBAE9B,GAAG,EAAE,CAAA;gBAEL,IAAI,QAAQ,IAAI,QAAQ;oBAAE,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA;;oBAC7C,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAA;YAChD,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,MAAM,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAA;QAExC,OAAO,OAAO,CAAA;IAChB,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,MAAc,EAAE,GAAG,MAAa;QAClD,MAAM,OAAO,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAW,CAAA;QAE3D,MAAM,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAA;IAC1C,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,OAAY;QAC9B,IAAI,OAAO,OAAO,KAAK,QAAQ;YAAE,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAA;QAExE,IAAI,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC;YAAE,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAA;QAEpE,MAAM,IAAI,GAAG,OAA0B,CAAA;QAEvC,IAAI,IAAI,CAAC,OAAO,KAAK,KAAK;YAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAA;QAEvE,IAAI,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC;YAAE,OAAM;QAE3B,IAAI,IAAI,CAAC,EAAE,KAAK,SAAS;YAAE,OAAM;QAEjC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAA;IACpD,CAAC;CACF"}
@@ -0,0 +1,61 @@
1
+ import { Ajv } from 'ajv';
2
+ import Type from 'typebox';
3
+ const ajv = new Ajv();
4
+ export class JSONRPCServerMethod {
5
+ name;
6
+ schema;
7
+ validate;
8
+ fn;
9
+ constructor(name, configOrFn, maybeFn) {
10
+ if (typeof configOrFn === 'function') {
11
+ this.name = name;
12
+ this.schema = [];
13
+ this.fn = configOrFn;
14
+ }
15
+ else if (typeof maybeFn === 'function') {
16
+ this.name = name;
17
+ this.schema = configOrFn.schema ?? [];
18
+ this.fn = maybeFn;
19
+ }
20
+ else
21
+ throw new Error('Invalid constructor arguments');
22
+ this.validate = this.schema.map(schema => ajv.compile(schema));
23
+ }
24
+ async call(params) {
25
+ if (!Array.isArray(params))
26
+ return this.call([params]);
27
+ const isValid = this.validate.every((validate, index) => validate(params[index]));
28
+ if (!isValid)
29
+ throw new Error('Invalid parameters');
30
+ return await this.fn(...params);
31
+ }
32
+ }
33
+ export class JSONRPCServer {
34
+ methods;
35
+ send;
36
+ constructor(methods, send) {
37
+ this.methods = methods;
38
+ this.send = send;
39
+ }
40
+ async handle(message) {
41
+ if (typeof message === 'string')
42
+ return this.handle(JSON.parse(message));
43
+ if (Buffer.isBuffer(message))
44
+ return this.handle(message.toString());
45
+ if (typeof message !== 'object')
46
+ return;
47
+ if (!message)
48
+ return;
49
+ if (!('method' in message))
50
+ return;
51
+ const method = this.methods.find(method => method.name === message.method);
52
+ if (!method)
53
+ throw new Error(`Method ${message.method} not found`);
54
+ const result = (await method.call(message.params)) ?? null;
55
+ await this.send(JSON.stringify({ jsonrpc: '2.0', id: message.id, result }));
56
+ }
57
+ async notify(method, ...params) {
58
+ await this.send(JSON.stringify({ jsonrpc: '2.0', method, params }));
59
+ }
60
+ }
61
+ //# sourceMappingURL=JSONRPCServer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JSONRPCServer.js","sourceRoot":"","sources":["../../src/models/JSONRPCServer.ts"],"names":[],"mappings":"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"}