@elizaos/plugin-tunnel 2.0.0-beta.1 → 2.0.3-beta.3

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 (50) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +8 -6
  3. package/package.json +23 -5
  4. package/registry-entry.json +45 -0
  5. package/src/__tests__/unit/local-tunnel-service.test.ts +244 -13
  6. package/src/actions/start-tunnel.ts +5 -0
  7. package/src/actions/tunnel.ts +7 -30
  8. package/src/environment.ts +4 -3
  9. package/src/index.ts +1 -1
  10. package/src/services/LocalTunnelService.ts +3 -3
  11. package/dist/__tests__/TunnelTestSuite.d.ts +0 -6
  12. package/dist/__tests__/TunnelTestSuite.d.ts.map +0 -1
  13. package/dist/__tests__/TunnelTestSuite.js +0 -47
  14. package/dist/__tests__/TunnelTestSuite.js.map +0 -1
  15. package/dist/actions/get-tunnel-status.d.ts +0 -3
  16. package/dist/actions/get-tunnel-status.d.ts.map +0 -1
  17. package/dist/actions/get-tunnel-status.js +0 -43
  18. package/dist/actions/get-tunnel-status.js.map +0 -1
  19. package/dist/actions/start-tunnel.d.ts +0 -3
  20. package/dist/actions/start-tunnel.d.ts.map +0 -1
  21. package/dist/actions/start-tunnel.js +0 -96
  22. package/dist/actions/start-tunnel.js.map +0 -1
  23. package/dist/actions/stop-tunnel.d.ts +0 -3
  24. package/dist/actions/stop-tunnel.d.ts.map +0 -1
  25. package/dist/actions/stop-tunnel.js +0 -41
  26. package/dist/actions/stop-tunnel.js.map +0 -1
  27. package/dist/actions/tunnel.d.ts +0 -20
  28. package/dist/actions/tunnel.d.ts.map +0 -1
  29. package/dist/actions/tunnel.js +0 -159
  30. package/dist/actions/tunnel.js.map +0 -1
  31. package/dist/environment.d.ts +0 -18
  32. package/dist/environment.d.ts.map +0 -1
  33. package/dist/environment.js +0 -66
  34. package/dist/environment.js.map +0 -1
  35. package/dist/index.d.ts +0 -21
  36. package/dist/index.d.ts.map +0 -1
  37. package/dist/index.js +0 -46
  38. package/dist/index.js.map +0 -1
  39. package/dist/providers/tunnel-state.d.ts +0 -12
  40. package/dist/providers/tunnel-state.d.ts.map +0 -1
  41. package/dist/providers/tunnel-state.js +0 -43
  42. package/dist/providers/tunnel-state.js.map +0 -1
  43. package/dist/services/LocalTunnelService.d.ts +0 -37
  44. package/dist/services/LocalTunnelService.d.ts.map +0 -1
  45. package/dist/services/LocalTunnelService.js +0 -186
  46. package/dist/services/LocalTunnelService.js.map +0 -1
  47. package/dist/types.d.ts +0 -47
  48. package/dist/types.d.ts.map +0 -1
  49. package/dist/types.js +0 -34
  50. package/dist/types.js.map +0 -1
