@journal.one/gateway 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. package/dist/common/logger.d.ts +19 -0
  2. package/dist/common/logger.d.ts.map +1 -0
  3. package/dist/common/logger.js +52 -0
  4. package/dist/common/logger.js.map +1 -0
  5. package/dist/config.d.ts +64 -0
  6. package/dist/config.d.ts.map +1 -0
  7. package/dist/config.js +103 -0
  8. package/dist/config.js.map +1 -0
  9. package/dist/connection.d.ts +21 -0
  10. package/dist/connection.d.ts.map +1 -0
  11. package/dist/connection.js +266 -0
  12. package/dist/connection.js.map +1 -0
  13. package/dist/main.d.ts +3 -0
  14. package/dist/main.d.ts.map +1 -0
  15. package/dist/main.js +32 -0
  16. package/dist/main.js.map +1 -0
  17. package/dist/mcp-client.d.ts +24 -0
  18. package/dist/mcp-client.d.ts.map +1 -0
  19. package/dist/mcp-client.js +91 -0
  20. package/dist/mcp-client.js.map +1 -0
  21. package/dist/runtime.d.ts +25 -0
  22. package/dist/runtime.d.ts.map +1 -0
  23. package/dist/runtime.js +124 -0
  24. package/dist/runtime.js.map +1 -0
  25. package/dist/skill-client.d.ts +18 -0
  26. package/dist/skill-client.d.ts.map +1 -0
  27. package/dist/skill-client.js +75 -0
  28. package/dist/skill-client.js.map +1 -0
  29. package/dist/types/errors.d.ts +16 -0
  30. package/dist/types/errors.d.ts.map +1 -0
  31. package/dist/types/errors.js +13 -0
  32. package/dist/types/errors.js.map +1 -0
  33. package/dist/types/index.d.ts +7 -0
  34. package/dist/types/index.d.ts.map +1 -0
  35. package/dist/types/index.js +6 -0
  36. package/dist/types/index.js.map +1 -0
  37. package/dist/types/integrations.d.ts +165 -0
  38. package/dist/types/integrations.d.ts.map +1 -0
  39. package/dist/types/integrations.js +32 -0
  40. package/dist/types/integrations.js.map +1 -0
  41. package/dist/types/messages.d.ts +570 -0
  42. package/dist/types/messages.d.ts.map +1 -0
  43. package/dist/types/messages.js +68 -0
  44. package/dist/types/messages.js.map +1 -0
  45. package/dist/types/provider.d.ts +16 -0
  46. package/dist/types/provider.d.ts.map +1 -0
  47. package/dist/types/provider.js +7 -0
  48. package/dist/types/provider.js.map +1 -0
  49. package/dist/types/skills.d.ts +13 -0
  50. package/dist/types/skills.d.ts.map +1 -0
  51. package/dist/types/skills.js +6 -0
  52. package/dist/types/skills.js.map +1 -0
  53. package/dist/version-hash.d.ts +8 -0
  54. package/dist/version-hash.d.ts.map +1 -0
  55. package/dist/version-hash.js +23 -0
  56. package/dist/version-hash.js.map +1 -0
  57. package/dist/version.d.ts +2 -0
  58. package/dist/version.d.ts.map +1 -0
  59. package/dist/version.js +16 -0
  60. package/dist/version.js.map +1 -0
  61. package/package.json +39 -0
