@agent-relay/sdk 2.3.4 → 2.3.6

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.
@@ -1,129 +0,0 @@
1
- /**
2
- * Transport module for relay client communication.
3
- * @agent-relay/sdk
4
- *
5
- * Provides transport abstraction and implementations:
6
- * - SocketTransport: Unix/TCP sockets (Node.js only)
7
- * - WebSocketTransport: WebSocket connections (Node.js and Browser)
8
- *
9
- * Auto-detection selects the appropriate transport based on environment.
10
- */
11
- // Socket transport (Node.js)
12
- export { SocketTransport, createSocketTransport, } from './socket-transport.js';
13
- // WebSocket transport (Node.js and Browser)
14
- export { WebSocketTransport, createWebSocketTransport, socketPathToWsUrl, } from './websocket-transport.js';
15
- import { SocketTransport } from './socket-transport.js';
16
- import { WebSocketTransport, socketPathToWsUrl } from './websocket-transport.js';
17
- /**
18
- * Detect the current runtime environment.
19
- */
20
- export function detectEnvironment() {
21
- const isBrowser = typeof window !== 'undefined' && typeof window.document !== 'undefined';
22
- const isNode = typeof process !== 'undefined' &&
23
- process.versions != null &&
24
- process.versions.node != null;
25
- const hasWebSocket = typeof WebSocket !== 'undefined' || isNode; // 'ws' can provide WebSocket in Node
26
- const hasUnixSockets = isNode; // Only Node.js supports Unix sockets
27
- return {
28
- isBrowser,
29
- isNode,
30
- hasWebSocket,
31
- hasUnixSockets,
32
- };
33
- }
34
- /**
35
- * Create a transport automatically based on environment and options.
36
- *
37
- * In browser environments, WebSocket transport is always used.
38
- * In Node.js, Unix socket is preferred if socketPath is provided,
39
- * otherwise WebSocket is used if wsUrl or wsHost is provided.
40
- *
41
- * @param options - Transport configuration options
42
- * @returns Configured transport instance
43
- *
44
- * @example Browser usage
45
- * ```typescript
46
- * const transport = createAutoTransport({
47
- * wsUrl: 'wss://relay.example.com/ws'
48
- * });
49
- * ```
50
- *
51
- * @example Node.js with Unix socket
52
- * ```typescript
53
- * const transport = createAutoTransport({
54
- * socketPath: '/tmp/agent-relay.sock'
55
- * });
56
- * ```
57
- *
58
- * @example Node.js with WebSocket
59
- * ```typescript
60
- * const transport = createAutoTransport({
61
- * wsHost: 'localhost',
62
- * wsPort: 3888
63
- * });
64
- * ```
65
- */
66
- export function createAutoTransport(options) {
67
- const env = detectEnvironment();
68
- const { forceTransport, ...config } = options;
69
- // Forced transport type
70
- if (forceTransport === 'websocket') {
71
- return createWsTransportFromOptions(options);
72
- }
73
- if (forceTransport === 'socket') {
74
- if (!options.socketPath) {
75
- throw new Error('socketPath is required when forcing socket transport');
76
- }
77
- if (!env.hasUnixSockets) {
78
- throw new Error('Unix sockets are not available in this environment');
79
- }
80
- return new SocketTransport({
81
- socketPath: options.socketPath,
82
- connectTimeout: config.connectTimeout,
83
- });
84
- }
85
- // Auto-detect: Browser always uses WebSocket
86
- if (env.isBrowser) {
87
- return createWsTransportFromOptions(options);
88
- }
89
- // Node.js: prefer Unix socket if path is provided
90
- if (env.isNode && options.socketPath) {
91
- return new SocketTransport({
92
- socketPath: options.socketPath,
93
- connectTimeout: config.connectTimeout,
94
- });
95
- }
96
- // Fall back to WebSocket
97
- return createWsTransportFromOptions(options);
98
- }
99
- /**
100
- * Create WebSocket transport from options.
101
- */
102
- function createWsTransportFromOptions(options) {
103
- let url = options.wsUrl;
104
- if (!url) {
105
- // Construct URL from components
106
- const host = options.wsHost ?? 'localhost';
107
- const port = options.wsPort ?? 3888;
108
- const path = options.wsPath ?? '/ws';
109
- const secure = options.wsSecure ?? false;
110
- url = socketPathToWsUrl(host, port, path, secure);
111
- }
112
- return new WebSocketTransport({
113
- url,
114
- connectTimeout: options.connectTimeout,
115
- });
116
- }
117
- /**
118
- * Check if running in a browser environment.
119
- */
120
- export function isBrowser() {
121
- return detectEnvironment().isBrowser;
122
- }
123
- /**
124
- * Check if running in Node.js environment.
125
- */
126
- export function isNode() {
127
- return detectEnvironment().isNode;
128
- }
129
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/transports/index.ts"],"names":[],"mappings":"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"}
@@ -1,30 +0,0 @@
1
- /**
2
- * Unix/TCP Socket Transport for Node.js environments.
3
- * @agent-relay/sdk
4
- */
5
- import type { Transport, TransportConfig, TransportEvents, TransportState } from './types.js';
6
- export interface SocketTransportConfig extends TransportConfig {
7
- /** Unix socket path or TCP host:port */
8
- socketPath: string;
9
- }
10
- /**
11
- * Socket-based transport for Unix sockets and TCP connections.
12
- * This is the default transport for Node.js environments.
13
- */
14
- export declare class SocketTransport implements Transport {
15
- private socket?;
16
- private config;
17
- private events;
18
- private _state;
19
- constructor(config: SocketTransportConfig);
20
- get state(): TransportState;
21
- setEvents(events: TransportEvents): void;
22
- connect(): Promise<void>;
23
- disconnect(): void;
24
- send(data: Uint8Array | Buffer): boolean;
25
- }
26
- /**
27
- * Create a socket transport for Unix/TCP connections.
28
- */
29
- export declare function createSocketTransport(socketPath: string, config?: TransportConfig): SocketTransport;
30
- //# sourceMappingURL=socket-transport.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"socket-transport.d.ts","sourceRoot":"","sources":["../../src/transports/socket-transport.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,KAAK,EAAE,SAAS,EAAE,eAAe,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAE9F,MAAM,WAAW,qBAAsB,SAAQ,eAAe;IAC5D,wCAAwC;IACxC,UAAU,EAAE,MAAM,CAAC;CACpB;AAED;;;GAGG;AACH,qBAAa,eAAgB,YAAW,SAAS;IAC/C,OAAO,CAAC,MAAM,CAAC,CAAa;IAC5B,OAAO,CAAC,MAAM,CAAwB;IACtC,OAAO,CAAC,MAAM,CAAuB;IACrC,OAAO,CAAC,MAAM,CAAkC;gBAEpC,MAAM,EAAE,qBAAqB;IAOzC,IAAI,KAAK,IAAI,cAAc,CAE1B;IAED,SAAS,CAAC,MAAM,EAAE,eAAe,GAAG,IAAI;IAIxC,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IA4CxB,UAAU,IAAI,IAAI;IAWlB,IAAI,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,GAAG,OAAO;CAczC;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,eAAe,GAAG,eAAe,CAEnG"}
@@ -1,94 +0,0 @@
1
- /**
2
- * Unix/TCP Socket Transport for Node.js environments.
3
- * @agent-relay/sdk
4
- */
5
- import net from 'node:net';
6
- /**
7
- * Socket-based transport for Unix sockets and TCP connections.
8
- * This is the default transport for Node.js environments.
9
- */
10
- export class SocketTransport {
11
- socket;
12
- config;
13
- events = {};
14
- _state = 'disconnected';
15
- constructor(config) {
16
- this.config = {
17
- connectTimeout: 5000,
18
- ...config,
19
- };
20
- }
21
- get state() {
22
- return this._state;
23
- }
24
- setEvents(events) {
25
- this.events = events;
26
- }
27
- connect() {
28
- if (this._state !== 'disconnected') {
29
- return Promise.resolve();
30
- }
31
- return new Promise((resolve, reject) => {
32
- this._state = 'connecting';
33
- const timeout = setTimeout(() => {
34
- if (this._state === 'connecting') {
35
- this.socket?.destroy();
36
- this._state = 'disconnected';
37
- reject(new Error('Connection timeout'));
38
- }
39
- }, this.config.connectTimeout);
40
- this.socket = net.createConnection(this.config.socketPath, () => {
41
- clearTimeout(timeout);
42
- this._state = 'connected';
43
- this.events.onConnect?.();
44
- resolve();
45
- });
46
- this.socket.on('data', (data) => {
47
- // Convert Buffer to Uint8Array for consistent interface
48
- this.events.onData?.(new Uint8Array(data.buffer, data.byteOffset, data.byteLength));
49
- });
50
- this.socket.on('close', () => {
51
- this._state = 'disconnected';
52
- this.events.onClose?.();
53
- });
54
- this.socket.on('error', (err) => {
55
- clearTimeout(timeout);
56
- if (this._state === 'connecting') {
57
- this._state = 'disconnected';
58
- reject(err);
59
- }
60
- this.events.onError?.(err);
61
- });
62
- });
63
- }
64
- disconnect() {
65
- if (!this.socket || this._state === 'disconnected') {
66
- return;
67
- }
68
- this._state = 'closing';
69
- this.socket.end();
70
- this.socket = undefined;
71
- this._state = 'disconnected';
72
- }
73
- send(data) {
74
- if (!this.socket || this._state !== 'connected') {
75
- return false;
76
- }
77
- try {
78
- // Ensure we're sending a Buffer
79
- const buffer = data instanceof Buffer ? data : Buffer.from(data);
80
- this.socket.write(buffer);
81
- return true;
82
- }
83
- catch {
84
- return false;
85
- }
86
- }
87
- }
88
- /**
89
- * Create a socket transport for Unix/TCP connections.
90
- */
91
- export function createSocketTransport(socketPath, config) {
92
- return new SocketTransport({ socketPath, ...config });
93
- }
94
- //# sourceMappingURL=socket-transport.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"socket-transport.js","sourceRoot":"","sources":["../../src/transports/socket-transport.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,GAAG,MAAM,UAAU,CAAC;AAQ3B;;;GAGG;AACH,MAAM,OAAO,eAAe;IAClB,MAAM,CAAc;IACpB,MAAM,CAAwB;IAC9B,MAAM,GAAoB,EAAE,CAAC;IAC7B,MAAM,GAAmB,cAAc,CAAC;IAEhD,YAAY,MAA6B;QACvC,IAAI,CAAC,MAAM,GAAG;YACZ,cAAc,EAAE,IAAI;YACpB,GAAG,MAAM;SACV,CAAC;IACJ,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,SAAS,CAAC,MAAuB;QAC/B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,MAAM,KAAK,cAAc,EAAE,CAAC;YACnC,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;QAC3B,CAAC;QAED,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC;YAE3B,MAAM,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE;gBAC9B,IAAI,IAAI,CAAC,MAAM,KAAK,YAAY,EAAE,CAAC;oBACjC,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,CAAC;oBACvB,IAAI,CAAC,MAAM,GAAG,cAAc,CAAC;oBAC7B,MAAM,CAAC,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC,CAAC;gBAC1C,CAAC;YACH,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;YAE/B,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,GAAG,EAAE;gBAC9D,YAAY,CAAC,OAAO,CAAC,CAAC;gBACtB,IAAI,CAAC,MAAM,GAAG,WAAW,CAAC;gBAC1B,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,EAAE,CAAC;gBAC1B,OAAO,EAAE,CAAC;YACZ,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;gBAC9B,wDAAwD;gBACxD,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YACtF,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;gBAC3B,IAAI,CAAC,MAAM,GAAG,cAAc,CAAC;gBAC7B,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,CAAC;YAC1B,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;gBAC9B,YAAY,CAAC,OAAO,CAAC,CAAC;gBACtB,IAAI,IAAI,CAAC,MAAM,KAAK,YAAY,EAAE,CAAC;oBACjC,IAAI,CAAC,MAAM,GAAG,cAAc,CAAC;oBAC7B,MAAM,CAAC,GAAG,CAAC,CAAC;gBACd,CAAC;gBACD,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC;YAC7B,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,KAAK,cAAc,EAAE,CAAC;YACnD,OAAO;QACT,CAAC;QAED,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;QACxB,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;QAClB,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;QACxB,IAAI,CAAC,MAAM,GAAG,cAAc,CAAC;IAC/B,CAAC;IAED,IAAI,CAAC,IAAyB;QAC5B,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,KAAK,WAAW,EAAE,CAAC;YAChD,OAAO,KAAK,CAAC;QACf,CAAC;QAED,IAAI,CAAC;YACH,gCAAgC;YAChC,MAAM,MAAM,GAAG,IAAI,YAAY,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACjE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAC1B,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;CACF;AAED;;GAEG;AACH,MAAM,UAAU,qBAAqB,CAAC,UAAkB,EAAE,MAAwB;IAChF,OAAO,IAAI,eAAe,CAAC,EAAE,UAAU,EAAE,GAAG,MAAM,EAAE,CAAC,CAAC;AACxD,CAAC"}
@@ -1,69 +0,0 @@
1
- /**
2
- * Transport abstraction for relay client communication.
3
- * @agent-relay/sdk
4
- *
5
- * Defines the interface for different transport implementations:
6
- * - SocketTransport: Unix/TCP sockets (Node.js)
7
- * - WebSocketTransport: WebSocket connections (Node.js and Browser)
8
- */
9
- /**
10
- * Transport connection state.
11
- */
12
- export type TransportState = 'disconnected' | 'connecting' | 'connected' | 'closing';
13
- /**
14
- * Transport event handlers.
15
- */
16
- export interface TransportEvents {
17
- /** Called when transport connects successfully */
18
- onConnect?: () => void;
19
- /** Called when transport receives data */
20
- onData?: (data: Uint8Array) => void;
21
- /** Called when transport disconnects */
22
- onClose?: () => void;
23
- /** Called when transport encounters an error */
24
- onError?: (error: Error) => void;
25
- }
26
- /**
27
- * Transport configuration options.
28
- */
29
- export interface TransportConfig {
30
- /** Connection timeout in milliseconds */
31
- connectTimeout?: number;
32
- }
33
- /**
34
- * Transport interface for relay client communication.
35
- *
36
- * Implementations must handle:
37
- * - Connection lifecycle (connect, disconnect)
38
- * - Binary data transmission
39
- * - Event callbacks for state changes
40
- */
41
- export interface Transport {
42
- /** Current connection state */
43
- readonly state: TransportState;
44
- /**
45
- * Connect to the relay endpoint.
46
- * @throws Error if connection fails
47
- */
48
- connect(): Promise<void>;
49
- /**
50
- * Disconnect from the relay.
51
- */
52
- disconnect(): void;
53
- /**
54
- * Send binary data to the relay.
55
- * @param data - Data to send (Buffer or Uint8Array)
56
- * @returns true if data was queued for sending
57
- */
58
- send(data: Uint8Array | Buffer): boolean;
59
- /**
60
- * Set event handlers.
61
- * @param events - Event handler callbacks
62
- */
63
- setEvents(events: TransportEvents): void;
64
- }
65
- /**
66
- * Transport factory function type.
67
- */
68
- export type TransportFactory = (config?: TransportConfig) => Transport;
69
- //# sourceMappingURL=types.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/transports/types.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,cAAc,GAAG,YAAY,GAAG,WAAW,GAAG,SAAS,CAAC;AAErF;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,kDAAkD;IAClD,SAAS,CAAC,EAAE,MAAM,IAAI,CAAC;IACvB,0CAA0C;IAC1C,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,UAAU,KAAK,IAAI,CAAC;IACpC,wCAAwC;IACxC,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,gDAAgD;IAChD,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;CAClC;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,yCAAyC;IACzC,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED;;;;;;;GAOG;AACH,MAAM,WAAW,SAAS;IACxB,+BAA+B;IAC/B,QAAQ,CAAC,KAAK,EAAE,cAAc,CAAC;IAE/B;;;OAGG;IACH,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEzB;;OAEG;IACH,UAAU,IAAI,IAAI,CAAC;IAEnB;;;;OAIG;IACH,IAAI,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,GAAG,OAAO,CAAC;IAEzC;;;OAGG;IACH,SAAS,CAAC,MAAM,EAAE,eAAe,GAAG,IAAI,CAAC;CAC1C;AAED;;GAEG;AACH,MAAM,MAAM,gBAAgB,GAAG,CAAC,MAAM,CAAC,EAAE,eAAe,KAAK,SAAS,CAAC"}
@@ -1,10 +0,0 @@
1
- /**
2
- * Transport abstraction for relay client communication.
3
- * @agent-relay/sdk
4
- *
5
- * Defines the interface for different transport implementations:
6
- * - SocketTransport: Unix/TCP sockets (Node.js)
7
- * - WebSocketTransport: WebSocket connections (Node.js and Browser)
8
- */
9
- export {};
10
- //# sourceMappingURL=types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/transports/types.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG"}
@@ -1,55 +0,0 @@
1
- /**
2
- * WebSocket Transport for browser and Node.js environments.
3
- * @agent-relay/sdk
4
- *
5
- * Uses native WebSocket in browsers and 'ws' package in Node.js.
6
- * The transport expects the daemon to have a WebSocket endpoint (e.g., /ws).
7
- */
8
- import type { Transport, TransportConfig, TransportEvents, TransportState } from './types.js';
9
- export interface WebSocketTransportConfig extends TransportConfig {
10
- /** WebSocket URL (e.g., ws://localhost:3888/ws) */
11
- url: string;
12
- /** Protocols to use in WebSocket handshake */
13
- protocols?: string | string[];
14
- }
15
- /**
16
- * WebSocket-based transport for browser and Node.js.
17
- *
18
- * In browsers, uses native WebSocket.
19
- * In Node.js, requires 'ws' package (optional dependency).
20
- */
21
- export declare class WebSocketTransport implements Transport {
22
- private ws?;
23
- private config;
24
- private events;
25
- private _state;
26
- private WebSocketImpl?;
27
- constructor(config: WebSocketTransportConfig);
28
- get state(): TransportState;
29
- setEvents(events: TransportEvents): void;
30
- /**
31
- * Get WebSocket implementation (native or 'ws' package).
32
- */
33
- private getWebSocketImpl;
34
- connect(): Promise<void>;
35
- disconnect(): void;
36
- send(data: Uint8Array | Buffer): boolean;
37
- }
38
- /**
39
- * Create a WebSocket transport.
40
- *
41
- * @param url - WebSocket URL (e.g., ws://localhost:3888/ws)
42
- * @param config - Additional configuration options
43
- */
44
- export declare function createWebSocketTransport(url: string, config?: Omit<WebSocketTransportConfig, 'url'>): WebSocketTransport;
45
- /**
46
- * Convert a socket path to WebSocket URL.
47
- * Useful when daemon provides both Unix socket and WebSocket endpoints.
48
- *
49
- * @param host - Host address (default: localhost)
50
- * @param port - Port number (default: 3888)
51
- * @param path - WebSocket path (default: /ws)
52
- * @param secure - Use wss:// instead of ws:// (default: false)
53
- */
54
- export declare function socketPathToWsUrl(host?: string, port?: number, path?: string, secure?: boolean): string;
55
- //# sourceMappingURL=websocket-transport.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"websocket-transport.d.ts","sourceRoot":"","sources":["../../src/transports/websocket-transport.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,eAAe,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAE9F,MAAM,WAAW,wBAAyB,SAAQ,eAAe;IAC/D,mDAAmD;IACnD,GAAG,EAAE,MAAM,CAAC;IACZ,8CAA8C;IAC9C,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;CAC/B;AAiCD;;;;;GAKG;AACH,qBAAa,kBAAmB,YAAW,SAAS;IAClD,OAAO,CAAC,EAAE,CAAC,CAAgB;IAC3B,OAAO,CAAC,MAAM,CAA2B;IACzC,OAAO,CAAC,MAAM,CAAuB;IACrC,OAAO,CAAC,MAAM,CAAkC;IAChD,OAAO,CAAC,aAAa,CAAC,CAAuB;gBAEjC,MAAM,EAAE,wBAAwB;IAO5C,IAAI,KAAK,IAAI,cAAc,CAE1B;IAED,SAAS,CAAC,MAAM,EAAE,eAAe,GAAG,IAAI;IAIxC;;OAEG;YACW,gBAAgB;IA+BxB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAqE9B,UAAU,IAAI,IAAI;IAWlB,IAAI,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,GAAG,OAAO;CAsBzC;AAED;;;;;GAKG;AACH,wBAAgB,wBAAwB,CACtC,GAAG,EAAE,MAAM,EACX,MAAM,CAAC,EAAE,IAAI,CAAC,wBAAwB,EAAE,KAAK,CAAC,GAC7C,kBAAkB,CAEpB;AAED;;;;;;;;GAQG;AACH,wBAAgB,iBAAiB,CAC/B,IAAI,SAAc,EAClB,IAAI,SAAO,EACX,IAAI,SAAQ,EACZ,MAAM,UAAQ,GACb,MAAM,CAGR"}
@@ -1,180 +0,0 @@
1
- /**
2
- * WebSocket Transport for browser and Node.js environments.
3
- * @agent-relay/sdk
4
- *
5
- * Uses native WebSocket in browsers and 'ws' package in Node.js.
6
- * The transport expects the daemon to have a WebSocket endpoint (e.g., /ws).
7
- */
8
- /**
9
- * WebSocket-based transport for browser and Node.js.
10
- *
11
- * In browsers, uses native WebSocket.
12
- * In Node.js, requires 'ws' package (optional dependency).
13
- */
14
- export class WebSocketTransport {
15
- ws;
16
- config;
17
- events = {};
18
- _state = 'disconnected';
19
- WebSocketImpl;
20
- constructor(config) {
21
- this.config = {
22
- connectTimeout: 5000,
23
- ...config,
24
- };
25
- }
26
- get state() {
27
- return this._state;
28
- }
29
- setEvents(events) {
30
- this.events = events;
31
- }
32
- /**
33
- * Get WebSocket implementation (native or 'ws' package).
34
- */
35
- async getWebSocketImpl() {
36
- if (this.WebSocketImpl) {
37
- return this.WebSocketImpl;
38
- }
39
- // Check for browser environment
40
- if (typeof globalThis !== 'undefined' && 'WebSocket' in globalThis) {
41
- this.WebSocketImpl = globalThis.WebSocket;
42
- return this.WebSocketImpl;
43
- }
44
- // Node.js environment - try to load 'ws' package
45
- try {
46
- // Dynamic import of 'ws' for Node.js
47
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
48
- const wsModule = await import('ws');
49
- const impl = wsModule.default || wsModule.WebSocket || wsModule;
50
- if (!impl) {
51
- throw new Error('ws module loaded but WebSocket constructor not found');
52
- }
53
- this.WebSocketImpl = impl;
54
- return this.WebSocketImpl;
55
- }
56
- catch {
57
- throw new Error('WebSocket not available. In Node.js, install the "ws" package:\n' +
58
- ' npm install ws\n\n' +
59
- 'In browsers, native WebSocket should be available.');
60
- }
61
- }
62
- async connect() {
63
- if (this._state !== 'disconnected') {
64
- return;
65
- }
66
- const WebSocketImpl = await this.getWebSocketImpl();
67
- return new Promise((resolve, reject) => {
68
- this._state = 'connecting';
69
- const timeout = setTimeout(() => {
70
- if (this._state === 'connecting') {
71
- this.ws?.close();
72
- this._state = 'disconnected';
73
- reject(new Error('Connection timeout'));
74
- }
75
- }, this.config.connectTimeout);
76
- try {
77
- this.ws = new WebSocketImpl(this.config.url, this.config.protocols);
78
- this.ws.binaryType = 'arraybuffer';
79
- this.ws.onopen = () => {
80
- clearTimeout(timeout);
81
- this._state = 'connected';
82
- this.events.onConnect?.();
83
- resolve();
84
- };
85
- this.ws.onmessage = (event) => {
86
- // Handle binary data
87
- if (event.data instanceof ArrayBuffer) {
88
- this.events.onData?.(new Uint8Array(event.data));
89
- }
90
- else if (typeof event.data === 'string') {
91
- // Convert string to Uint8Array (shouldn't happen with binaryType = 'arraybuffer')
92
- const encoder = new TextEncoder();
93
- this.events.onData?.(encoder.encode(event.data));
94
- }
95
- else if (event.data && typeof event.data.buffer !== 'undefined') {
96
- // Handle Node.js Buffer
97
- const buf = event.data;
98
- this.events.onData?.(new Uint8Array(buf.buffer, buf.byteOffset, buf.byteLength));
99
- }
100
- };
101
- this.ws.onclose = () => {
102
- clearTimeout(timeout);
103
- this._state = 'disconnected';
104
- this.events.onClose?.();
105
- };
106
- this.ws.onerror = (event) => {
107
- clearTimeout(timeout);
108
- const error = event instanceof Error
109
- ? event
110
- : new Error('WebSocket error');
111
- if (this._state === 'connecting') {
112
- this._state = 'disconnected';
113
- reject(error);
114
- }
115
- this.events.onError?.(error);
116
- };
117
- }
118
- catch (err) {
119
- clearTimeout(timeout);
120
- this._state = 'disconnected';
121
- reject(err instanceof Error ? err : new Error(String(err)));
122
- }
123
- });
124
- }
125
- disconnect() {
126
- if (!this.ws || this._state === 'disconnected') {
127
- return;
128
- }
129
- this._state = 'closing';
130
- this.ws.close();
131
- this.ws = undefined;
132
- this._state = 'disconnected';
133
- }
134
- send(data) {
135
- if (!this.ws || this._state !== 'connected') {
136
- return false;
137
- }
138
- try {
139
- // WebSocket send accepts ArrayBuffer or Uint8Array
140
- // Convert Buffer to Uint8Array for browser compatibility
141
- let bytes;
142
- if (data instanceof Uint8Array) {
143
- bytes = data;
144
- }
145
- else {
146
- // Handle Buffer (Node.js)
147
- const buf = data;
148
- bytes = new Uint8Array(buf.buffer, buf.byteOffset, buf.byteLength);
149
- }
150
- this.ws.send(bytes);
151
- return true;
152
- }
153
- catch {
154
- return false;
155
- }
156
- }
157
- }
158
- /**
159
- * Create a WebSocket transport.
160
- *
161
- * @param url - WebSocket URL (e.g., ws://localhost:3888/ws)
162
- * @param config - Additional configuration options
163
- */
164
- export function createWebSocketTransport(url, config) {
165
- return new WebSocketTransport({ url, ...config });
166
- }
167
- /**
168
- * Convert a socket path to WebSocket URL.
169
- * Useful when daemon provides both Unix socket and WebSocket endpoints.
170
- *
171
- * @param host - Host address (default: localhost)
172
- * @param port - Port number (default: 3888)
173
- * @param path - WebSocket path (default: /ws)
174
- * @param secure - Use wss:// instead of ws:// (default: false)
175
- */
176
- export function socketPathToWsUrl(host = 'localhost', port = 3888, path = '/ws', secure = false) {
177
- const protocol = secure ? 'wss' : 'ws';
178
- return `${protocol}://${host}:${port}${path}`;
179
- }
180
- //# sourceMappingURL=websocket-transport.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"websocket-transport.js","sourceRoot":"","sources":["../../src/transports/websocket-transport.ts"],"names":[],"mappings":"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"}