@stateflowx/runtime 0.4.19 → 0.4.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/core/runtime/Runtime.d.ts +2 -1
- package/dist/core/runtime/Runtime.js +4 -1
- package/dist/core/runtime/Runtime.js.map +1 -1
- package/dist/core/runtime/create-runtime-config.interface.d.ts +1 -1
- package/dist/core/runtime/create-runtime.js +22 -34
- package/dist/core/runtime/create-runtime.js.map +1 -1
- package/dist/core/runtime/normalize-runtime-config.js +4 -1
- package/dist/core/runtime/normalize-runtime-config.js.map +1 -1
- package/dist/core/runtime/runtime-options.interface.d.ts +1 -1
- package/dist/core/transport/Runtime.module.d.ts +2 -0
- package/dist/{websocket-runtime.module.js → core/transport/Runtime.module.js} +19 -10
- package/dist/core/transport/Runtime.module.js.map +1 -0
- package/dist/core/transport/http/http.transport.d.ts +2 -0
- package/dist/core/transport/http/http.transport.js +11 -1
- package/dist/core/transport/http/http.transport.js.map +1 -1
- package/dist/core/transport/transport-capabilities.interface.d.ts +15 -0
- package/dist/core/transport/transport-capabilities.interface.js +2 -0
- package/dist/core/transport/transport-capabilities.interface.js.map +1 -0
- package/dist/core/transport/transport.interface.d.ts +2 -0
- package/dist/core/transport/ws/ws.transport.d.ts +2 -0
- package/dist/core/transport/ws/ws.transport.js +5 -0
- package/dist/core/transport/ws/ws.transport.js.map +1 -1
- package/dist/http/bootstrap-http-runtime.d.ts +6 -1
- package/dist/http/bootstrap-http-runtime.js +17 -2
- package/dist/http/bootstrap-http-runtime.js.map +1 -1
- package/dist/main.js +9 -15
- package/dist/main.js.map +1 -1
- package/package.json +1 -1
- package/dist/websocket-runtime.module.d.ts +0 -2
- package/dist/websocket-runtime.module.js.map +0 -1
|
@@ -3,6 +3,7 @@ import { WebSocketEventDispatcher } from "../events/dispatchers/ws/websocket-eve
|
|
|
3
3
|
import { RuntimeEventBus } from "../events/runtime-event-bus.js";
|
|
4
4
|
import { ProviderManager } from "../provider/provider.manager.js";
|
|
5
5
|
import { ServiceManager } from "../service/service.manager.js";
|
|
6
|
+
import { Transport } from "../transport/transport.interface.js";
|
|
6
7
|
import { ExecutionManager } from "./execution/execution-manager.js";
|
|
7
8
|
import { RuntimeOptions } from "./runtime-options.interface.js";
|
|
8
9
|
export declare class Runtime {
|
|
@@ -10,7 +11,7 @@ export declare class Runtime {
|
|
|
10
11
|
private started;
|
|
11
12
|
readonly apiKey: string;
|
|
12
13
|
readonly db: import("../db.interface.js").DB;
|
|
13
|
-
readonly
|
|
14
|
+
readonly transports: Transport[];
|
|
14
15
|
readonly protocol: import("../protocol/protocol.interface.js").Protocol;
|
|
15
16
|
readonly events: RuntimeEventBus;
|
|
16
17
|
readonly execution: ExecutionManager;
|
|
@@ -11,7 +11,10 @@ export class Runtime {
|
|
|
11
11
|
this.dispatchers = [];
|
|
12
12
|
this.apiKey = options.apiKey;
|
|
13
13
|
this.db = options.db ?? new InMemoryDB();
|
|
14
|
-
this.
|
|
14
|
+
this.transports = options.transports;
|
|
15
|
+
// this.transports =
|
|
16
|
+
// options.transports ??
|
|
17
|
+
// (options.transport ? [options.transport] : []);
|
|
15
18
|
this.protocol = options.protocol;
|
|
16
19
|
this.events =
|
|
17
20
|
options.events ?? new RuntimeEventBus();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Runtime.js","sourceRoot":"","sources":["../../../src/core/runtime/Runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAGzD,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AAEjE,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAElE,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAE/D,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;
|
|
1
|
+
{"version":3,"file":"Runtime.js","sourceRoot":"","sources":["../../../src/core/runtime/Runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAGzD,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AAEjE,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAElE,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAE/D,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAGxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAOpE,MAAM,OAAO,OAAO;IA0BhB,YAAY,OAAuB;QAxB3B,gBAAW,GAAG,KAAK,CAAC;QAEpB,YAAO,GAAG,KAAK,CAAC;QAoBP,gBAAW,GAA6B,EAAE,CAAC;QAIxD,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;QAE7B,IAAI,CAAC,EAAE,GAAG,OAAO,CAAC,EAAE,IAAI,IAAI,UAAU,EAAE,CAAC;QAEzC,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;QAErC,oBAAoB;QACpB,4BAA4B;QAC5B,sDAAsD;QAEtD,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;QAEjC,IAAI,CAAC,MAAM;YACP,OAAO,CAAC,MAAM,IAAI,IAAI,eAAe,EAAE,CAAC;QAE5C,IAAI,CAAC,SAAS;YACV,IAAI,eAAe,CAAC,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC;QAEjD,IAAI,CAAC,QAAQ;YACT,IAAI,cAAc,CAAC,OAAO,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC;QAE/C,IAAI,CAAC,MAAM;YACP,IAAI,YAAY,CAAC,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;QAE3C,IAAI,CAAC,SAAS;YACV,IAAI,gBAAgB,EAAE,CAAC;IAE/B,CAAC;IAGD,KAAK,CAAC,UAAU;QAEZ,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,OAAO;QACX,CAAC;QAED,KAAK,MAAM,UAAU,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YAExC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,KAAK,EAAC,KAAK,EAAC,EAAE;gBAC9B,MAAM,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACrC,CAAC,CAAC,CAAC;QAEP,CAAC;QAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,KAAK;QAEP,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;QACzD,CAAC;QAED,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,OAAO;QACX,CAAC;QAED,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IAExB,CAAC;IAED,kBAAkB,CAAC,UAAoC;QACnD,IAAI,CAAC,MAAM,EAAE,EAAE,CACX,GAAG,EAEH,KAAK,EAAE,KAAK,EAAE,EAAE;YACZ,MAAM,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACrC,CAAC,CACJ,CAAC;IACN,CAAC;CAEJ"}
|
|
@@ -6,7 +6,7 @@ import { Protocol } from '../protocol/protocol.interface.js';
|
|
|
6
6
|
import { AgentConfig } from '@stateflowx/common';
|
|
7
7
|
export interface CreateRuntimeConfig {
|
|
8
8
|
apiKey?: string;
|
|
9
|
-
|
|
9
|
+
transports: Transport[];
|
|
10
10
|
protocol: Protocol;
|
|
11
11
|
agents?: AgentConfig[];
|
|
12
12
|
providers: ProviderConfig[];
|
|
@@ -6,41 +6,29 @@ export function createRuntime(config) {
|
|
|
6
6
|
const options = normalizeRuntimeConfig(config);
|
|
7
7
|
const runtime = new Runtime(options);
|
|
8
8
|
initializeRuntimeCapabilities(runtime);
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
payload
|
|
9
|
+
for (const transport of runtime.transports) {
|
|
10
|
+
transport.onMessage(async (clientId, payload) => {
|
|
11
|
+
runtime.events?.emit({
|
|
12
|
+
id: randomUUID(),
|
|
13
|
+
type: 'runtime.message.received',
|
|
14
|
+
timestamp: Date.now(),
|
|
15
|
+
source: 'transport',
|
|
16
|
+
payload,
|
|
17
|
+
});
|
|
18
|
+
const response = await runtime.protocol.receive(payload);
|
|
19
|
+
if (response !== undefined) {
|
|
20
|
+
await transport.send(clientId, response);
|
|
21
|
+
}
|
|
22
|
+
runtime.events?.emit({
|
|
23
|
+
id: randomUUID(),
|
|
24
|
+
type: 'runtime.message.completed',
|
|
25
|
+
timestamp: Date.now(),
|
|
26
|
+
source: 'runtime',
|
|
27
|
+
payload: response,
|
|
28
|
+
});
|
|
29
|
+
return response;
|
|
19
30
|
});
|
|
20
|
-
|
|
21
|
-
//
|
|
22
|
-
// Push-based transports
|
|
23
|
-
// (WebSocket, MQTT, TCP)
|
|
24
|
-
//
|
|
25
|
-
if (response !== undefined) {
|
|
26
|
-
await runtime.transport.send(clientId, response);
|
|
27
|
-
}
|
|
28
|
-
//
|
|
29
|
-
// Runtime response event
|
|
30
|
-
//
|
|
31
|
-
runtime.events?.emit({
|
|
32
|
-
id: randomUUID(),
|
|
33
|
-
type: 'runtime.message.completed',
|
|
34
|
-
timestamp: Date.now(),
|
|
35
|
-
source: 'runtime',
|
|
36
|
-
payload: response,
|
|
37
|
-
});
|
|
38
|
-
//
|
|
39
|
-
// HTTP transports will ignore
|
|
40
|
-
// transport.send() and instead return the response directly
|
|
41
|
-
//
|
|
42
|
-
return response;
|
|
43
|
-
});
|
|
31
|
+
}
|
|
44
32
|
return runtime;
|
|
45
33
|
}
|
|
46
34
|
//# sourceMappingURL=create-runtime.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-runtime.js","sourceRoot":"","sources":["../../../src/core/runtime/create-runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEpC,OAAO,EAAE,6BAA6B,EAAE,MAAM,4CAA4C,CAAC;AAI3F,OAAO,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAC;AAIvE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,MAAM,UAAU,aAAa,CAAC,MAA2B;IAEvD,MAAM,OAAO,GAAmB,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAE/D,MAAM,OAAO,GACX,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;IAEvB,6BAA6B,CAAC,OAAO,CAAC,CAAC;IAEvC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE;
|
|
1
|
+
{"version":3,"file":"create-runtime.js","sourceRoot":"","sources":["../../../src/core/runtime/create-runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEpC,OAAO,EAAE,6BAA6B,EAAE,MAAM,4CAA4C,CAAC;AAI3F,OAAO,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAC;AAIvE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,MAAM,UAAU,aAAa,CAAC,MAA2B;IAEvD,MAAM,OAAO,GAAmB,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAE/D,MAAM,OAAO,GACX,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;IAEvB,6BAA6B,CAAC,OAAO,CAAC,CAAC;IAEvC,KAAK,MAAM,SAAS,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;QAE3C,SAAS,CAAC,SAAS,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE;YAE9C,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC;gBACnB,EAAE,EAAE,UAAU,EAAE;gBAChB,IAAI,EAAE,0BAA0B;gBAChC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;gBACrB,MAAM,EAAE,WAAW;gBACnB,OAAO;aACR,CAAC,CAAC;YAEH,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAEzD,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;gBAC3B,MAAM,SAAS,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;YAC3C,CAAC;YAED,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC;gBACnB,EAAE,EAAE,UAAU,EAAE;gBAChB,IAAI,EAAE,2BAA2B;gBACjC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;gBACrB,MAAM,EAAE,SAAS;gBACjB,OAAO,EAAE,QAAQ;aAClB,CAAC,CAAC;YAEH,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAC,CAAC;IACL,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
|
@@ -3,7 +3,10 @@ export function normalizeRuntimeConfig(config) {
|
|
|
3
3
|
return {
|
|
4
4
|
apiKey: config?.apiKey ?? process.env.GEMINI_API_KEY ?? '',
|
|
5
5
|
db: config.db ?? new InMemoryDB(),
|
|
6
|
-
|
|
6
|
+
transports: config.transports,
|
|
7
|
+
// transports:
|
|
8
|
+
// config.transports ??
|
|
9
|
+
// (config.transport ? [config.transport] : []),
|
|
7
10
|
protocol: config.protocol,
|
|
8
11
|
agents: config.agents,
|
|
9
12
|
providers: config.providers,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"normalize-runtime-config.js","sourceRoot":"","sources":["../../../src/core/runtime/normalize-runtime-config.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAExD,MAAM,UAAU,sBAAsB,CACpC,MAA2B;IAE3B,OAAO;QACL,MAAM,EAAE,MAAM,EAAE,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,EAAE;QAE1D,EAAE,EAAE,MAAM,CAAC,EAAE,IAAI,IAAI,UAAU,EAAE;QAEjC,
|
|
1
|
+
{"version":3,"file":"normalize-runtime-config.js","sourceRoot":"","sources":["../../../src/core/runtime/normalize-runtime-config.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAExD,MAAM,UAAU,sBAAsB,CACpC,MAA2B;IAE3B,OAAO;QACL,MAAM,EAAE,MAAM,EAAE,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,EAAE;QAE1D,EAAE,EAAE,MAAM,CAAC,EAAE,IAAI,IAAI,UAAU,EAAE;QAEjC,UAAU,EAAE,MAAM,CAAC,UAAU;QAE7B,cAAc;QACd,yBAAyB;QACzB,kDAAkD;QAElD,QAAQ,EAAE,MAAM,CAAC,QAAQ;QAEzB,MAAM,EAAE,MAAM,CAAC,MAAM;QAErB,SAAS,EAAE,MAAM,CAAC,SAAS;QAE3B,QAAQ,EAAE,MAAM,CAAC,QAAQ;QAEzB,SAAS,EAAE;YACT,OAAO,EAAE,MAAM,CAAC,SAAS,EAAE,OAAO,IAAI,KAAK;YAE3C,MAAM,EAAE;gBACN,OAAO,EAAE,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,IAAI,KAAK;aACpD;YAED,SAAS,EAAE;gBACT,OAAO,EAAE,MAAM,CAAC,SAAS,EAAE,SAAS,EAAE,OAAO,IAAI,KAAK;aACvD;SACF;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -7,7 +7,7 @@ import { ServiceConfig } from '../service/service-config.interface.js';
|
|
|
7
7
|
import { Transport } from '../transport/transport.interface.js';
|
|
8
8
|
export interface RuntimeOptions {
|
|
9
9
|
apiKey: string;
|
|
10
|
-
|
|
10
|
+
transports: Transport[];
|
|
11
11
|
protocol: Protocol;
|
|
12
12
|
agents?: AgentConfig[];
|
|
13
13
|
providers: ProviderConfig[];
|
|
@@ -4,16 +4,25 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
4
4
|
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
5
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
6
|
};
|
|
7
|
-
import { Module } from
|
|
8
|
-
import
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
let
|
|
7
|
+
import { Module } from "@nestjs/common";
|
|
8
|
+
import { HttpRpcController } from "./http/http.controller.js";
|
|
9
|
+
import { HttpTransport } from "./http/http.transport.js";
|
|
10
|
+
import EventsGateway from "./ws/events.gateway.js";
|
|
11
|
+
let RuntimeModule = class RuntimeModule {
|
|
12
12
|
};
|
|
13
|
-
|
|
13
|
+
RuntimeModule = __decorate([
|
|
14
14
|
Module({
|
|
15
|
-
|
|
15
|
+
controllers: [
|
|
16
|
+
HttpRpcController,
|
|
17
|
+
],
|
|
18
|
+
providers: [
|
|
19
|
+
HttpTransport,
|
|
20
|
+
EventsGateway,
|
|
21
|
+
],
|
|
22
|
+
exports: [
|
|
23
|
+
HttpTransport,
|
|
24
|
+
],
|
|
16
25
|
})
|
|
17
|
-
],
|
|
18
|
-
export {
|
|
19
|
-
//# sourceMappingURL=
|
|
26
|
+
], RuntimeModule);
|
|
27
|
+
export { RuntimeModule };
|
|
28
|
+
//# sourceMappingURL=Runtime.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Runtime.module.js","sourceRoot":"","sources":["../../../src/core/transport/Runtime.module.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AACxC,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,aAAa,MAAM,wBAAwB,CAAC;AAgB5C,IAAM,aAAa,GAAnB,MAAM,aAAa;CAAG,CAAA;AAAhB,aAAa;IAdzB,MAAM,CAAC;QACN,WAAW,EAAE;YACX,iBAAiB;SAClB;QAED,SAAS,EAAE;YACT,aAAa;YACb,aAAa;SACd;QAED,OAAO,EAAE;YACP,aAAa;SACd;KACF,CAAC;GACW,aAAa,CAAG"}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
|
+
import { TransportCapabilities } from '../transport-capabilities.interface.js';
|
|
1
2
|
import { Transport } from '../transport.interface.js';
|
|
2
3
|
export declare class HttpTransport implements Transport {
|
|
4
|
+
readonly capabilities: TransportCapabilities;
|
|
3
5
|
private messageHandler?;
|
|
4
6
|
onMessage(handler: (clientId: string, payload: unknown) => Promise<unknown>): void;
|
|
5
7
|
handleRequest(payload: unknown): Promise<unknown>;
|
|
@@ -1,10 +1,20 @@
|
|
|
1
1
|
export class HttpTransport {
|
|
2
|
+
constructor() {
|
|
3
|
+
this.capabilities = {
|
|
4
|
+
duplex: false,
|
|
5
|
+
supportsEvents: false,
|
|
6
|
+
persistent: false,
|
|
7
|
+
};
|
|
8
|
+
}
|
|
2
9
|
onMessage(handler) {
|
|
3
10
|
this.messageHandler = handler;
|
|
4
11
|
}
|
|
5
12
|
async handleRequest(payload) {
|
|
13
|
+
// if (!this.messageHandler) {
|
|
14
|
+
// return;
|
|
15
|
+
// }
|
|
6
16
|
if (!this.messageHandler) {
|
|
7
|
-
|
|
17
|
+
throw new Error("HTTP transport has no message handler registered.");
|
|
8
18
|
}
|
|
9
19
|
return this.messageHandler('http-client', payload);
|
|
10
20
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"http.transport.js","sourceRoot":"","sources":["../../../../src/core/transport/http/http.transport.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"http.transport.js","sourceRoot":"","sources":["../../../../src/core/transport/http/http.transport.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,aAAa;IAA1B;QAEW,iBAAY,GAA0B;YAC7C,MAAM,EAAE,KAAK;YACb,cAAc,EAAE,KAAK;YACrB,UAAU,EAAE,KAAK;SAClB,CAAC;IA+BJ,CAAC;IAxBC,SAAS,CACP,OAAiE;QAEjE,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,OAAgB;QAElC,8BAA8B;QAC9B,YAAY;QACZ,IAAI;QACJ,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;QACvE,CAAC;QAED,OAAO,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;IAErD,CAAC;IAED,KAAK,CAAC,IAAI,KAAoB,CAAC;IAE/B,KAAK,CAAC,KAAK,KAAoB,CAAC;IAEhC,KAAK,CAAC,IAAI,KAAoB,CAAC;CAChC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export interface TransportCapabilities {
|
|
2
|
+
/**
|
|
3
|
+
* Indicates whether the transport supports bidirectional communication
|
|
4
|
+
*/
|
|
5
|
+
readonly duplex: boolean;
|
|
6
|
+
/**
|
|
7
|
+
* Indicates whether the transport supports runtime event streaming
|
|
8
|
+
*/
|
|
9
|
+
readonly supportsEvents: boolean;
|
|
10
|
+
/**
|
|
11
|
+
* Indicates whether the transport maintains a persistent connection.
|
|
12
|
+
*
|
|
13
|
+
*/
|
|
14
|
+
readonly persistent: boolean;
|
|
15
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transport-capabilities.interface.js","sourceRoot":"","sources":["../../../src/core/transport/transport-capabilities.interface.ts"],"names":[],"mappings":""}
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
+
import { TransportCapabilities } from "./transport-capabilities.interface.js";
|
|
1
2
|
export interface Transport {
|
|
3
|
+
readonly capabilities: TransportCapabilities;
|
|
2
4
|
start(): Promise<void>;
|
|
3
5
|
stop(): Promise<void>;
|
|
4
6
|
onMessage(handler: (clientId: string, payload: unknown) => Promise<unknown>): void;
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { WebSocketServer } from 'ws';
|
|
2
2
|
import { Transport } from '../transport.interface.js';
|
|
3
|
+
import { TransportCapabilities } from '../transport-capabilities.interface.js';
|
|
3
4
|
export declare class WebSocketTransport implements Transport {
|
|
4
5
|
private server;
|
|
6
|
+
readonly capabilities: TransportCapabilities;
|
|
5
7
|
private clients;
|
|
6
8
|
private messageHandler?;
|
|
7
9
|
constructor(server: WebSocketServer);
|
|
@@ -3,6 +3,11 @@ import { logger } from '../../logger/logger.js';
|
|
|
3
3
|
export class WebSocketTransport {
|
|
4
4
|
constructor(server) {
|
|
5
5
|
this.server = server;
|
|
6
|
+
this.capabilities = {
|
|
7
|
+
duplex: true,
|
|
8
|
+
supportsEvents: true,
|
|
9
|
+
persistent: true,
|
|
10
|
+
};
|
|
6
11
|
this.clients = new Map();
|
|
7
12
|
this.server.on('connection', this.handleConnection.bind(this));
|
|
8
13
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ws.transport.js","sourceRoot":"","sources":["../../../../src/core/transport/ws/ws.transport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAOpC,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"ws.transport.js","sourceRoot":"","sources":["../../../../src/core/transport/ws/ws.transport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAOpC,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAGhD,MAAM,OAAO,kBAAkB;IAe7B,YAAoB,MAAuB;QAAvB,WAAM,GAAN,MAAM,CAAiB;QAblC,iBAAY,GAA0B;YAC7C,MAAM,EAAE,IAAI;YACZ,cAAc,EAAE,IAAI;YACpB,UAAU,EAAE,IAAI;SACnB,CAAC;QAEQ,YAAO,GAAG,IAAI,GAAG,EAAsB,CAAC;QAQ9C,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACjE,CAAC;IAED,KAAK,CAAC,KAAK,KAAmB,CAAC;IAE/B,KAAK,CAAC,IAAI;QACR,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;IACtB,CAAC;IAED,SAAS,CACP,OAA8D;QAE9D,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,QAAgB,EAAE,OAAgB;QAC3C,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAE1C,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO;QACT,CAAC;QAED,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;IACvC,CAAC;IAEO,gBAAgB,CAAC,MAAkB;QACzC,MAAM,CAAC,EAAE,GAAG,UAAU,EAAE,CAAC;QAEzB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC;QAEpC,MAAM,CAAC,EAAE,CACP,SAAS,EAET,KAAK,EAAE,GAAY,EAAE,EAAE;YACrB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;gBACzB,OAAO;YACT,CAAC;YAED,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;gBAE3C,MAAM,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;YAChD,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,CAAC,KAAK,CAAC;oBACX,IAAI,EAAE,iBAAiB;oBACvB,SAAS,EAAE,WAAW;oBACtB,QAAQ,EAAE,MAAM,CAAC,EAAE;oBACnB,KAAK,EAAE,GAAG;iBACX,CAAC,CAAC;YACL,CAAC;QACH,CAAC,CACF,CAAC;QAEF,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;YACtB,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;IACL,CAAC;CACF"}
|
|
@@ -1 +1,6 @@
|
|
|
1
|
-
|
|
1
|
+
import { HttpTransport } from '../core/transport/http/http.transport.js';
|
|
2
|
+
export declare function bootstrapHttpRuntime(config?: any): Promise<{
|
|
3
|
+
app: import("@nestjs/common").INestApplication<any>;
|
|
4
|
+
runtime: import("../core/runtime/Runtime.js").Runtime;
|
|
5
|
+
transport: HttpTransport;
|
|
6
|
+
}>;
|
|
@@ -11,14 +11,29 @@ export async function bootstrapHttpRuntime(config = {}) {
|
|
|
11
11
|
const transport = app.get(HttpTransport);
|
|
12
12
|
const protocol = new JsonRpcProtocol();
|
|
13
13
|
const runtime = createRuntime({
|
|
14
|
-
|
|
14
|
+
transports: [
|
|
15
|
+
transport,
|
|
16
|
+
],
|
|
15
17
|
protocol,
|
|
16
18
|
...config,
|
|
17
19
|
});
|
|
20
|
+
//
|
|
21
|
+
// Runtime lifecycle
|
|
22
|
+
//
|
|
23
|
+
// 1. Bootstrap application components
|
|
24
|
+
// 2. Initialize runtime
|
|
25
|
+
// 3. Start runtime
|
|
26
|
+
//
|
|
18
27
|
bootstrapRuntime(config.apps ?? [], runtime);
|
|
28
|
+
await runtime.initialize();
|
|
29
|
+
await runtime.start();
|
|
19
30
|
const port = config.port ?? 3000;
|
|
20
31
|
await app.listen(port);
|
|
21
32
|
console.log(`StateFlowX runtime listening on http://localhost:${port}/rpc`);
|
|
22
|
-
return
|
|
33
|
+
return {
|
|
34
|
+
app,
|
|
35
|
+
runtime,
|
|
36
|
+
transport,
|
|
37
|
+
};
|
|
23
38
|
}
|
|
24
39
|
//# sourceMappingURL=bootstrap-http-runtime.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bootstrap-http-runtime.js","sourceRoot":"","sources":["../../src/http/bootstrap-http-runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAE3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAE9D,OAAO,EAAE,aAAa,EAAE,MAAM,0CAA0C,CAAC;AAEzE,OAAO,EAAE,eAAe,EAAE,MAAM,gDAAgD,CAAC;AAEjF,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAElE,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAEhE,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,SAAc,EAAE;
|
|
1
|
+
{"version":3,"file":"bootstrap-http-runtime.js","sourceRoot":"","sources":["../../src/http/bootstrap-http-runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAE3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAE9D,OAAO,EAAE,aAAa,EAAE,MAAM,0CAA0C,CAAC;AAEzE,OAAO,EAAE,eAAe,EAAE,MAAM,gDAAgD,CAAC;AAEjF,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAElE,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAEhE,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,SAAc,EAAE;IAEzD,MAAM,GAAG,GAAG,MAAM,WAAW,CAAC,MAAM,CAAC,iBAAiB,EAAE;QACtD,IAAI,EAAE,IAAI;KACX,CAAC,CAAC;IAEH,MAAM,SAAS,GACb,GAAG,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;IAEzB,MAAM,QAAQ,GACZ,IAAI,eAAe,EAAE,CAAC;IAExB,MAAM,OAAO,GACX,aAAa,CAAC;QAEZ,UAAU,EAAE;YACV,SAAS;SACV;QAED,QAAQ;QAER,GAAG,MAAM;KACV,CAAC,CAAC;IAEL,EAAE;IACF,oBAAoB;IACpB,EAAE;IACF,sCAAsC;IACtC,wBAAwB;IACxB,mBAAmB;IACnB,EAAE;IACF,gBAAgB,CACd,MAAM,CAAC,IAAI,IAAI,EAAE,EAEjB,OAAO,CACR,CAAC;IAEF,MAAM,OAAO,CAAC,UAAU,EAAE,CAAC;IAE3B,MAAM,OAAO,CAAC,KAAK,EAAE,CAAC;IAEtB,MAAM,IAAI,GACR,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC;IAEtB,MAAM,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAEvB,OAAO,CAAC,GAAG,CACT,oDAAoD,IAAI,MAAM,CAC/D,CAAC;IAEF,OAAO;QACL,GAAG;QACH,OAAO;QACP,SAAS;KACV,CAAC;AACJ,CAAC"}
|
package/dist/main.js
CHANGED
|
@@ -2,22 +2,15 @@ import 'dotenv/config';
|
|
|
2
2
|
import { NestFactory } from '@nestjs/core';
|
|
3
3
|
import { WsAdapter } from '@nestjs/platform-ws';
|
|
4
4
|
import { WebSocketServer } from 'ws';
|
|
5
|
-
import {
|
|
6
|
-
import { bootstrapRuntime, createRuntime, GeminiProvider, RuntimeInitializeApp, } from './index.js';
|
|
5
|
+
import { bootstrapRuntime, createRuntime, GeminiProvider, RuntimeInitializeApp, HttpTransport } from './index.js';
|
|
7
6
|
import { JsonRpcProtocol } from './core/protocol/json-rpc/json-rpc.protocol.js';
|
|
8
7
|
import { WebSocketTransport } from './core/transport/ws/ws.transport.js';
|
|
9
8
|
import { WebSocketEventDispatcher } from './core/events/dispatchers/ws/websocket-event-dispatcher.js';
|
|
10
9
|
import { GoogleADKAgent } from './core/agent/google-adk-agent.js';
|
|
11
10
|
import { GoogleAdkProvider } from './core/provider/providers/google-adk.provider.js';
|
|
11
|
+
import { RuntimeModule } from './core/transport/Runtime.module.js';
|
|
12
12
|
async function bootstrap() {
|
|
13
|
-
|
|
14
|
-
// await NestFactory.create(
|
|
15
|
-
// HttpRuntimeModule,
|
|
16
|
-
// {
|
|
17
|
-
// cors: true,
|
|
18
|
-
// },
|
|
19
|
-
// );
|
|
20
|
-
const app = await NestFactory.create(WebSocketRuntimeModule, {
|
|
13
|
+
const app = await NestFactory.create(RuntimeModule, {
|
|
21
14
|
cors: true,
|
|
22
15
|
});
|
|
23
16
|
app.useWebSocketAdapter(new WsAdapter(app));
|
|
@@ -26,17 +19,18 @@ async function bootstrap() {
|
|
|
26
19
|
});
|
|
27
20
|
await app.listen(3000);
|
|
28
21
|
//
|
|
29
|
-
//
|
|
22
|
+
// Websocket transport server
|
|
30
23
|
//
|
|
31
24
|
const server = new WebSocketServer({
|
|
32
25
|
port: 3001,
|
|
33
26
|
});
|
|
34
|
-
const
|
|
35
|
-
|
|
36
|
-
|
|
27
|
+
const transports = [
|
|
28
|
+
app.get(HttpTransport),
|
|
29
|
+
new WebSocketTransport(server),
|
|
30
|
+
];
|
|
37
31
|
const protocol = new JsonRpcProtocol();
|
|
38
32
|
const runtime = createRuntime({
|
|
39
|
-
|
|
33
|
+
transports,
|
|
40
34
|
protocol,
|
|
41
35
|
agents: [
|
|
42
36
|
{
|
package/dist/main.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,CAAC;AAEvB,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAE3C,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,OAAO,EAAE,eAAe,EAAE,MAAM,IAAI,CAAC;AAErC,OAAO,
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,CAAC;AAEvB,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAE3C,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,OAAO,EAAE,eAAe,EAAE,MAAM,IAAI,CAAC;AAErC,OAAO,EACL,gBAAgB,EAChB,aAAa,EACb,cAAc,EACd,oBAAoB,EACpB,aAAa,EACd,MAAM,YAAY,CAAC;AAEpB,OAAO,EAAE,eAAe,EAAE,MAAM,+CAA+C,CAAC;AAEhF,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAEzE,OAAO,EAAE,wBAAwB,EAAE,MAAM,4DAA4D,CAAC;AAEtG,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAElE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kDAAkD,CAAC;AACrF,OAAO,EAAE,aAAa,EAAE,MAAM,oCAAoC,CAAC;AAEnE,KAAK,UAAU,SAAS;IAEtB,MAAM,GAAG,GAAG,MAAM,WAAW,CAAC,MAAM,CAAC,aAAa,EAAE;QAClD,IAAI,EAAE,IAAI;KACX,CAAC,CAAC;IAEH,GAAG,CAAC,mBAAmB,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;IAE5C,GAAG,CAAC,UAAU,CAAC;QACb,MAAM,EAAE,uBAAuB;KAChC,CAAC,CAAC;IAEH,MAAM,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAEvB,EAAE;IACF,6BAA6B;IAC7B,EAAE;IACF,MAAM,MAAM,GAAG,IAAI,eAAe,CAAC;QACjC,IAAI,EAAE,IAAI;KACX,CAAC,CAAC;IAEH,MAAM,UAAU,GAAG;QACjB,GAAG,CAAC,GAAG,CAAC,aAAa,CAAC;QACtB,IAAI,kBAAkB,CAAC,MAAM,CAAC;KAC/B,CAAA;IAED,MAAM,QAAQ,GAAG,IAAI,eAAe,EAAE,CAAC;IAEvC,MAAM,OAAO,GAAG,aAAa,CAAC;QAE5B,UAAU;QAEV,QAAQ;QAER,MAAM,EAAE;YACN;gBACE,IAAI,EAAE,eAAe;gBACrB,KAAK,EAAE,IAAI,cAAc,CAAC,eAAe,CAAC;aAC3C;SACF;QAED,SAAS,EAAE;YACT;gBACE,IAAI,EAAE,QAAQ;gBAEd,QAAQ,EAAE,IAAI,cAAc,EAAE;aAC/B;YACD;gBACE,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,IAAI,iBAAiB,CAAC,IAAI,cAAc,CAAC,eAAe,CAAC,CAAC;aACrE;SACF;QAED,QAAQ,EAAE,EAAE;QAEZ,SAAS,EAAE;YACT,OAAO,EAAE,IAAI;YAEb,MAAM,EAAE;gBACN,OAAO,EAAE,IAAI;aACd;YAED,SAAS,EAAE;gBACT,OAAO,EAAE,KAAK;aACf;SACF;KACF,CAAC,CAAC;IAIH,EAAE;IACF,oBAAoB;IACpB,EAAE;IACF,gCAAgC;IAChC,sCAAsC;IACtC,wBAAwB;IACxB,mBAAmB;IACnB,EAAE;IACF,OAAO,CAAC,kBAAkB,CACxB,IAAI,wBAAwB,CAAC,MAAM,CAAC,CACrC,CAAC;IAEF,gBAAgB,CACd,CAAC,IAAI,oBAAoB,EAAE,CAAC,EAE5B,OAAO,CACR,CAAC;IAEF,MAAM,OAAO,CAAC,UAAU,EAAE,CAAC;IAE3B,MAAM,OAAO,CAAC,KAAK,EAAE,CAAC;IAEtB,OAAO,CAAC,GAAG,CAAC,qDAAqD,CAAC,CAAC;AACrE,CAAC;AAED,SAAS,EAAE,CAAC"}
|
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"websocket-runtime.module.js","sourceRoot":"","sources":["../src/websocket-runtime.module.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAExC,OAAO,aAAa,MAAM,uCAAuC,CAAC;AAElE,gCAAgC;AAChC,kDAAkD;AAK3C,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;CAAG,CAAA;AAAzB,sBAAsB;IAHlC,MAAM,CAAC;QACN,SAAS,EAAE,CAAC,aAAa,CAAC;KAC3B,CAAC;GACW,sBAAsB,CAAG"}
|