@@ -0,0 +1,19 @@
1
+ export type LogLevel = "debug" | "info" | "warn" | "error";
2
+ export declare class Logger {
3
+ private level;
4
+ constructor(level?: LogLevel);
5
+ debug(message: string, meta?: Record<string, unknown>): void;
6
+ info(message: string, meta?: Record<string, unknown>): void;
7
+ warn(message: string, meta?: Record<string, unknown>): void;
8
+ error(message: string, meta?: Record<string, unknown>): void;
9
+ toolCall(params: {
10
+ integrationId: string;
11
+ toolName: string;
12
+ requestId: string;
13
+ durationMs: number;
14
+ success: boolean;
15
+ error?: string;
16
+ }): void;
17
+ private log;
18
+ }
19
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/common/logger.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;AAS3D,qBAAa,MAAM;IACjB,OAAO,CAAC,KAAK,CAAS;gBAEV,KAAK,GAAE,QAAiB;IAIpC,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI5D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI3D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI3D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAI5D,QAAQ,CAAC,MAAM,EAAE;QACf,aAAa,EAAE,MAAM,CAAC;QACtB,QAAQ,EAAE,MAAM,CAAC;QACjB,SAAS,EAAE,MAAM,CAAC;QAClB,UAAU,EAAE,MAAM,CAAC;QACnB,OAAO,EAAE,OAAO,CAAC;QACjB,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,GAAG,IAAI;IAWR,OAAO,CAAC,GAAG;CAqBZ"}
@@ -0,0 +1,52 @@
1
+ const LOG_LEVELS = {
2
+ debug: 0,
3
+ info: 1,
4
+ warn: 2,
5
+ error: 3,
6
+ };
7
+ export class Logger {
8
+ level;
9
+ constructor(level = "info") {
10
+ this.level = LOG_LEVELS[level];
11
+ }
12
+ debug(message, meta) {
13
+ this.log("debug", message, meta);
14
+ }
15
+ info(message, meta) {
16
+ this.log("info", message, meta);
17
+ }
18
+ warn(message, meta) {
19
+ this.log("warn", message, meta);
20
+ }
21
+ error(message, meta) {
22
+ this.log("error", message, meta);
23
+ }
24
+ toolCall(params) {
25
+ this.log(params.success ? "info" : "error", "tool_call", {
26
+ integrationId: params.integrationId,
27
+ toolName: params.toolName,
28
+ requestId: params.requestId,
29
+ durationMs: params.durationMs,
30
+ success: params.success,
31
+ ...(params.error ? { error: params.error } : {}),
32
+ });
33
+ }
34
+ log(level, message, meta) {
35
+ if (LOG_LEVELS[level] < this.level)
36
+ return;
37
+ const entry = {
38
+ timestamp: new Date().toISOString(),
39
+ level,
40
+ message,
41
+ ...meta,
42
+ };
43
+ const output = JSON.stringify(entry);
44
+ if (level === "error") {
45
+ process.stderr.write(output + "\n");
46
+ }
47
+ else {
48
+ process.stdout.write(output + "\n");
49
+ }
50
+ }
51
+ }
52
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/common/logger.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,GAA6B;IAC3C,KAAK,EAAE,CAAC;IACR,IAAI,EAAE,CAAC;IACP,IAAI,EAAE,CAAC;IACP,KAAK,EAAE,CAAC;CACT,CAAC;AAEF,MAAM,OAAO,MAAM;IACT,KAAK,CAAS;IAEtB,YAAY,QAAkB,MAAM;QAClC,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,IAA8B;QACnD,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,IAAI,CAAC,OAAe,EAAE,IAA8B;QAClD,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IAClC,CAAC;IAED,IAAI,CAAC,OAAe,EAAE,IAA8B;QAClD,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IAClC,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,IAA8B;QACnD,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,QAAQ,CAAC,MAOR;QACC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,EAAE,WAAW,EAAE;YACvD,aAAa,EAAE,MAAM,CAAC,aAAa;YACnC,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,SAAS,EAAE,MAAM,CAAC,SAAS;YAC3B,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SACjD,CAAC,CAAC;IACL,CAAC;IAEO,GAAG,CACT,KAAe,EACf,OAAe,EACf,IAA8B;QAE9B,IAAI,UAAU,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,KAAK;YAAE,OAAO;QAE3C,MAAM,KAAK,GAA4B;YACrC,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,KAAK;YACL,OAAO;YACP,GAAG,IAAI;SACR,CAAC;QAEF,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACrC,IAAI,KAAK,KAAK,OAAO,EAAE,CAAC;YACtB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;QACtC,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;CACF"}
@@ -0,0 +1,64 @@
1
+ import { z } from "zod";
2
+ import type { GatewayConfig } from "@journal.one/gateway-protocol";
3
+ export interface McpServerConfig {
4
+ id: string;
5
+ type: "mcp_server";
6
+ name: string;
7
+ description: string;
8
+ command: string;
9
+ args: string[];
10
+ envVars: Record<string, string>;
11
+ }
12
+ export type RuntimeConfig = GatewayConfig & {
13
+ mcpServers: McpServerConfig[];
14
+ mcpEnvVars: Map<string, Record<string, string>>;
15
+ skillsDir: string | null;
16
+ };
17
+ export declare const GatewayConfigFileSchema: z.ZodObject<{
18
+ mcpServers: z.ZodDefault<z.ZodArray<z.ZodObject<{
19
+ id: z.ZodString;
20
+ command: z.ZodString;
21
+ args: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
22
+ name: z.ZodOptional<z.ZodString>;
23
+ description: z.ZodDefault<z.ZodString>;
24
+ envVars: z.ZodDefault<z.ZodRecord<z.ZodString, z.ZodString>>;
25
+ }, "strip", z.ZodTypeAny, {
26
+ id: string;
27
+ command: string;
28
+ args: string[];
29
+ description: string;
30
+ envVars: Record<string, string>;
31
+ name?: string | undefined;
32
+ }, {
33
+ id: string;
34
+ command: string;
35
+ args?: string[] | undefined;
36
+ name?: string | undefined;
37
+ description?: string | undefined;
38
+ envVars?: Record<string, string> | undefined;
39
+ }>, "many">>;
40
+ skillsDir: z.ZodDefault<z.ZodNullable<z.ZodString>>;
41
+ }, "strip", z.ZodTypeAny, {
42
+ mcpServers: {
43
+ id: string;
44
+ command: string;
45
+ args: string[];
46
+ description: string;
47
+ envVars: Record<string, string>;
48
+ name?: string | undefined;
49
+ }[];
50
+ skillsDir: string | null;
51
+ }, {
52
+ mcpServers?: {
53
+ id: string;
54
+ command: string;
55
+ args?: string[] | undefined;
56
+ name?: string | undefined;
57
+ description?: string | undefined;
58
+ envVars?: Record<string, string> | undefined;
59
+ }[] | undefined;
60
+ skillsDir?: string | null | undefined;
61
+ }>;
62
+ export type GatewayConfigFile = z.infer<typeof GatewayConfigFileSchema>;
63
+ export declare function parseConfig(env?: Record<string, string | undefined>, argv?: string[]): RuntimeConfig;
64
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAEnE,MAAM,WAAW,eAAe;IAC9B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,YAAY,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACjC;AAED,MAAM,MAAM,aAAa,GAAG,aAAa,GAAG;IAC1C,UAAU,EAAE,eAAe,EAAE,CAAC;IAC9B,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;IAChD,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;CAC1B,CAAC;AAiBF,eAAO,MAAM,uBAAuB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAGlC,CAAC;AAEH,MAAM,MAAM,iBAAiB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,uBAAuB,CAAC,CAAC;AAwBxE,wBAAgB,WAAW,CACzB,GAAG,GAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAe,EACrD,IAAI,GAAE,MAAM,EAAiB,GAC5B,aAAa,CAyEf"}
package/dist/config.js ADDED
@@ -0,0 +1,103 @@
1
+ import { z } from "zod";
2
+ import { readFileSync } from "node:fs";
3
+ const OperationalSchema = z.object({
4
+ token: z.string().min(1, "JOURNAL_GATEWAY_TOKEN is required"),
5
+ url: z.string().url(),
6
+ logLevel: z.enum(["debug", "info", "warn", "error"]),
7
+ });
8
+ const McpServerConfigSchema = z.object({
9
+ id: z.string().min(1, "Each MCP server must have an id"),
10
+ command: z.string().min(1, "Each MCP server must have a command"),
11
+ args: z.array(z.string()).default([]),
12
+ name: z.string().optional(),
13
+ description: z.string().default(""),
14
+ envVars: z.record(z.string()).default({}),
15
+ });
16
+ export const GatewayConfigFileSchema = z.object({
17
+ mcpServers: z.array(McpServerConfigSchema).default([]),
18
+ skillsDir: z.string().nullable().default(null),
19
+ });
20
+ function parseCliConfigArg(argv) {
21
+ const idx = argv.indexOf("--config");
22
+ if (idx === -1 || idx + 1 >= argv.length)
23
+ return null;
24
+ return argv[idx + 1];
25
+ }
26
+ function readConfigFile(path) {
27
+ let raw;
28
+ try {
29
+ raw = readFileSync(path, "utf-8");
30
+ }
31
+ catch {
32
+ throw new Error(`Cannot read config file: ${path}`);
33
+ }
34
+ let parsed;
35
+ try {
36
+ parsed = JSON.parse(raw);
37
+ }
38
+ catch {
39
+ throw new Error(`Config file is not valid JSON: ${path}`);
40
+ }
41
+ return GatewayConfigFileSchema.parse(parsed);
42
+ }
43
+ export function parseConfig(env = process.env, argv = process.argv) {
44
+ const token = env.JOURNAL_GATEWAY_TOKEN ?? "";
45
+ const url = env.JOURNAL_GATEWAY_URL ?? "wss://gateway.journal.one/v1";
46
+ const logLevel = (env.LOG_LEVEL ?? "info");
47
+ const base = OperationalSchema.parse({ token, url, logLevel });
48
+ // Resolve config: --config arg > JOURNAL_GATEWAY_CONFIG env var > empty config
49
+ const cliConfigPath = parseCliConfigArg(argv);
50
+ const envConfig = env.JOURNAL_GATEWAY_CONFIG ?? null;
51
+ let configFile;
52
+ if (cliConfigPath) {
53
+ configFile = readConfigFile(cliConfigPath);
54
+ }
55
+ else if (envConfig) {
56
+ if (envConfig.trimStart().startsWith("{")) {
57
+ // Inline JSON
58
+ let parsed;
59
+ try {
60
+ parsed = JSON.parse(envConfig);
61
+ }
62
+ catch {
63
+ throw new Error("JOURNAL_GATEWAY_CONFIG is not valid JSON");
64
+ }
65
+ configFile = GatewayConfigFileSchema.parse(parsed);
66
+ }
67
+ else {
68
+ configFile = readConfigFile(envConfig);
69
+ }
70
+ }
71
+ else {
72
+ configFile = GatewayConfigFileSchema.parse({});
73
+ }
74
+ if (configFile.mcpServers.length === 0 && !configFile.skillsDir) {
75
+ console.warn("Warning: no mcpServers or skillsDir configured. The gateway will connect but have no tools or skills to offer.");
76
+ }
77
+ // Build McpServerConfig[] and resolve envVars
78
+ const mcpServers = [];
79
+ const mcpEnvVars = new Map();
80
+ for (const server of configFile.mcpServers) {
81
+ const config = {
82
+ id: server.id,
83
+ type: "mcp_server",
84
+ name: server.name ?? server.id,
85
+ description: server.description,
86
+ command: server.command,
87
+ args: server.args,
88
+ envVars: server.envVars,
89
+ };
90
+ const resolvedEnv = {};
91
+ for (const [hostVar, serverVar] of Object.entries(config.envVars)) {
92
+ const value = env[hostVar];
93
+ if (!value) {
94
+ throw new Error(`MCP server "${config.id}" requires environment variable ${hostVar}`);
95
+ }
96
+ resolvedEnv[serverVar] = value;
97
+ }
98
+ mcpServers.push(config);
99
+ mcpEnvVars.set(config.id, resolvedEnv);
100
+ }
101
+ return { ...base, mcpServers, mcpEnvVars, skillsDir: configFile.skillsDir };
102
+ }
103
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ import { type IntegrationProvider, type GatewayConfig } from "@journal.one/gateway-protocol";
2
+ export declare class GatewayConnection {
3
+ private config;
4
+ private provider;
5
+ private ws;
6
+ private logger;
7
+ private reconnectDelay;
8
+ private closed;
9
+ private reconnectTimer;
10
+ private changeListener;
11
+ constructor(config: GatewayConfig, provider: IntegrationProvider);
12
+ connect(): Promise<void>;
13
+ private establishConnection;
14
+ private subscribeToChanges;
15
+ private unsubscribeFromChanges;
16
+ private handleToolCall;
17
+ private scheduleReconnect;
18
+ private send;
19
+ close(): Promise<void>;
20
+ }
21
+ //# sourceMappingURL=connection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connection.d.ts","sourceRoot":"","sources":["../src/connection.ts"],"names":[],"mappings":"AACA,OAAO,EAML,KAAK,mBAAmB,EACxB,KAAK,aAAa,EACnB,MAAM,+BAA+B,CAAC;AAmBvC,qBAAa,iBAAiB;IAS1B,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,QAAQ;IATlB,OAAO,CAAC,EAAE,CAA0B;IACpC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,cAAc,CAAwB;IAC9C,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,cAAc,CAA8C;IACpE,OAAO,CAAC,cAAc,CAA6B;gBAGzC,MAAM,EAAE,aAAa,EACrB,QAAQ,EAAE,mBAAmB;IAKjC,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;YAKhB,mBAAmB;IA+IjC,OAAO,CAAC,kBAAkB;IAoB1B,OAAO,CAAC,sBAAsB;YAOhB,cAAc;IAyD5B,OAAO,CAAC,iBAAiB;IA2BzB,OAAO,CAAC,IAAI;IAMN,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAa7B"}
@@ -0,0 +1,266 @@
1
+ import WebSocket from "ws";
2
+ import { ServiceMessageSchema, IntegrationNotFoundError, } from "@journal.one/gateway-protocol";
3
+ import { Logger } from "./common/logger.js";
4
+ import { VERSION } from "./version.js";
5
+ const PROTOCOL_VERSION = 2;
6
+ const AUTH_TIMEOUT_MS = 10_000;
7
+ const TOOL_CALL_TIMEOUT_MS = 60_000;
8
+ class ToolTimeoutError extends Error {
9
+ constructor() {
10
+ super("Tool execution timed out");
11
+ this.name = "ToolTimeoutError";
12
+ }
13
+ }
14
+ const RECONNECT_INITIAL_MS = 1_000;
15
+ const RECONNECT_MAX_MS = 30_000;
16
+ const RECONNECT_MULTIPLIER = 2;
17
+ const RECONNECT_JITTER = 0.25;
18
+ export class GatewayConnection {
19
+ config;
20
+ provider;
21
+ ws = null;
22
+ logger;
23
+ reconnectDelay = RECONNECT_INITIAL_MS;
24
+ closed = false;
25
+ reconnectTimer = null;
26
+ changeListener = null;
27
+ constructor(config, provider) {
28
+ this.config = config;
29
+ this.provider = provider;
30
+ this.logger = new Logger(config.logLevel);
31
+ }
32
+ async connect() {
33
+ this.closed = false;
34
+ await this.establishConnection();
35
+ }
36
+ async establishConnection() {
37
+ return new Promise((resolve, reject) => {
38
+ this.logger.info("Connecting to Journal service", {
39
+ url: this.config.url,
40
+ });
41
+ const ws = new WebSocket(this.config.url);
42
+ this.ws = ws;
43
+ let authenticated = false;
44
+ let ready = false;
45
+ const authTimer = setTimeout(() => {
46
+ if (!authenticated) {
47
+ ws.close();
48
+ reject(new Error("Authentication timed out"));
49
+ }
50
+ }, AUTH_TIMEOUT_MS);
51
+ ws.on("open", () => {
52
+ this.logger.info("WebSocket connected, authenticating");
53
+ this.send({
54
+ type: "authenticate",
55
+ token: this.config.token,
56
+ protocolVersion: PROTOCOL_VERSION,
57
+ gatewayVersion: VERSION,
58
+ });
59
+ });
60
+ ws.on("message", async (data) => {
61
+ let msg;
62
+ try {
63
+ msg = ServiceMessageSchema.parse(JSON.parse(data.toString()));
64
+ }
65
+ catch (err) {
66
+ this.logger.warn("Received invalid message", {
67
+ error: String(err),
68
+ });
69
+ return;
70
+ }
71
+ switch (msg.type) {
72
+ case "authenticated": {
73
+ clearTimeout(authTimer);
74
+ authenticated = true;
75
+ this.logger.info("Authenticated", {
76
+ organizationId: msg.organizationId,
77
+ organizationName: msg.organizationName,
78
+ });
79
+ // Send initial version_changed (fire-and-forget)
80
+ const versions = this.provider.getVersions();
81
+ this.send({
82
+ type: "version_changed",
83
+ mcpVersion: versions.mcpVersion,
84
+ skillsVersion: versions.skillsVersion,
85
+ });
86
+ // Subscribe to provider change events
87
+ this.subscribeToChanges(ws);
88
+ // Connection is ready
89
+ ready = true;
90
+ this.reconnectDelay = RECONNECT_INITIAL_MS;
91
+ this.logger.info("Gateway ready");
92
+ resolve();
93
+ break;
94
+ }
95
+ case "auth_error": {
96
+ clearTimeout(authTimer);
97
+ this.logger.error("Authentication failed", {
98
+ error: msg.error,
99
+ });
100
+ ws.close();
101
+ reject(new Error(`Authentication failed: ${msg.error}`));
102
+ break;
103
+ }
104
+ case "get_versions": {
105
+ const versions = this.provider.getVersions();
106
+ this.send({
107
+ type: "versions",
108
+ requestId: msg.requestId,
109
+ mcpVersion: versions.mcpVersion,
110
+ skillsVersion: versions.skillsVersion,
111
+ });
112
+ break;
113
+ }
114
+ case "get_tools": {
115
+ const tools = await this.provider.getTools();
116
+ const versions = this.provider.getVersions();
117
+ this.send({
118
+ type: "tools",
119
+ requestId: msg.requestId,
120
+ integrations: tools,
121
+ mcpVersion: versions.mcpVersion,
122
+ });
123
+ break;
124
+ }
125
+ case "get_skills": {
126
+ const skills = this.provider.getSkills();
127
+ const versions = this.provider.getVersions();
128
+ this.send({
129
+ type: "skills",
130
+ requestId: msg.requestId,
131
+ skills,
132
+ skillsVersion: versions.skillsVersion,
133
+ });
134
+ break;
135
+ }
136
+ case "tool_call": {
137
+ this.handleToolCall(msg.requestId, msg.integrationId, msg.toolName, msg.arguments);
138
+ break;
139
+ }
140
+ case "ping": {
141
+ this.send({ type: "pong" });
142
+ break;
143
+ }
144
+ }
145
+ });
146
+ ws.on("close", () => {
147
+ this.logger.warn("WebSocket disconnected");
148
+ this.unsubscribeFromChanges();
149
+ if (!this.closed && ready) {
150
+ this.scheduleReconnect();
151
+ }
152
+ });
153
+ ws.on("error", (err) => {
154
+ this.logger.error("WebSocket error", { error: err.message });
155
+ if (!authenticated) {
156
+ clearTimeout(authTimer);
157
+ reject(err);
158
+ }
159
+ });
160
+ });
161
+ }
162
+ subscribeToChanges(ws) {
163
+ this.unsubscribeFromChanges();
164
+ if (!this.provider.on)
165
+ return;
166
+ this.changeListener = () => {
167
+ if (ws.readyState !== WebSocket.OPEN)
168
+ return;
169
+ this.logger.info("Provider versions changed, notifying service");
170
+ const versions = this.provider.getVersions();
171
+ this.send({
172
+ type: "version_changed",
173
+ mcpVersion: versions.mcpVersion,
174
+ skillsVersion: versions.skillsVersion,
175
+ });
176
+ };
177
+ this.provider.on("versions_changed", this.changeListener);
178
+ }
179
+ unsubscribeFromChanges() {
180
+ if (this.changeListener && this.provider.off) {
181
+ this.provider.off("versions_changed", this.changeListener);
182
+ this.changeListener = null;
183
+ }
184
+ }
185
+ async handleToolCall(requestId, integrationId, toolName, args) {
186
+ const start = Date.now();
187
+ const timeout = new Promise((_, reject) => {
188
+ setTimeout(() => reject(new ToolTimeoutError()), TOOL_CALL_TIMEOUT_MS);
189
+ });
190
+ try {
191
+ const result = await Promise.race([
192
+ this.provider.callTool(integrationId, toolName, args),
193
+ timeout,
194
+ ]);
195
+ this.send({ type: "tool_result", requestId, result });
196
+ this.logger.toolCall({
197
+ integrationId,
198
+ toolName,
199
+ requestId,
200
+ durationMs: Date.now() - start,
201
+ success: true,
202
+ });
203
+ }
204
+ catch (err) {
205
+ let code = "EXECUTION_FAILED";
206
+ let message = err instanceof Error ? err.message : String(err);
207
+ if (err instanceof IntegrationNotFoundError) {
208
+ code = "INTEGRATION_NOT_FOUND";
209
+ }
210
+ else if (err instanceof ToolTimeoutError) {
211
+ code = "TIMEOUT";
212
+ }
213
+ this.send({
214
+ type: "tool_error",
215
+ requestId,
216
+ error: { code, message },
217
+ });
218
+ this.logger.toolCall({
219
+ integrationId,
220
+ toolName,
221
+ requestId,
222
+ durationMs: Date.now() - start,
223
+ success: false,
224
+ error: message,
225
+ });
226
+ }
227
+ }
228
+ scheduleReconnect() {
229
+ if (this.closed)
230
+ return;
231
+ const jitter = 1 + (Math.random() * 2 - 1) * RECONNECT_JITTER;
232
+ const delay = Math.min(this.reconnectDelay * jitter, RECONNECT_MAX_MS);
233
+ this.reconnectDelay = Math.min(this.reconnectDelay * RECONNECT_MULTIPLIER, RECONNECT_MAX_MS);
234
+ this.logger.info(`Reconnecting in ${Math.round(delay)}ms`);
235
+ this.reconnectTimer = setTimeout(async () => {
236
+ try {
237
+ await this.establishConnection();
238
+ }
239
+ catch (err) {
240
+ this.logger.error("Reconnection failed", {
241
+ error: err instanceof Error ? err.message : String(err),
242
+ });
243
+ this.scheduleReconnect();
244
+ }
245
+ }, delay);
246
+ }
247
+ send(message) {
248
+ if (this.ws?.readyState === WebSocket.OPEN) {
249
+ this.ws.send(JSON.stringify(message));
250
+ }
251
+ }
252
+ async close() {
253
+ this.closed = true;
254
+ this.unsubscribeFromChanges();
255
+ if (this.reconnectTimer) {
256
+ clearTimeout(this.reconnectTimer);
257
+ this.reconnectTimer = null;
258
+ }
259
+ if (this.ws) {
260
+ this.ws.close();
261
+ this.ws = null;
262
+ }
263
+ this.logger.info("Gateway connection closed");
264
+ }
265
+ }
266
+ //# sourceMappingURL=connection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connection.js","sourceRoot":"","sources":["../src/connection.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,IAAI,CAAC;AAC3B,OAAO,EACL,oBAAoB,EACpB,wBAAwB,GAMzB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,MAAM,gBAAgB,GAAG,CAAC,CAAC;AAC3B,MAAM,eAAe,GAAG,MAAM,CAAC;AAC/B,MAAM,oBAAoB,GAAG,MAAM,CAAC;AAEpC,MAAM,gBAAiB,SAAQ,KAAK;IAClC;QACE,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAClC,IAAI,CAAC,IAAI,GAAG,kBAAkB,CAAC;IACjC,CAAC;CACF;AACD,MAAM,oBAAoB,GAAG,KAAK,CAAC;AACnC,MAAM,gBAAgB,GAAG,MAAM,CAAC;AAChC,MAAM,oBAAoB,GAAG,CAAC,CAAC;AAC/B,MAAM,gBAAgB,GAAG,IAAI,CAAC;AAE9B,MAAM,OAAO,iBAAiB;IASlB;IACA;IATF,EAAE,GAAqB,IAAI,CAAC;IAC5B,MAAM,CAAS;IACf,cAAc,GAAG,oBAAoB,CAAC;IACtC,MAAM,GAAG,KAAK,CAAC;IACf,cAAc,GAAyC,IAAI,CAAC;IAC5D,cAAc,GAAwB,IAAI,CAAC;IAEnD,YACU,MAAqB,EACrB,QAA6B;QAD7B,WAAM,GAAN,MAAM,CAAe;QACrB,aAAQ,GAAR,QAAQ,CAAqB;QAErC,IAAI,CAAC,MAAM,GAAG,IAAI,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IAC5C,CAAC;IAED,KAAK,CAAC,OAAO;QACX,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;IACnC,CAAC;IAEO,KAAK,CAAC,mBAAmB;QAC/B,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC3C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,+BAA+B,EAAE;gBAChD,GAAG,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG;aACrB,CAAC,CAAC;YAEH,MAAM,EAAE,GAAG,IAAI,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YAC1C,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;YAEb,IAAI,aAAa,GAAG,KAAK,CAAC;YAC1B,IAAI,KAAK,GAAG,KAAK,CAAC;YAElB,MAAM,SAAS,GAAG,UAAU,CAAC,GAAG,EAAE;gBAChC,IAAI,CAAC,aAAa,EAAE,CAAC;oBACnB,EAAE,CAAC,KAAK,EAAE,CAAC;oBACX,MAAM,CAAC,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC,CAAC;gBAChD,CAAC;YACH,CAAC,EAAE,eAAe,CAAC,CAAC;YAEpB,EAAE,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE;gBACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qCAAqC,CAAC,CAAC;gBACxD,IAAI,CAAC,IAAI,CAAC;oBACR,IAAI,EAAE,cAAc;oBACpB,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK;oBACxB,eAAe,EAAE,gBAAgB;oBACjC,cAAc,EAAE,OAAO;iBACxB,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YAEH,EAAE,CAAC,EAAE,CAAC,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;gBAC9B,IAAI,GAAmB,CAAC;gBACxB,IAAI,CAAC;oBACH,GAAG,GAAG,oBAAoB,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;gBAChE,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,0BAA0B,EAAE;wBAC3C,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC;qBACnB,CAAC,CAAC;oBACH,OAAO;gBACT,CAAC;gBAED,QAAQ,GAAG,CAAC,IAAI,EAAE,CAAC;oBACjB,KAAK,eAAe,CAAC,CAAC,CAAC;wBACrB,YAAY,CAAC,SAAS,CAAC,CAAC;wBACxB,aAAa,GAAG,IAAI,CAAC;wBACrB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE;4BAChC,cAAc,EAAE,GAAG,CAAC,cAAc;4BAClC,gBAAgB,EAAE,GAAG,CAAC,gBAAgB;yBACvC,CAAC,CAAC;wBAEH,iDAAiD;wBACjD,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;wBAC7C,IAAI,CAAC,IAAI,CAAC;4BACR,IAAI,EAAE,iBAAiB;4BACvB,UAAU,EAAE,QAAQ,CAAC,UAAU;4BAC/B,aAAa,EAAE,QAAQ,CAAC,aAAa;yBACtC,CAAC,CAAC;wBAEH,sCAAsC;wBACtC,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC;wBAE5B,sBAAsB;wBACtB,KAAK,GAAG,IAAI,CAAC;wBACb,IAAI,CAAC,cAAc,GAAG,oBAAoB,CAAC;wBAC3C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;wBAClC,OAAO,EAAE,CAAC;wBACV,MAAM;oBACR,CAAC;oBAED,KAAK,YAAY,CAAC,CAAC,CAAC;wBAClB,YAAY,CAAC,SAAS,CAAC,CAAC;wBACxB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,uBAAuB,EAAE;4BACzC,KAAK,EAAE,GAAG,CAAC,KAAK;yBACjB,CAAC,CAAC;wBACH,EAAE,CAAC,KAAK,EAAE,CAAC;wBACX,MAAM,CAAC,IAAI,KAAK,CAAC,0BAA0B,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;wBACzD,MAAM;oBACR,CAAC;oBAED,KAAK,cAAc,CAAC,CAAC,CAAC;wBACpB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;wBAC7C,IAAI,CAAC,IAAI,CAAC;4BACR,IAAI,EAAE,UAAU;4BAChB,SAAS,EAAE,GAAG,CAAC,SAAS;4BACxB,UAAU,EAAE,QAAQ,CAAC,UAAU;4BAC/B,aAAa,EAAE,QAAQ,CAAC,aAAa;yBACtC,CAAC,CAAC;wBACH,MAAM;oBACR,CAAC;oBAED,KAAK,WAAW,CAAC,CAAC,CAAC;wBACjB,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;wBAC7C,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;wBAC7C,IAAI,CAAC,IAAI,CAAC;4BACR,IAAI,EAAE,OAAO;4BACb,SAAS,EAAE,GAAG,CAAC,SAAS;4BACxB,YAAY,EAAE,KAAK;4BACnB,UAAU,EAAE,QAAQ,CAAC,UAAU;yBAChC,CAAC,CAAC;wBACH,MAAM;oBACR,CAAC;oBAED,KAAK,YAAY,CAAC,CAAC,CAAC;wBAClB,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;wBACzC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;wBAC7C,IAAI,CAAC,IAAI,CAAC;4BACR,IAAI,EAAE,QAAQ;4BACd,SAAS,EAAE,GAAG,CAAC,SAAS;4BACxB,MAAM;4BACN,aAAa,EAAE,QAAQ,CAAC,aAAa;yBACtC,CAAC,CAAC;wBACH,MAAM;oBACR,CAAC;oBAED,KAAK,WAAW,CAAC,CAAC,CAAC;wBACjB,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,SAAS,EAAE,GAAG,CAAC,aAAa,EAAE,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC;wBACnF,MAAM;oBACR,CAAC;oBAED,KAAK,MAAM,CAAC,CAAC,CAAC;wBACZ,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;wBAC5B,MAAM;oBACR,CAAC;gBACH,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,EAAE,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;gBAClB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;gBAC3C,IAAI,CAAC,sBAAsB,EAAE,CAAC;gBAC9B,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,KAAK,EAAE,CAAC;oBAC1B,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAC3B,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,EAAE,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;gBACrB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,iBAAiB,EAAE,EAAE,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;gBAC7D,IAAI,CAAC,aAAa,EAAE,CAAC;oBACnB,YAAY,CAAC,SAAS,CAAC,CAAC;oBACxB,MAAM,CAAC,GAAG,CAAC,CAAC;gBACd,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,kBAAkB,CAAC,EAAa;QACtC,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAE9B,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;YAAE,OAAO;QAE9B,IAAI,CAAC,cAAc,GAAG,GAAG,EAAE;YACzB,IAAI,EAAE,CAAC,UAAU,KAAK,SAAS,CAAC,IAAI;gBAAE,OAAO;YAE7C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,8CAA8C,CAAC,CAAC;YACjE,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;YAC7C,IAAI,CAAC,IAAI,CAAC;gBACR,IAAI,EAAE,iBAAiB;gBACvB,UAAU,EAAE,QAAQ,CAAC,UAAU;gBAC/B,aAAa,EAAE,QAAQ,CAAC,aAAa;aACtC,CAAC,CAAC;QACL,CAAC,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,kBAAkB,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IAC5D,CAAC;IAEO,sBAAsB;QAC5B,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;YAC7C,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,kBAAkB,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;YAC3D,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC7B,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,cAAc,CAC1B,SAAiB,EACjB,aAAqB,EACrB,QAAgB,EAChB,IAA6B;QAE7B,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAEzB,MAAM,OAAO,GAAG,IAAI,OAAO,CAAQ,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE;YAC/C,UAAU,CACR,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,gBAAgB,EAAE,CAAC,EACpC,oBAAoB,CACrB,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC;gBAChC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,aAAa,EAAE,QAAQ,EAAE,IAAI,CAAC;gBACrD,OAAO;aACR,CAAC,CAAC;YAEH,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;YAEtD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;gBACnB,aAAa;gBACb,QAAQ;gBACR,SAAS;gBACT,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK;gBAC9B,OAAO,EAAE,IAAI;aACd,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,IAAI,GAAqB,kBAAkB,CAAC;YAChD,IAAI,OAAO,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YAE/D,IAAI,GAAG,YAAY,wBAAwB,EAAE,CAAC;gBAC5C,IAAI,GAAG,uBAAuB,CAAC;YACjC,CAAC;iBAAM,IAAI,GAAG,YAAY,gBAAgB,EAAE,CAAC;gBAC3C,IAAI,GAAG,SAAS,CAAC;YACnB,CAAC;YAED,IAAI,CAAC,IAAI,CAAC;gBACR,IAAI,EAAE,YAAY;gBAClB,SAAS;gBACT,KAAK,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE;aACzB,CAAC,CAAC;YAEH,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;gBACnB,aAAa;gBACb,QAAQ;gBACR,SAAS;gBACT,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK;gBAC9B,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,OAAO;aACf,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAEO,iBAAiB;QACvB,IAAI,IAAI,CAAC,MAAM;YAAE,OAAO;QAExB,MAAM,MAAM,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,gBAAgB,CAAC;QAC9D,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CACpB,IAAI,CAAC,cAAc,GAAG,MAAM,EAC5B,gBAAgB,CACjB,CAAC;QACF,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,CAC5B,IAAI,CAAC,cAAc,GAAG,oBAAoB,EAC1C,gBAAgB,CACjB,CAAC;QAEF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAE3D,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC,KAAK,IAAI,EAAE;YAC1C,IAAI,CAAC;gBACH,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;YACnC,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,qBAAqB,EAAE;oBACvC,KAAK,EAAE,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;iBACxD,CAAC,CAAC;gBACH,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,CAAC;QACH,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;IAEO,IAAI,CAAC,OAAuB;QAClC,IAAI,IAAI,CAAC,EAAE,EAAE,UAAU,KAAK,SAAS,CAAC,IAAI,EAAE,CAAC;YAC3C,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAED,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAClC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC7B,CAAC;QACD,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;YACZ,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC;QACjB,CAAC;QACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;IAChD,CAAC;CACF"}
package/dist/main.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env node
2
+ export {};
3
+ //# sourceMappingURL=main.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"main.d.ts","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":""}
package/dist/main.js ADDED
@@ -0,0 +1,32 @@
1
+ #!/usr/bin/env node
2
+ import { parseConfig } from "./config.js";
3
+ import { Runtime } from "./runtime.js";
4
+ import { GatewayConnection } from "./connection.js";
5
+ import { Logger } from "./common/logger.js";
6
+ async function main() {
7
+ const config = parseConfig(process.env, process.argv);
8
+ const logger = new Logger(config.logLevel);
9
+ logger.info("Starting Journal Gateway", {
10
+ url: config.url,
11
+ mcpServers: config.mcpServers.map((s) => s.id),
12
+ ...(config.skillsDir ? { skillsDir: config.skillsDir } : {}),
13
+ });
14
+ const runtime = new Runtime(config);
15
+ await runtime.start();
16
+ const connection = new GatewayConnection(config, runtime);
17
+ await connection.connect();
18
+ logger.info("Journal Gateway is running");
19
+ const shutdown = async (signal) => {
20
+ logger.info(`Received ${signal}, shutting down`);
21
+ await connection.close();
22
+ await runtime.stop();
23
+ process.exit(0);
24
+ };
25
+ process.on("SIGTERM", () => shutdown("SIGTERM"));
26
+ process.on("SIGINT", () => shutdown("SIGINT"));
27
+ }
28
+ main().catch((err) => {
29
+ console.error("Fatal error:", err);
30
+ process.exit(1);
31
+ });
32
+ //# sourceMappingURL=main.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,KAAK,UAAU,IAAI;IACjB,MAAM,MAAM,GAAG,WAAW,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;IACtD,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IAE3C,MAAM,CAAC,IAAI,CAAC,0BAA0B,EAAE;QACtC,GAAG,EAAE,MAAM,CAAC,GAAG;QACf,UAAU,EAAE,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9C,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KAC7D,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC;IACpC,MAAM,OAAO,CAAC,KAAK,EAAE,CAAC;IAEtB,MAAM,UAAU,GAAG,IAAI,iBAAiB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC1D,MAAM,UAAU,CAAC,OAAO,EAAE,CAAC;IAE3B,MAAM,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;IAE1C,MAAM,QAAQ,GAAG,KAAK,EAAE,MAAc,EAAE,EAAE;QACxC,MAAM,CAAC,IAAI,CAAC,YAAY,MAAM,iBAAiB,CAAC,CAAC;QACjD,MAAM,UAAU,CAAC,KAAK,EAAE,CAAC;QACzB,MAAM,OAAO,CAAC,IAAI,EAAE,CAAC;QACrB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC,CAAC;IAEF,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC;IACjD,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;AACjD,CAAC;AAED,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;IACnB,OAAO,CAAC,KAAK,CAAC,cAAc,EAAE,GAAG,CAAC,CAAC;IACnC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC,CAAC,CAAC"}
@@ -0,0 +1,24 @@
1
+ import type { McpServerConfig } from "./config.js";
2
+ import type { ToolDefinition, ToolResult } from "@journal.one/gateway-protocol";
3
+ import { Logger } from "./common/logger.js";
4
+ import { EventEmitter } from "node:events";
5
+ export interface McpClientEvents {
6
+ crash: [error: Error];
7
+ tools_changed: [];
8
+ }
9
+ export declare class McpClient extends EventEmitter<McpClientEvents> {
10
+ private definition;
11
+ private env;
12
+ private logger;
13
+ private client;
14
+ private transport;
15
+ private running;
16
+ constructor(definition: McpServerConfig, env: Record<string, string>, logger: Logger);
17
+ start(): Promise<void>;
18
+ listTools(): Promise<ToolDefinition[]>;
19
+ callTool(name: string, args: Record<string, unknown>): Promise<ToolResult>;
20
+ stop(): Promise<void>;
21
+ isRunning(): boolean;
22
+ get integrationId(): string;
23
+ }
24
+ //# sourceMappingURL=mcp-client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mcp-client.d.ts","sourceRoot":"","sources":["../src/mcp-client.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACnD,OAAO,KAAK,EAAE,cAAc,EAAE,UAAU,EAAgB,MAAM,+BAA+B,CAAC;AAC9F,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACtB,aAAa,EAAE,EAAE,CAAC;CACnB;AAED,qBAAa,SAAU,SAAQ,YAAY,CAAC,eAAe,CAAC;IAMxD,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,MAAM;IAPhB,OAAO,CAAC,MAAM,CAAuB;IACrC,OAAO,CAAC,SAAS,CAAqC;IACtD,OAAO,CAAC,OAAO,CAAS;gBAGd,UAAU,EAAE,eAAe,EAC3B,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAC3B,MAAM,EAAE,MAAM;IAKlB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IA8CtB,SAAS,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;IAWtC,QAAQ,CACZ,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAC5B,OAAO,CAAC,UAAU,CAAC;IAwBhB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAY3B,SAAS,IAAI,OAAO;IAIpB,IAAI,aAAa,IAAI,MAAM,CAE1B;CACF"}