@@ -1,43 +0,0 @@
1
- import { elizaLogger, } from '@elizaos/core';
2
- import { getTunnelService } from '../types';
3
- function formatUptime(startedAt) {
4
- const ms = Date.now() - startedAt.getTime();
5
- const minutes = Math.floor(ms / 60_000);
6
- const hours = Math.floor(minutes / 60);
7
- if (hours > 0) {
8
- return `${hours} hour${hours === 1 ? '' : 's'}, ${minutes % 60} minute${minutes % 60 === 1 ? '' : 's'}`;
9
- }
10
- return `${minutes} minute${minutes === 1 ? '' : 's'}`;
11
- }
12
- export async function handleGetTunnelStatus(runtime, _message, _state, _options, callback) {
13
- const tunnelService = getTunnelService(runtime);
14
- if (!tunnelService) {
15
- if (callback) {
16
- await callback({ text: 'Tunnel service is not available.' });
17
- }
18
- return { success: false, error: 'tunnel service unavailable' };
19
- }
20
- elizaLogger.info('[get-tunnel-status] reading status');
21
- const status = tunnelService.getStatus();
22
- const uptime = status.startedAt ? formatUptime(status.startedAt) : 'N/A';
23
- const responseText = status.active
24
- ? `✅ tunnel active (${status.provider}).\n\nURL: ${status.url}\nLocal port: ${status.port}\nUptime: ${uptime}`
25
- : '❌ No active tunnel. Say "start tunnel on port [PORT]" to start one.';
26
- if (callback) {
27
- await callback({ text: responseText });
28
- }
29
- return {
30
- success: true,
31
- text: responseText,
32
- data: {
33
- action: 'tunnel_status',
34
- active: status.active,
35
- url: status.url ?? '',
36
- port: status.port ?? 0,
37
- provider: status.provider,
38
- backend: status.backend ?? '',
39
- uptime,
40
- },
41
- };
42
- }
43
- //# sourceMappingURL=get-tunnel-status.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"get-tunnel-status.js","sourceRoot":"","sources":["../../src/actions/get-tunnel-status.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,WAAW,GAKZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAE5C,SAAS,YAAY,CAAC,SAAe;IACnC,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC,OAAO,EAAE,CAAC;IAC5C,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,MAAM,CAAC,CAAC;IACxC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC,CAAC;IACvC,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;QACd,OAAO,GAAG,KAAK,QAAQ,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,OAAO,GAAG,EAAE,UAAU,OAAO,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;IAC1G,CAAC;IACD,OAAO,GAAG,OAAO,UAAU,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;AACxD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,OAAsB,EACtB,QAAiB,EACjB,MAAc,EACd,QAAkC,EAClC,QAA0B;IAE1B,MAAM,aAAa,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC;IAChD,IAAI,CAAC,aAAa,EAAE,CAAC;QACnB,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,QAAQ,CAAC,EAAE,IAAI,EAAE,kCAAkC,EAAE,CAAC,CAAC;QAC/D,CAAC;QACD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,4BAA4B,EAAE,CAAC;IACjE,CAAC;IAED,WAAW,CAAC,IAAI,CAAC,oCAAoC,CAAC,CAAC;IACvD,MAAM,MAAM,GAAG,aAAa,CAAC,SAAS,EAAE,CAAC;IACzC,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IAEzE,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM;QAChC,CAAC,CAAC,oBAAoB,MAAM,CAAC,QAAQ,cAAc,MAAM,CAAC,GAAG,iBAAiB,MAAM,CAAC,IAAI,aAAa,MAAM,EAAE;QAC9G,CAAC,CAAC,qEAAqE,CAAC;IAE1E,IAAI,QAAQ,EAAE,CAAC;QACb,MAAM,QAAQ,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,CAAC;IACzC,CAAC;IACD,OAAO;QACL,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE;YACJ,MAAM,EAAE,eAAe;YACvB,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,GAAG,EAAE,MAAM,CAAC,GAAG,IAAI,EAAE;YACrB,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,CAAC;YACtB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,EAAE;YAC7B,MAAM;SACP;KACF,CAAC;AACJ,CAAC"}
@@ -1,3 +0,0 @@
1
- import { type ActionResult, type HandlerCallback, type IAgentRuntime, type Memory, type State } from '@elizaos/core';
2
- export declare function handleStartTunnel(runtime: IAgentRuntime, message: Memory, _state?: State, options?: Record<string, unknown>, callback?: HandlerCallback): Promise<ActionResult>;
3
- //# sourceMappingURL=start-tunnel.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"start-tunnel.d.ts","sourceRoot":"","sources":["../../src/actions/start-tunnel.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,YAAY,EAEjB,KAAK,eAAe,EACpB,KAAK,aAAa,EAClB,KAAK,MAAM,EAEX,KAAK,KAAK,EACX,MAAM,eAAe,CAAC;AA0CvB,wBAAsB,iBAAiB,CACrC,OAAO,EAAE,aAAa,EACtB,OAAO,EAAE,MAAM,EACf,MAAM,CAAC,EAAE,KAAK,EACd,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACjC,QAAQ,CAAC,EAAE,eAAe,GACzB,OAAO,CAAC,YAAY,CAAC,CA4DvB"}
@@ -1,96 +0,0 @@
1
- import { elizaLogger, ModelType, } from '@elizaos/core';
2
- import { z } from 'zod';
3
- import { getTunnelService } from '../types';
4
- const portPayloadSchema = z.object({
5
- port: z.union([z.number(), z.string().regex(/^\d+$/)]).transform((value) => {
6
- const num = typeof value === 'string' ? Number.parseInt(value, 10) : value;
7
- return num;
8
- }),
9
- });
10
- const PORT_PROMPT_TEMPLATE = `Respond with a JSON object containing the port number to start the tunnel on.
11
- The user said: "{{userMessage}}"
12
-
13
- Extract the port number from their message, or use the default port 3000 if not specified.
14
-
15
- Response format:
16
- \`\`\`json
17
- { "port": 3000 }
18
- \`\`\``;
19
- const DEFAULT_PORT = 3000;
20
- function isValidPort(value) {
21
- return Number.isInteger(value) && value >= 1 && value <= 65535;
22
- }
23
- function parsePort(value) {
24
- try {
25
- const parsed = JSON.parse(value);
26
- const result = portPayloadSchema.safeParse(parsed);
27
- if (result.success && isValidPort(result.data.port))
28
- return result.data.port;
29
- }
30
- catch {
31
- // fall through
32
- }
33
- const match = value.match(/\b(\d{1,5})\b/);
34
- const captured = match?.[1];
35
- if (!captured)
36
- return DEFAULT_PORT;
37
- const num = Number.parseInt(captured, 10);
38
- return isValidPort(num) ? num : DEFAULT_PORT;
39
- }
40
- export async function handleStartTunnel(runtime, message, _state, options, callback) {
41
- const tunnelService = getTunnelService(runtime);
42
- if (!tunnelService) {
43
- if (callback) {
44
- await callback({
45
- text: 'Tunnel service is not available. Configure plugin-tunnel, plugin-elizacloud, or plugin-ngrok.',
46
- });
47
- }
48
- return { success: false, error: 'tunnel service unavailable' };
49
- }
50
- if (tunnelService.isActive()) {
51
- if (callback) {
52
- await callback({
53
- text: 'Tunnel is already active. Stop the existing tunnel before starting a new one.',
54
- });
55
- }
56
- return { success: false, error: 'tunnel already active' };
57
- }
58
- elizaLogger.info('[start-tunnel] starting tunnel');
59
- let port;
60
- const explicitPort = options?.port;
61
- if (typeof explicitPort === 'number' && isValidPort(explicitPort)) {
62
- port = explicitPort;
63
- }
64
- else if (typeof explicitPort === 'string' && /^\d+$/.test(explicitPort)) {
65
- const parsed = Number.parseInt(explicitPort, 10);
66
- if (isValidPort(parsed))
67
- port = parsed;
68
- }
69
- if (port === undefined) {
70
- const userMessage = message.content.text ?? '';
71
- const portResponse = await runtime.useModel(ModelType.TEXT_SMALL, {
72
- prompt: PORT_PROMPT_TEMPLATE.replace('{{userMessage}}', userMessage),
73
- temperature: 0.3,
74
- });
75
- port = parsePort(String(portResponse));
76
- }
77
- const url = await tunnelService.startTunnel(port);
78
- const publicUrl = typeof url === 'string' ? url : tunnelService.getUrl();
79
- const status = tunnelService.getStatus();
80
- if (callback) {
81
- await callback({
82
- text: `Tunnel started (${status.provider}).\n\nURL: ${publicUrl ?? 'unknown'}\nLocal port: ${port}`,
83
- });
84
- }
85
- return {
86
- success: true,
87
- text: `Tunnel started on port ${port}`,
88
- data: {
89
- action: 'tunnel_started',
90
- tunnelUrl: publicUrl ?? '',
91
- port,
92
- provider: status.provider,
93
- },
94
- };
95
- }
96
- //# sourceMappingURL=start-tunnel.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"start-tunnel.js","sourceRoot":"","sources":["../../src/actions/start-tunnel.ts"],"names":[],"mappings":"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"}
@@ -1,3 +0,0 @@
1
- import { type ActionResult, type HandlerCallback, type IAgentRuntime, type Memory, type State } from '@elizaos/core';
2
- export declare function handleStopTunnel(runtime: IAgentRuntime, _message?: Memory, _state?: State, _options?: Record<string, unknown>, callback?: HandlerCallback): Promise<ActionResult>;
3
- //# sourceMappingURL=stop-tunnel.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"stop-tunnel.d.ts","sourceRoot":"","sources":["../../src/actions/stop-tunnel.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,YAAY,EAEjB,KAAK,eAAe,EACpB,KAAK,aAAa,EAClB,KAAK,MAAM,EACX,KAAK,KAAK,EACX,MAAM,eAAe,CAAC;AAGvB,wBAAsB,gBAAgB,CACpC,OAAO,EAAE,aAAa,EACtB,QAAQ,CAAC,EAAE,MAAM,EACjB,MAAM,CAAC,EAAE,KAAK,EACd,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAClC,QAAQ,CAAC,EAAE,eAAe,GACzB,OAAO,CAAC,YAAY,CAAC,CAyCvB"}
@@ -1,41 +0,0 @@
1
- import { elizaLogger, } from '@elizaos/core';
2
- import { getTunnelService } from '../types';
3
- export async function handleStopTunnel(runtime, _message, _state, _options, callback) {
4
- const tunnelService = getTunnelService(runtime);
5
- if (!tunnelService) {
6
- if (callback) {
7
- await callback({ text: 'Tunnel service is not available.' });
8
- }
9
- return { success: false, error: 'tunnel service unavailable' };
10
- }
11
- if (!tunnelService.isActive()) {
12
- elizaLogger.warn('[stop-tunnel] no active tunnel to stop');
13
- if (callback) {
14
- await callback({ text: 'No tunnel is currently running.' });
15
- }
16
- return {
17
- success: true,
18
- text: 'no active tunnel',
19
- data: { action: 'tunnel_not_active' },
20
- };
21
- }
22
- const status = tunnelService.getStatus();
23
- const previousUrl = status.url;
24
- const previousPort = status.port;
25
- await tunnelService.stopTunnel();
26
- if (callback) {
27
- await callback({
28
- text: `Tunnel stopped.\n\nWas running on port: ${previousPort}\nPrevious URL: ${previousUrl}`,
29
- });
30
- }
31
- return {
32
- success: true,
33
- text: `Tunnel stopped (was on port ${previousPort})`,
34
- data: {
35
- action: 'tunnel_stopped',
36
- previousUrl: previousUrl ?? '',
37
- previousPort: previousPort ?? 0,
38
- },
39
- };
40
- }
41
- //# sourceMappingURL=stop-tunnel.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"stop-tunnel.js","sourceRoot":"","sources":["../../src/actions/stop-tunnel.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,WAAW,GAKZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAE5C,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,OAAsB,EACtB,QAAiB,EACjB,MAAc,EACd,QAAkC,EAClC,QAA0B;IAE1B,MAAM,aAAa,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC;IAChD,IAAI,CAAC,aAAa,EAAE,CAAC;QACnB,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,QAAQ,CAAC,EAAE,IAAI,EAAE,kCAAkC,EAAE,CAAC,CAAC;QAC/D,CAAC;QACD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,4BAA4B,EAAE,CAAC;IACjE,CAAC;IAED,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,EAAE,CAAC;QAC9B,WAAW,CAAC,IAAI,CAAC,wCAAwC,CAAC,CAAC;QAC3D,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,QAAQ,CAAC,EAAE,IAAI,EAAE,iCAAiC,EAAE,CAAC,CAAC;QAC9D,CAAC;QACD,OAAO;YACL,OAAO,EAAE,IAAI;YACb,IAAI,EAAE,kBAAkB;YACxB,IAAI,EAAE,EAAE,MAAM,EAAE,mBAAmB,EAAE;SACtC,CAAC;IACJ,CAAC;IAED,MAAM,MAAM,GAAG,aAAa,CAAC,SAAS,EAAE,CAAC;IACzC,MAAM,WAAW,GAAG,MAAM,CAAC,GAAG,CAAC;IAC/B,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC;IAEjC,MAAM,aAAa,CAAC,UAAU,EAAE,CAAC;IAEjC,IAAI,QAAQ,EAAE,CAAC;QACb,MAAM,QAAQ,CAAC;YACb,IAAI,EAAE,2CAA2C,YAAY,mBAAmB,WAAW,EAAE;SAC9F,CAAC,CAAC;IACL,CAAC;IACD,OAAO;QACL,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,+BAA+B,YAAY,GAAG;QACpD,IAAI,EAAE;YACJ,MAAM,EAAE,gBAAgB;YACxB,WAAW,EAAE,WAAW,IAAI,EAAE;YAC9B,YAAY,EAAE,YAAY,IAAI,CAAC;SAChC;KACF,CAAC;AACJ,CAAC"}
@@ -1,20 +0,0 @@
1
- /**
2
- * @module tunnel
3
- * @description Single dispatcher action that fans out to the active
4
- * tunnel-service implementation. The action's name is `TUNNEL`; legacy
5
- * `TAILSCALE`-prefixed action names are kept as `similes` so older
6
- * characters and callers still resolve.
7
- *
8
- * Sub-ops (selected via the `action` parameter-enum):
9
- * - start -> handleStartTunnel (optional `port`, defaults to 3000)
10
- * - stop -> handleStopTunnel (no parameters)
11
- * - status -> handleGetTunnelStatus (no parameters)
12
- *
13
- * The handler accepts both call shapes:
14
- * 1. `{ action, ...subParams }`
15
- * 2. `{ parameters: { action, parameters: { ...subParams } } }` (LLM extraction)
16
- */
17
- import type { Action } from '@elizaos/core';
18
- export declare const tunnelAction: Action;
19
- export default tunnelAction;
20
- //# sourceMappingURL=tunnel.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"tunnel.d.ts","sourceRoot":"","sources":["../../src/actions/tunnel.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAEH,OAAO,KAAK,EACV,MAAM,EAMP,MAAM,eAAe,CAAC;AAiDvB,eAAO,MAAM,YAAY,EAAE,MAqH1B,CAAC;AAEF,eAAe,YAAY,CAAC"}
@@ -1,159 +0,0 @@
1
- /**
2
- * @module tunnel
3
- * @description Single dispatcher action that fans out to the active
4
- * tunnel-service implementation. The action's name is `TUNNEL`; legacy
5
- * `TAILSCALE`-prefixed action names are kept as `similes` so older
6
- * characters and callers still resolve.
7
- *
8
- * Sub-ops (selected via the `action` parameter-enum):
9
- * - start -> handleStartTunnel (optional `port`, defaults to 3000)
10
- * - stop -> handleStopTunnel (no parameters)
11
- * - status -> handleGetTunnelStatus (no parameters)
12
- *
13
- * The handler accepts both call shapes:
14
- * 1. `{ action, ...subParams }`
15
- * 2. `{ parameters: { action, parameters: { ...subParams } } }` (LLM extraction)
16
- */
17
- import { getTunnelService } from '../types';
18
- import { handleGetTunnelStatus } from './get-tunnel-status';
19
- import { handleStartTunnel } from './start-tunnel';
20
- import { handleStopTunnel } from './stop-tunnel';
21
- const SUPPORTED_OPS = ['start', 'stop', 'status'];
22
- function pickRecord(value) {
23
- return value && typeof value === 'object' && !Array.isArray(value)
24
- ? value
25
- : undefined;
26
- }
27
- function resolveDispatch(options) {
28
- if (!options) {
29
- return { action: null, subOptions: {} };
30
- }
31
- const nested = pickRecord(options.parameters);
32
- const actionSource = nested ?? options;
33
- const rawAction = actionSource.action ?? actionSource.subaction ?? actionSource.op;
34
- const action = typeof rawAction === 'string' ? rawAction.toLowerCase() : null;
35
- let subOptions;
36
- if (nested) {
37
- const innerParams = pickRecord(nested.parameters);
38
- if (innerParams) {
39
- subOptions = { ...innerParams };
40
- }
41
- else {
42
- const { action: _omitAction, subaction: _omitSubaction, op: _omitOp, parameters: _omitParams, ...rest } = nested;
43
- subOptions = rest;
44
- }
45
- }
46
- else {
47
- const { action: _omitAction, subaction: _omitSubaction, op: _omitOp, ...rest } = options;
48
- subOptions = rest;
49
- }
50
- return { action, subOptions };
51
- }
52
- export const tunnelAction = {
53
- name: 'TUNNEL',
54
- similes: [
55
- // Legacy action names kept so existing characters/transcripts still resolve.
56
- 'TAILSCALE',
57
- 'START_TAILSCALE',
58
- 'STOP_TAILSCALE',
59
- 'GET_TAILSCALE_STATUS',
60
- 'START_TUNNEL',
61
- 'OPEN_TUNNEL',
62
- 'CREATE_TUNNEL',
63
- 'TAILSCALE_UP',
64
- 'STOP_TUNNEL',
65
- 'CLOSE_TUNNEL',
66
- 'TAILSCALE_DOWN',
67
- 'TAILSCALE_STATUS',
68
- 'CHECK_TUNNEL',
69
- 'TUNNEL_INFO',
70
- 'TUNNEL_STATUS',
71
- ],
72
- description: 'Tunnel operations dispatched by `action`: start, stop, status. The `start` action accepts an optional `port` (defaults to 3000); `stop` and `status` take no parameters. Backed by whichever tunnel plugin is active (local Tailscale CLI, Eliza Cloud headscale, or ngrok).',
73
- parameters: [
74
- {
75
- name: 'action',
76
- description: 'Which tunnel sub-operation to run. One of: start, stop, status.',
77
- required: true,
78
- schema: {
79
- type: 'string',
80
- enum: [...SUPPORTED_OPS],
81
- },
82
- },
83
- {
84
- name: 'parameters',
85
- description: 'Parameters forwarded to the selected sub-op. For `start`, optionally `{ port: number }`. `stop` and `status` take no parameters.',
86
- required: false,
87
- schema: { type: 'object' },
88
- },
89
- ],
90
- validate: async (runtime) => {
91
- return Boolean(getTunnelService(runtime));
92
- },
93
- handler: async (runtime, message, state, options, callback) => {
94
- const { action, subOptions } = resolveDispatch(options);
95
- if (!action) {
96
- const err = `TUNNEL requires action=start|stop|status`;
97
- if (callback)
98
- await callback({ text: err });
99
- return { success: false, error: err };
100
- }
101
- switch (action) {
102
- case 'start':
103
- return handleStartTunnel(runtime, message, state, subOptions, callback);
104
- case 'stop':
105
- return handleStopTunnel(runtime, message, state, subOptions, callback);
106
- case 'status':
107
- return handleGetTunnelStatus(runtime, message, state, subOptions, callback);
108
- default: {
109
- const err = `Unknown TUNNEL action "${action}". Supported: ${SUPPORTED_OPS.join(', ')}`;
110
- if (callback)
111
- await callback({ text: err });
112
- return { success: false, error: err };
113
- }
114
- }
115
- },
116
- examples: [
117
- [
118
- {
119
- name: '{{user1}}',
120
- content: { text: 'Start a tunnel on port 8080' },
121
- },
122
- {
123
- name: '{{agentName}}',
124
- content: {
125
- text: 'Tunnel started (tailscale).\n\nURL: https://device.tail-scale.ts.net\nLocal port: 8080',
126
- actions: ['TUNNEL'],
127
- },
128
- },
129
- ],
130
- [
131
- {
132
- name: '{{user1}}',
133
- content: { text: 'Stop the tunnel' },
134
- },
135
- {
136
- name: '{{agentName}}',
137
- content: {
138
- text: 'Tunnel stopped.',
139
- actions: ['TUNNEL'],
140
- },
141
- },
142
- ],
143
- [
144
- {
145
- name: '{{user1}}',
146
- content: { text: 'What is the tunnel status?' },
147
- },
148
- {
149
- name: '{{agentName}}',
150
- content: {
151
- text: '✅ tunnel active (tailscale).',
152
- actions: ['TUNNEL'],
153
- },
154
- },
155
- ],
156
- ],
157
- };
158
- export default tunnelAction;
159
- //# sourceMappingURL=tunnel.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"tunnel.js","sourceRoot":"","sources":["../../src/actions/tunnel.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAUH,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAC5C,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAEjD,MAAM,aAAa,GAAG,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,CAAU,CAAC;AAE3D,SAAS,UAAU,CAAC,KAAc;IAChC,OAAO,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;QAChE,CAAC,CAAE,KAAiC;QACpC,CAAC,CAAC,SAAS,CAAC;AAChB,CAAC;AAED,SAAS,eAAe,CAAC,OAA4C;IAInE,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC;IAC1C,CAAC;IACD,MAAM,MAAM,GAAG,UAAU,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC9C,MAAM,YAAY,GAAG,MAAM,IAAI,OAAO,CAAC;IACvC,MAAM,SAAS,GAAG,YAAY,CAAC,MAAM,IAAI,YAAY,CAAC,SAAS,IAAI,YAAY,CAAC,EAAE,CAAC;IACnF,MAAM,MAAM,GAAG,OAAO,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;IAE9E,IAAI,UAAmC,CAAC;IACxC,IAAI,MAAM,EAAE,CAAC;QACX,MAAM,WAAW,GAAG,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAClD,IAAI,WAAW,EAAE,CAAC;YAChB,UAAU,GAAG,EAAE,GAAG,WAAW,EAAE,CAAC;QAClC,CAAC;aAAM,CAAC;YACN,MAAM,EACJ,MAAM,EAAE,WAAW,EACnB,SAAS,EAAE,cAAc,EACzB,EAAE,EAAE,OAAO,EACX,UAAU,EAAE,WAAW,EACvB,GAAG,IAAI,EACR,GAAG,MAAM,CAAC;YACX,UAAU,GAAG,IAAI,CAAC;QACpB,CAAC;IACH,CAAC;SAAM,CAAC;QACN,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,cAAc,EAAE,EAAE,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,GAAG,OAAO,CAAC;QACzF,UAAU,GAAG,IAAI,CAAC;IACpB,CAAC;IAED,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC;AAChC,CAAC;AAED,MAAM,CAAC,MAAM,YAAY,GAAW;IAClC,IAAI,EAAE,QAAQ;IACd,OAAO,EAAE;QACP,6EAA6E;QAC7E,WAAW;QACX,iBAAiB;QACjB,gBAAgB;QAChB,sBAAsB;QACtB,cAAc;QACd,aAAa;QACb,eAAe;QACf,cAAc;QACd,aAAa;QACb,cAAc;QACd,gBAAgB;QAChB,kBAAkB;QAClB,cAAc;QACd,aAAa;QACb,eAAe;KAChB;IACD,WAAW,EACT,8QAA8Q;IAEhR,UAAU,EAAE;QACV;YACE,IAAI,EAAE,QAAQ;YACd,WAAW,EAAE,iEAAiE;YAC9E,QAAQ,EAAE,IAAI;YACd,MAAM,EAAE;gBACN,IAAI,EAAE,QAAQ;gBACd,IAAI,EAAE,CAAC,GAAG,aAAa,CAAC;aACzB;SACF;QACD;YACE,IAAI,EAAE,YAAY;YAClB,WAAW,EACT,kIAAkI;YACpI,QAAQ,EAAE,KAAK;YACf,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;SAC3B;KACF;IAED,QAAQ,EAAE,KAAK,EAAE,OAAsB,EAAoB,EAAE;QAC3D,OAAO,OAAO,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC;IAC5C,CAAC;IAED,OAAO,EAAE,KAAK,EACZ,OAAsB,EACtB,OAAe,EACf,KAAa,EACb,OAAiC,EACjC,QAA0B,EACH,EAAE;QACzB,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;QAExD,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,GAAG,GAAG,0CAA0C,CAAC;YACvD,IAAI,QAAQ;gBAAE,MAAM,QAAQ,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;YAC5C,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;QACxC,CAAC;QAED,QAAQ,MAAM,EAAE,CAAC;YACf,KAAK,OAAO;gBACV,OAAO,iBAAiB,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;YAC1E,KAAK,MAAM;gBACT,OAAO,gBAAgB,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;YACzE,KAAK,QAAQ;gBACX,OAAO,qBAAqB,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;YAC9E,OAAO,CAAC,CAAC,CAAC;gBACR,MAAM,GAAG,GAAG,0BAA0B,MAAM,iBAAiB,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;gBACxF,IAAI,QAAQ;oBAAE,MAAM,QAAQ,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;gBAC5C,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;YACxC,CAAC;QACH,CAAC;IACH,CAAC;IAED,QAAQ,EAAE;QACR;YACE;gBACE,IAAI,EAAE,WAAW;gBACjB,OAAO,EAAE,EAAE,IAAI,EAAE,6BAA6B,EAAE;aACjD;YACD;gBACE,IAAI,EAAE,eAAe;gBACrB,OAAO,EAAE;oBACP,IAAI,EAAE,wFAAwF;oBAC9F,OAAO,EAAE,CAAC,QAAQ,CAAC;iBACpB;aACF;SACF;QACD;YACE;gBACE,IAAI,EAAE,WAAW;gBACjB,OAAO,EAAE,EAAE,IAAI,EAAE,iBAAiB,EAAE;aACrC;YACD;gBACE,IAAI,EAAE,eAAe;gBACrB,OAAO,EAAE;oBACP,IAAI,EAAE,iBAAiB;oBACvB,OAAO,EAAE,CAAC,QAAQ,CAAC;iBACpB;aACF;SACF;QACD;YACE;gBACE,IAAI,EAAE,WAAW;gBACjB,OAAO,EAAE,EAAE,IAAI,EAAE,4BAA4B,EAAE;aAChD;YACD;gBACE,IAAI,EAAE,eAAe;gBACrB,OAAO,EAAE;oBACP,IAAI,EAAE,8BAA8B;oBACpC,OAAO,EAAE,CAAC,QAAQ,CAAC;iBACpB;aACF;SACF;KACF;CACF,CAAC;AAEF,eAAe,YAAY,CAAC"}
@@ -1,18 +0,0 @@
1
- import type { IAgentRuntime } from '@elizaos/core';
2
- import { z } from 'zod';
3
- /**
4
- * Local-CLI tunnel config. The cloud-backed (headscale) flavor lives in
5
- * `@elizaos/plugin-elizacloud`; this package only configures the local
6
- * `tailscale` CLI.
7
- *
8
- * `TUNNEL_*` env vars are the canonical names. `TAILSCALE_*` are accepted
9
- * as aliases for one release window so existing `.env` files keep working.
10
- */
11
- export declare const tunnelEnvSchema: z.ZodObject<{
12
- TUNNEL_TAGS: z.ZodDefault<z.ZodPipe<z.ZodOptional<z.ZodUnion<readonly [z.ZodString, z.ZodArray<z.ZodString>]>>, z.ZodTransform<string[], string | string[] | undefined>>>;
13
- TUNNEL_FUNNEL: z.ZodDefault<z.ZodPipe<z.ZodOptional<z.ZodUnion<readonly [z.ZodString, z.ZodBoolean]>>, z.ZodTransform<boolean, string | boolean | undefined>>>;
14
- TUNNEL_DEFAULT_PORT: z.ZodDefault<z.ZodPipe<z.ZodOptional<z.ZodUnion<readonly [z.ZodString, z.ZodNumber]>>, z.ZodTransform<number, string | number | undefined>>>;
15
- }, z.core.$strip>;
16
- export type TunnelConfig = z.infer<typeof tunnelEnvSchema>;
17
- export declare function validateTunnelConfig(runtime: IAgentRuntime): Promise<TunnelConfig>;
18
- //# sourceMappingURL=environment.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"environment.d.ts","sourceRoot":"","sources":["../src/environment.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB;;;;;;;GAOG;AACH,eAAO,MAAM,eAAe;;;;iBA6B1B,CAAC;AAEH,MAAM,MAAM,YAAY,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,eAAe,CAAC,CAAC;AAwB3D,wBAAsB,oBAAoB,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,YAAY,CAAC,CAOxF"}
@@ -1,66 +0,0 @@
1
- import { z } from 'zod';
2
- /**
3
- * Local-CLI tunnel config. The cloud-backed (headscale) flavor lives in
4
- * `@elizaos/plugin-elizacloud`; this package only configures the local
5
- * `tailscale` CLI.
6
- *
7
- * `TUNNEL_*` env vars are the canonical names. `TAILSCALE_*` are accepted
8
- * as aliases for one release window so existing `.env` files keep working.
9
- */
10
- export const tunnelEnvSchema = z.object({
11
- TUNNEL_TAGS: z
12
- .union([z.string(), z.array(z.string())])
13
- .optional()
14
- .transform((value) => {
15
- if (Array.isArray(value))
16
- return value.filter((tag) => tag.length > 0);
17
- if (typeof value === 'string' && value.length > 0)
18
- return value
19
- .split(',')
20
- .map((tag) => tag.trim())
21
- .filter((tag) => tag.length > 0);
22
- return ['tag:eliza-tunnel'];
23
- })
24
- .default(['tag:eliza-tunnel']),
25
- TUNNEL_FUNNEL: z
26
- .union([z.string(), z.boolean()])
27
- .optional()
28
- .transform((value) => value === true || value === 'true' || value === '1')
29
- .default(false),
30
- TUNNEL_DEFAULT_PORT: z
31
- .union([z.string(), z.number()])
32
- .optional()
33
- .transform((value) => {
34
- if (value === undefined || value === '')
35
- return 3000;
36
- const num = typeof value === 'string' ? Number.parseInt(value, 10) : value;
37
- if (Number.isNaN(num) || num <= 0 || num > 65535)
38
- return 3000;
39
- return num;
40
- })
41
- .default(3000),
42
- });
43
- function readSetting(runtime, key) {
44
- const value = runtime.getSetting(key);
45
- if (value === null || value === undefined)
46
- return undefined;
47
- return String(value);
48
- }
49
- /**
50
- * Read `TUNNEL_<KEY>` first, then fall back to the legacy `TAILSCALE_<KEY>`.
51
- */
52
- function readWithLegacy(runtime, newKey, legacyKey) {
53
- return (readSetting(runtime, newKey) ??
54
- readSetting(runtime, legacyKey) ??
55
- process.env[newKey] ??
56
- process.env[legacyKey]);
57
- }
58
- export async function validateTunnelConfig(runtime) {
59
- const config = {
60
- TUNNEL_TAGS: readWithLegacy(runtime, 'TUNNEL_TAGS', 'TAILSCALE_TAGS'),
61
- TUNNEL_FUNNEL: readWithLegacy(runtime, 'TUNNEL_FUNNEL', 'TAILSCALE_FUNNEL'),
62
- TUNNEL_DEFAULT_PORT: readWithLegacy(runtime, 'TUNNEL_DEFAULT_PORT', 'TAILSCALE_DEFAULT_PORT'),
63
- };
64
- return tunnelEnvSchema.parse(config);
65
- }
66
- //# sourceMappingURL=environment.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"environment.js","sourceRoot":"","sources":["../src/environment.ts"],"names":[],"mappings":"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"}
package/dist/index.d.ts DELETED
@@ -1,21 +0,0 @@
1
- import { type Plugin } from '@elizaos/core';
2
- /**
3
- * Local Tailscale-CLI tunnel plugin.
4
- *
5
- * Registers `serviceType = "tunnel"` ONLY when:
6
- * 1. No other tunnel service has already claimed the slot (first-active-wins
7
- * across plugin-tunnel, plugin-elizacloud, plugin-ngrok), AND
8
- * 2. The `tailscale` CLI is on PATH.
9
- *
10
- * The Eliza Cloud (headscale) tunnel lives in `@elizaos/plugin-elizacloud`.
11
- * Ngrok lives in `@elizaos/plugin-ngrok`. Enable as many as you like — only
12
- * one will bind.
13
- */
14
- export declare const tunnelPlugin: Plugin;
15
- export default tunnelPlugin;
16
- export { tunnelAction } from './actions/tunnel';
17
- export { type TunnelConfig, validateTunnelConfig } from './environment';
18
- export { tunnelStateProvider } from './providers/tunnel-state';
19
- export { checkTailscaleInstalled, LocalTunnelService } from './services/LocalTunnelService';
20
- export { getTunnelService, type ITunnelService, type TunnelProvider, type TunnelStatus, tunnelSlotIsFree, } from './types';
21
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAA2C,KAAK,MAAM,EAAE,MAAM,eAAe,CAAC;AAOrF;;;;;;;;;;;GAWG;AACH,eAAO,MAAM,YAAY,EAAE,MAwB1B,CAAC;AAEF,eAAe,YAAY,CAAC;AAE5B,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAE,KAAK,YAAY,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACxE,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAE/D,OAAO,EAAE,uBAAuB,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AAC5F,OAAO,EACL,gBAAgB,EAChB,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,KAAK,YAAY,EACjB,gBAAgB,GACjB,MAAM,SAAS,CAAC"}
package/dist/index.js DELETED
@@ -1,46 +0,0 @@
1
- import { elizaLogger, promoteSubactionsToActions } from '@elizaos/core';
2
- import { TunnelTestSuite } from './__tests__/TunnelTestSuite';
3
- import { tunnelAction } from './actions/tunnel';
4
- import { tunnelStateProvider } from './providers/tunnel-state';
5
- import { checkTailscaleInstalled, LocalTunnelService } from './services/LocalTunnelService';
6
- import { tunnelSlotIsFree } from './types';
7
- /**
8
- * Local Tailscale-CLI tunnel plugin.
9
- *
10
- * Registers `serviceType = "tunnel"` ONLY when:
11
- * 1. No other tunnel service has already claimed the slot (first-active-wins
12
- * across plugin-tunnel, plugin-elizacloud, plugin-ngrok), AND
13
- * 2. The `tailscale` CLI is on PATH.
14
- *
15
- * The Eliza Cloud (headscale) tunnel lives in `@elizaos/plugin-elizacloud`.
16
- * Ngrok lives in `@elizaos/plugin-ngrok`. Enable as many as you like — only
17
- * one will bind.
18
- */
19
- export const tunnelPlugin = {
20
- name: 'tunnel',
21
- description: 'Local Tailscale-CLI tunnel backend (serve / funnel). Coexists with plugin-elizacloud and plugin-ngrok via first-active-wins registration.',
22
- actions: [...promoteSubactionsToActions(tunnelAction)],
23
- providers: [tunnelStateProvider],
24
- tests: [new TunnelTestSuite()],
25
- init: async (_config, runtime) => {
26
- if (!tunnelSlotIsFree(runtime)) {
27
- elizaLogger.info('[plugin-tunnel] another tunnel service already registered — skipping LocalTunnelService');
28
- return;
29
- }
30
- const installed = await checkTailscaleInstalled();
31
- if (!installed) {
32
- elizaLogger.info('[plugin-tunnel] tailscale CLI not found on PATH — skipping LocalTunnelService');
33
- return;
34
- }
35
- elizaLogger.info('[plugin-tunnel] registering LocalTunnelService for serviceType="tunnel"');
36
- await runtime.registerService(LocalTunnelService);
37
- },
38
- };
39
- export default tunnelPlugin;
40
- export { tunnelAction } from './actions/tunnel';
41
- export { validateTunnelConfig } from './environment';
42
- export { tunnelStateProvider } from './providers/tunnel-state';
43
- // Public surface for consumers and sibling tunnel plugins.
44
- export { checkTailscaleInstalled, LocalTunnelService } from './services/LocalTunnelService';
45
- export { getTunnelService, tunnelSlotIsFree, } from './types';
46
- //# sourceMappingURL=index.js.map
package/dist/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,0BAA0B,EAAe,MAAM,eAAe,CAAC;AACrF,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EAAE,uBAAuB,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AAC5F,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE3C;;;;;;;;;;;GAWG;AACH,MAAM,CAAC,MAAM,YAAY,GAAW;IAClC,IAAI,EAAE,QAAQ;IACd,WAAW,EACT,2IAA2I;IAC7I,OAAO,EAAE,CAAC,GAAG,0BAA0B,CAAC,YAAY,CAAC,CAAC;IACtD,SAAS,EAAE,CAAC,mBAAmB,CAAC;IAChC,KAAK,EAAE,CAAC,IAAI,eAAe,EAAE,CAAC;IAC9B,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE;QAC/B,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,EAAE,CAAC;YAC/B,WAAW,CAAC,IAAI,CACd,yFAAyF,CAC1F,CAAC;YACF,OAAO;QACT,CAAC;QACD,MAAM,SAAS,GAAG,MAAM,uBAAuB,EAAE,CAAC;QAClD,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,WAAW,CAAC,IAAI,CACd,+EAA+E,CAChF,CAAC;YACF,OAAO;QACT,CAAC;QACD,WAAW,CAAC,IAAI,CAAC,yEAAyE,CAAC,CAAC;QAC5F,MAAM,OAAO,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC;IACpD,CAAC;CACF,CAAC;AAEF,eAAe,YAAY,CAAC;AAE5B,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAqB,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACxE,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,2DAA2D;AAC3D,OAAO,EAAE,uBAAuB,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AAC5F,OAAO,EACL,gBAAgB,EAIhB,gBAAgB,GACjB,MAAM,SAAS,CAAC"}
@@ -1,12 +0,0 @@
1
- import type { Provider } from '@elizaos/core';
2
- /**
3
- * Surfaces the active tunnel's status into the model's state. Renders a
4
- * one-line text summary and exposes the raw status object via `data`.
5
- *
6
- * Backend-agnostic — works with whichever tunnel implementation
7
- * (`LocalTunnelService` here, `CloudTunnelService` in plugin-elizacloud,
8
- * the ngrok service, etc.) won the `serviceType="tunnel"` slot.
9
- */
10
- export declare const tunnelStateProvider: Provider;
11
- export default tunnelStateProvider;
12
- //# sourceMappingURL=tunnel-state.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"tunnel-state.d.ts","sourceRoot":"","sources":["../../src/providers/tunnel-state.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAG9C;;;;;;;GAOG;AACH,eAAO,MAAM,mBAAmB,EAAE,QAgCjC,CAAC;AAEF,eAAe,mBAAmB,CAAC"}
@@ -1,43 +0,0 @@
1
- import { getTunnelService } from '../types';
2
- /**
3
- * Surfaces the active tunnel's status into the model's state. Renders a
4
- * one-line text summary and exposes the raw status object via `data`.
5
- *
6
- * Backend-agnostic — works with whichever tunnel implementation
7
- * (`LocalTunnelService` here, `CloudTunnelService` in plugin-elizacloud,
8
- * the ngrok service, etc.) won the `serviceType="tunnel"` slot.
9
- */
10
- export const tunnelStateProvider = {
11
- name: 'TUNNEL_STATE',
12
- description: 'Current tunnel status: active flag, public URL, local port, provider, backend.',
13
- descriptionCompressed: 'Tunnel: active/url/port/provider/backend',
14
- contexts: ['devtools', 'system'],
15
- relevanceKeywords: ['tunnel', 'tailscale', 'headscale', 'ngrok', 'serve', 'funnel', 'expose'],
16
- position: 200,
17
- get: async (runtime, _message) => {
18
- const svc = getTunnelService(runtime);
19
- if (!svc) {
20
- return {
21
- text: 'No tunnel service is registered.',
22
- data: {
23
- active: false,
24
- available: false,
25
- },
26
- };
27
- }
28
- const status = svc.getStatus();
29
- const text = status.active
30
- ? `Tunnel ACTIVE — ${status.url ?? 'unknown URL'} (port ${status.port}, ${status.provider}${status.backend ? `/${status.backend}` : ''})`
31
- : `Tunnel idle (${status.provider} ready).`;
32
- return {
33
- text,
34
- data: {
35
- available: true,
36
- ...status,
37
- startedAt: status.startedAt ? status.startedAt.toISOString() : null,
38
- },
39
- };
40
- },
41
- };
42
- export default tunnelStateProvider;
43
- //# sourceMappingURL=tunnel-state.js.map