@ravi-hq/ravi 0.5.3 → 0.5.5

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 (83) hide show
  1. package/README.md +62 -68
  2. package/dist/auth.d.ts +2 -0
  3. package/dist/auth.d.ts.map +1 -1
  4. package/dist/auth.js.map +1 -1
  5. package/dist/bin/ravi-secrets.d.ts +3 -3
  6. package/dist/bin/ravi-secrets.js +7 -7
  7. package/dist/bin/ravi-secrets.js.map +1 -1
  8. package/dist/channels/email-trusted.d.ts.map +1 -1
  9. package/dist/channels/email-trusted.js +5 -7
  10. package/dist/channels/email-trusted.js.map +1 -1
  11. package/dist/channels/email-untrusted.d.ts.map +1 -1
  12. package/dist/channels/email-untrusted.js +5 -7
  13. package/dist/channels/email-untrusted.js.map +1 -1
  14. package/dist/channels/email.d.ts +12 -22
  15. package/dist/channels/email.d.ts.map +1 -1
  16. package/dist/channels/email.js +48 -54
  17. package/dist/channels/email.js.map +1 -1
  18. package/dist/cli.d.ts +15 -2
  19. package/dist/cli.d.ts.map +1 -1
  20. package/dist/cli.js +271 -211
  21. package/dist/cli.js.map +1 -1
  22. package/dist/client.d.ts +62 -22
  23. package/dist/client.d.ts.map +1 -1
  24. package/dist/client.js +75 -33
  25. package/dist/client.js.map +1 -1
  26. package/dist/index.d.ts +7 -19
  27. package/dist/index.d.ts.map +1 -1
  28. package/dist/index.js +19 -76
  29. package/dist/index.js.map +1 -1
  30. package/dist/sse-pool.d.ts +5 -2
  31. package/dist/sse-pool.d.ts.map +1 -1
  32. package/dist/sse-pool.js +9 -7
  33. package/dist/sse-pool.js.map +1 -1
  34. package/dist/sse.d.ts +7 -21
  35. package/dist/sse.d.ts.map +1 -1
  36. package/dist/sse.js +10 -33
  37. package/dist/sse.js.map +1 -1
  38. package/dist/tools/contacts.d.ts +14 -0
  39. package/dist/tools/contacts.d.ts.map +1 -0
  40. package/dist/tools/contacts.js +186 -0
  41. package/dist/tools/contacts.js.map +1 -0
  42. package/dist/tools/email-send.d.ts.map +1 -1
  43. package/dist/tools/email-send.js +11 -4
  44. package/dist/tools/email-send.js.map +1 -1
  45. package/dist/tools/identity.d.ts +2 -2
  46. package/dist/tools/identity.d.ts.map +1 -1
  47. package/dist/tools/identity.js +14 -6
  48. package/dist/tools/identity.js.map +1 -1
  49. package/dist/tools/inbox.js +7 -7
  50. package/dist/tools/inbox.js.map +1 -1
  51. package/dist/tools/passwords.d.ts.map +1 -1
  52. package/dist/tools/passwords.js +20 -7
  53. package/dist/tools/passwords.js.map +1 -1
  54. package/dist/tools/secrets.d.ts +15 -0
  55. package/dist/tools/secrets.d.ts.map +1 -0
  56. package/dist/tools/{vault.js → secrets.js} +23 -23
  57. package/dist/tools/secrets.js.map +1 -0
  58. package/dist/tools/sms-send.d.ts.map +1 -1
  59. package/dist/tools/sms-send.js +3 -1
  60. package/dist/tools/sms-send.js.map +1 -1
  61. package/dist/types.d.ts +18 -12
  62. package/dist/types.d.ts.map +1 -1
  63. package/openclaw.plugin.json +1 -1
  64. package/package.json +4 -13
  65. package/dist/channels/sms-trusted.d.ts +0 -161
  66. package/dist/channels/sms-trusted.d.ts.map +0 -1
  67. package/dist/channels/sms-trusted.js +0 -306
  68. package/dist/channels/sms-trusted.js.map +0 -1
  69. package/dist/channels/sms-untrusted.d.ts +0 -124
  70. package/dist/channels/sms-untrusted.d.ts.map +0 -1
  71. package/dist/channels/sms-untrusted.js +0 -269
  72. package/dist/channels/sms-untrusted.js.map +0 -1
  73. package/dist/channels/sms.d.ts +0 -279
  74. package/dist/channels/sms.d.ts.map +0 -1
  75. package/dist/channels/sms.js +0 -385
  76. package/dist/channels/sms.js.map +0 -1
  77. package/dist/service.d.ts +0 -107
  78. package/dist/service.d.ts.map +0 -1
  79. package/dist/service.js +0 -211
  80. package/dist/service.js.map +0 -1
  81. package/dist/tools/vault.d.ts +0 -15
  82. package/dist/tools/vault.d.ts.map +0 -1
  83. package/dist/tools/vault.js.map +0 -1
@@ -1,385 +0,0 @@
1
- // ─── Channel Definition ──────────────────────────────────────────────────────
2
- /**
3
- * Creates the ravi-sms channel definition for OpenClaw.
4
- *
5
- * All messages from one phone number are grouped into a single session:
6
- * - A new `from_number` triggers creation of a new session.
7
- * - A known `from_number` resumes the existing session.
8
- *
9
- * The channel is a plain object (not a class) following OpenClaw's
10
- * declarative channel convention.
11
- *
12
- * @returns The ravi-sms channel definition object.
13
- */
14
- export function createSmsChannel() {
15
- return {
16
- id: "ravi-sms",
17
- meta: {
18
- id: "ravi-sms",
19
- label: "Ravi SMS",
20
- selectionLabel: "Ravi SMS (AI Agent Identity)",
21
- blurb: "SMS channel via Ravi identity provider. All messages from one phone number form a single agent session.",
22
- aliases: ["ravi-text"],
23
- },
24
- capabilities: {
25
- chatTypes: ["direct"],
26
- },
27
- config: {
28
- /**
29
- * List all configured account IDs (identity UUIDs) for the ravi-sms channel.
30
- *
31
- * Reads from the plugin config path first (set by `openclaw ravi login`),
32
- * then falls back to the standard `channels.ravi-sms.accounts` path.
33
- * Deduplicates when both sources contain the same UUID.
34
- *
35
- * @param cfg - The full OpenClaw gateway configuration object.
36
- * @returns Array of identity UUID strings.
37
- */
38
- listAccountIds: (cfg) => {
39
- // Primary: read from plugin config (set by `openclaw ravi login`)
40
- const plugins = cfg.plugins;
41
- const uuid = plugins?.entries?.ravi?.config?.identityUuid;
42
- // Fallback: standard channel accounts path
43
- const channels = cfg.channels;
44
- const channelIds = Object.keys(channels?.["ravi-sms"]?.accounts ?? {});
45
- // Deduplicate — plugin config uuid takes priority
46
- if (uuid) {
47
- return [uuid, ...channelIds.filter((id) => id !== uuid)];
48
- }
49
- return channelIds;
50
- },
51
- /**
52
- * Resolve an account configuration by its ID (identity UUID).
53
- *
54
- * Returns a minimal config with just the UUID if the account is not
55
- * found in the standard channels path. The gateway adapter will fetch
56
- * identity details at startup.
57
- *
58
- * @param cfg - The full OpenClaw gateway configuration object.
59
- * @param accountId - The identity UUID to look up.
60
- * @returns The resolved {@link SmsAccountConfig}.
61
- */
62
- resolveAccount: (cfg, accountId) => {
63
- const channels = cfg.channels;
64
- const found = channels?.["ravi-sms"]?.accounts?.[accountId];
65
- if (found)
66
- return found;
67
- // Fallback: return minimal config — gateway adapter fetches details at startup
68
- return {
69
- identityUuid: accountId,
70
- identityName: "",
71
- phone: "",
72
- };
73
- },
74
- },
75
- /**
76
- * Normalize an inbound SSE SMS event into a channel message envelope.
77
- *
78
- * Only owner events reach this channel — trust-level routing happens
79
- * at the SSE layer. No read-only or sender classification needed.
80
- *
81
- * @param event - The raw {@link SmsEvent} from the SSE stream.
82
- * @param account - The {@link SmsAccountConfig} for the receiving identity.
83
- * @returns A normalized {@link SmsInboundEnvelope}. Current implementation always returns non-null.
84
- */
85
- normalizeInbound(event, account) {
86
- return {
87
- senderId: event.from_number,
88
- text: event.body,
89
- threadId: event.from_number,
90
- metadata: {
91
- conversationId: event.conversation_id,
92
- },
93
- };
94
- },
95
- outbound: {
96
- deliveryMode: "direct",
97
- /**
98
- * Send an SMS reply to the phone number that triggered this session.
99
- *
100
- * Calls {@link RaviClient.sendSms} with the plain-text body (no HTML
101
- * wrapping, unlike the email channel).
102
- *
103
- * @param params.text - Plain-text message body.
104
- * @param params.client - An authenticated {@link RaviClient} instance.
105
- * @param params.threadContext - Thread context containing the recipient's phone number.
106
- * @returns A result object indicating success or failure.
107
- */
108
- sendText: async (params) => {
109
- const { text, client, threadContext } = params;
110
- if (!threadContext?.phoneNumber) {
111
- return {
112
- ok: false,
113
- error: "No SMS thread context — cannot send without a recipient phone number",
114
- };
115
- }
116
- try {
117
- await client.sendSms(threadContext.phoneNumber, text);
118
- return { ok: true };
119
- }
120
- catch (error) {
121
- const message = error instanceof Error ? error.message : "Unknown error";
122
- return { ok: false, error: `Failed to send SMS: ${message}` };
123
- }
124
- },
125
- },
126
- /**
127
- * Generate the session key for this channel.
128
- *
129
- * The key uniquely identifies a session by combining the agent, account,
130
- * and phone number. OpenClaw uses this to route inbound events to the
131
- * correct session and persist session state.
132
- *
133
- * For SMS, all messages from the same phone number share one session,
134
- * so `phoneNumber` is used as the conversation discriminator (unlike
135
- * email which uses `threadId`).
136
- *
137
- * Format: `agent:{agentId}:ravi-sms:{accountId}:dm:{phoneNumber}`
138
- *
139
- * @param agentId - The OpenClaw agent identifier.
140
- * @param accountId - The identity UUID (account ID).
141
- * @param phoneNumber - The other party's phone number (E.164 format).
142
- * @returns The deterministic session key string.
143
- */
144
- getSessionKey(agentId, accountId, phoneNumber) {
145
- return `agent:${agentId}:ravi-sms:${accountId}:dm:${phoneNumber}`;
146
- },
147
- // ─── Gateway Adapter ──────────────────────────────────────────────────
148
- gateway: {
149
- /**
150
- * Start monitoring inbound SMS for a single identity account.
151
- *
152
- * Called by the ChannelManager once per account. Opens an SSE stream
153
- * to the Ravi backend, dispatches inbound SMS through the OpenClaw
154
- * reply pipeline, and blocks until the abort signal fires.
155
- *
156
- * Bails out early if the identity has no phone number — SMS requires
157
- * a provisioned phone number.
158
- *
159
- * Only owner events reach this adapter — trust-level routing at the
160
- * SSE layer filters out non-owner senders before they arrive here.
161
- *
162
- * This gateway adapter is the ChannelManager-driven path, used when
163
- * OpenClaw manages channel lifecycles directly. The `normalizeInbound` +
164
- * `RaviListenerService` path in service.ts is the legacy self-managed
165
- * approach for environments where the gateway doesn't call startAccount.
166
- *
167
- * @param ctx - Gateway context provided by the ChannelManager.
168
- * @returns Promise that resolves when the account is stopped.
169
- */
170
- startAccount: async (ctx) => {
171
- const log = ctx.log ?? {
172
- info: (...args) => console.log("[ravi-sms]", ...args),
173
- warn: (...args) => console.warn("[ravi-sms]", ...args),
174
- error: (...args) => console.error("[ravi-sms]", ...args),
175
- };
176
- // Lazy imports — only loaded when the gateway actually starts an account.
177
- // This avoids pulling in runtime/auth/config/client/sse in test environments
178
- // where gateway.startAccount() is never called.
179
- let getRaviRuntime, loadAuth, updateAuth, RAVI_API_URL, RaviClient, acquireSSEClient, releaseSSEClient;
180
- try {
181
- ({ getRaviRuntime } = await import("../runtime.js"));
182
- ({ loadAuth, updateAuth } = await import("../auth.js"));
183
- ({ RAVI_API_URL } = await import("../config.js"));
184
- ({ RaviClient } = await import("../client.js"));
185
- ({ acquireSSEClient, releaseSSEClient } = await import("../sse-pool.js"));
186
- }
187
- catch (err) {
188
- const detail = err instanceof Error ? err.message : String(err);
189
- log.error(`[ravi-sms] Failed to load dependencies: ${detail}. Is the plugin built correctly?`);
190
- return;
191
- }
192
- const runtime = getRaviRuntime();
193
- const auth = loadAuth();
194
- if (!auth?.access_token) {
195
- log.error("[ravi-sms] No auth credentials — cannot start SMS channel. Run 'openclaw ravi login'.");
196
- return;
197
- }
198
- // Track the current token — onTokenRefresh updates this when the
199
- // REST client auto-refreshes on 401, so the SSE client (created after
200
- // the first REST call) gets the fresh token instead of the stale one.
201
- let currentToken = auth.access_token;
202
- let sse = null;
203
- // Build HTTP client for identity lookup + outbound replies
204
- const client = new RaviClient({
205
- apiUrl: RAVI_API_URL,
206
- token: auth.access_token,
207
- refreshToken: auth.refresh_token,
208
- identityUuid: ctx.accountId,
209
- onTokenRefresh: (newToken) => {
210
- currentToken = newToken;
211
- try {
212
- updateAuth({ access_token: newToken });
213
- }
214
- catch (err) {
215
- const detail = err instanceof Error ? err.message : String(err);
216
- log.error(`[ravi-sms] Failed to persist refreshed token: ${detail}`);
217
- }
218
- sse?.updateToken(newToken);
219
- },
220
- });
221
- // Fetch identity details (phone number, name) if not in config
222
- let phone = ctx.account.phone;
223
- let identityName = ctx.account.identityName;
224
- if (!phone) {
225
- try {
226
- const identities = await client.listIdentities();
227
- const identity = identities.find((i) => i.uuid === ctx.accountId);
228
- phone = identity?.phone ?? "";
229
- identityName = identity?.display_name ?? identity?.name ?? ctx.accountId;
230
- }
231
- catch (err) {
232
- if (err?.name === "RaviApiError") {
233
- const status = err.status;
234
- log.error(`[ravi-sms] Failed to fetch identity details (HTTP ${status}): ${err.message}` +
235
- (status === 401 ? ". Token may be expired — run 'openclaw ravi login'." : ""));
236
- }
237
- else {
238
- const detail = err instanceof Error ? err.message : String(err);
239
- log.error(`[ravi-sms] Failed to fetch identity details: ${detail}`);
240
- }
241
- return;
242
- }
243
- }
244
- // SMS requires a phone number — bail out if the identity doesn't have one
245
- if (!phone) {
246
- log.info(`[ravi-sms] Identity ${identityName} has no phone number — skipping SMS channel`);
247
- return;
248
- }
249
- log.info(`[ravi-sms] Starting SMS channel for ${identityName} (${phone})`);
250
- // Build SSE client using currentToken — which may have been refreshed
251
- // by the listIdentities() call above if the original token was expired.
252
- // onAuthFailure triggers a REST call to force auto-refresh, then returns
253
- // the updated currentToken (already set by onTokenRefresh callback).
254
- sse = acquireSSEClient({
255
- apiUrl: RAVI_API_URL,
256
- token: currentToken,
257
- identityUuid: ctx.accountId,
258
- onAuthFailure: async () => {
259
- const tokenBefore = currentToken;
260
- try {
261
- await client.listIdentities();
262
- }
263
- catch (err) {
264
- const detail = err instanceof Error ? err.message : String(err);
265
- log.error(`[ravi-sms] Auth refresh failed during SSE reconnect: ${detail}. Run 'openclaw ravi login' to re-authenticate.`);
266
- return null;
267
- }
268
- if (currentToken === tokenBefore) {
269
- log.warn(`[ravi-sms] Auth refresh did not produce a new token — SSE auth failure is not recoverable via REST refresh`);
270
- return null;
271
- }
272
- return currentToken;
273
- },
274
- });
275
- sse.onSmsOwner((event) => {
276
- try {
277
- // Resolve agent route — maps (channel, accountId) → agentId + session key
278
- const route = runtime.channel.routing.resolveAgentRoute({
279
- cfg: ctx.cfg,
280
- channel: "ravi-sms",
281
- accountId: ctx.accountId,
282
- peer: { kind: "direct", id: event.from_number },
283
- });
284
- const sessionKey = route.sessionKey;
285
- // Build MsgContext for dispatch
286
- const msgCtx = {
287
- Body: event.body,
288
- BodyForAgent: event.body,
289
- From: `ravi-sms:${event.from_number}`,
290
- To: `ravi-sms:${phone}`,
291
- SessionKey: sessionKey,
292
- AccountId: ctx.accountId,
293
- ChatType: "direct",
294
- Provider: "ravi-sms",
295
- Surface: "ravi-sms",
296
- OriginatingChannel: "ravi-sms",
297
- OriginatingTo: ctx.accountId,
298
- SenderName: event.from_number,
299
- SenderId: event.from_number,
300
- Timestamp: Date.now(),
301
- CommandAuthorized: true,
302
- MessageSid: `ravi-sms:${event.id}`,
303
- };
304
- // Record inbound session so follow-ups route back through SMS
305
- try {
306
- runtime.channel.session.recordInboundSession({
307
- storePath: runtime.channel.session.resolveStorePath(ctx.cfg.session?.store, { agentId: route.agentId }),
308
- sessionKey,
309
- ctx: msgCtx,
310
- updateLastRoute: {
311
- sessionKey,
312
- channel: "ravi-sms",
313
- to: ctx.accountId,
314
- accountId: ctx.accountId,
315
- phoneNumber: event.from_number,
316
- },
317
- onRecordError: (err) => {
318
- const detail = err instanceof Error ? err.message : String(err);
319
- log.error(`[ravi-sms] Session record error for ${event.from_number}: ${detail}`);
320
- },
321
- });
322
- }
323
- catch (err) {
324
- const detail = err instanceof Error ? err.message : String(err);
325
- log.error(`[ravi-sms] recordInboundSession threw for ${event.from_number}: ${detail}`);
326
- }
327
- // Dispatch — triggers AI agent turn. Owner always gets full reply delivery.
328
- runtime.channel.reply.dispatchReplyWithBufferedBlockDispatcher({
329
- ctx: msgCtx,
330
- cfg: ctx.cfg,
331
- dispatcherOptions: {
332
- deliver: async (payload) => {
333
- if (!payload.text) {
334
- log.info(`[ravi-sms] Deliver called with empty text for ${event.from_number} — skipping`);
335
- return;
336
- }
337
- try {
338
- await client.sendSms(event.from_number, payload.text);
339
- }
340
- catch (err) {
341
- const detail = err instanceof Error ? err.message : String(err);
342
- const status = err?.status;
343
- log.error(`[ravi-sms] Failed to deliver reply to ${event.from_number}` +
344
- `${status ? ` (HTTP ${status})` : ""}: ${detail}`);
345
- }
346
- },
347
- onError: (err) => {
348
- log.error(`[ravi-sms] Dispatch error: ${err}`);
349
- },
350
- },
351
- }).catch((err) => {
352
- const detail = err instanceof Error ? err.message : String(err);
353
- log.error(`[ravi-sms] dispatchReply failed for ${event.from_number}: ${detail}`);
354
- });
355
- }
356
- catch (err) {
357
- const detail = err instanceof Error ? err.message : String(err);
358
- log.error(`[ravi-sms] Unhandled error processing event ${event.id}: ${detail}`);
359
- }
360
- });
361
- sse.onReconnect(() => {
362
- log.info(`[ravi-sms] SSE reconnecting for ${identityName}`);
363
- });
364
- log.info(`[ravi-sms] SSE connected for ${identityName} (${ctx.accountId})`);
365
- // Block until gateway signals shutdown
366
- await new Promise((resolve) => {
367
- if (ctx.abortSignal.aborted) {
368
- log.info(`[ravi-sms] Stopping SMS channel for ${identityName} (already aborted)`);
369
- releaseSSEClient(ctx.accountId);
370
- resolve();
371
- return;
372
- }
373
- ctx.abortSignal.addEventListener("abort", () => {
374
- log.info(`[ravi-sms] Stopping SMS channel for ${identityName}`);
375
- releaseSSEClient(ctx.accountId);
376
- resolve();
377
- });
378
- });
379
- },
380
- },
381
- };
382
- }
383
- /** The singleton ravi-sms channel instance. */
384
- export const raviSmsChannel = createSmsChannel();
385
- //# sourceMappingURL=sms.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sms.js","sourceRoot":"","sources":["../../src/channels/sms.ts"],"names":[],"mappings":"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"}
package/dist/service.d.ts DELETED
@@ -1,107 +0,0 @@
1
- import { type EmailAccountConfig } from "./channels/email.js";
2
- import { type SmsAccountConfig } from "./channels/sms.js";
3
- /** Message envelope dispatched to the OpenClaw gateway. */
4
- export interface InboundMessage {
5
- /** Channel that produced this message. */
6
- channel: "ravi-email" | "ravi-email-trusted" | "ravi-email-untrusted" | "ravi-sms" | "ravi-sms-trusted" | "ravi-sms-untrusted";
7
- /** Identity UUID identifying the receiving account. */
8
- accountId: string;
9
- /** Sender identifier (email address or phone number). */
10
- senderId: string;
11
- /** Plain-text body of the inbound message. */
12
- text: string;
13
- /** Thread or conversation identifier for session mapping. */
14
- threadId: string;
15
- /** Deterministic session key used by the OpenClaw gateway. */
16
- sessionKey: string;
17
- /** Channel-specific metadata passed through to the agent. */
18
- metadata: Record<string, unknown>;
19
- /** When true, the agent should treat this as read-only context — no outbound replies or write tools. */
20
- readOnly: boolean;
21
- }
22
- /** Callback for dispatching normalized messages to the OpenClaw gateway. */
23
- export type MessageDispatcher = (message: InboundMessage) => void;
24
- /** Configuration for a single listener (one identity). */
25
- export interface ListenerConfig {
26
- /** Base URL of the Ravi API (e.g. "https://api.ravi.dev"). */
27
- apiUrl: string;
28
- /** JWT bearer token for authentication. */
29
- token: string;
30
- /** Identity UUID for scoped event streaming. */
31
- identityUuid: string;
32
- /** OpenClaw agent identifier used in session key generation. */
33
- agentId: string;
34
- /** Email account config; omit to skip email event handling. */
35
- emailAccount?: EmailAccountConfig;
36
- /** SMS account config; omit to skip SMS event handling. */
37
- smsAccount?: SmsAccountConfig;
38
- /** When false, emails from unknown senders are silently dropped. Defaults to true. */
39
- externalEmail?: boolean;
40
- }
41
- /**
42
- * Background service that manages SSE connections per identity.
43
- *
44
- * Creates one {@link RaviSSEClient} per configured identity, listens for
45
- * inbound email and SMS events, normalizes them through the respective
46
- * channel definitions, and dispatches the resulting {@link InboundMessage}
47
- * envelopes to the OpenClaw gateway via a {@link MessageDispatcher} callback.
48
- *
49
- * @example
50
- * ```ts
51
- * const service = new RaviListenerService((msg) => {
52
- * console.log(`[${msg.channel}] ${msg.senderId}: ${msg.text}`);
53
- * });
54
- *
55
- * service.addListener({
56
- * apiUrl: "https://api.ravi.dev",
57
- * token: "ey...",
58
- * identityUuid: "abc-123",
59
- * agentId: "my-agent",
60
- * emailAccount: { ... },
61
- * });
62
- *
63
- * // Later: graceful shutdown
64
- * service.stopAll();
65
- * ```
66
- */
67
- export declare class RaviListenerService {
68
- private clients;
69
- private dispatcher;
70
- constructor(dispatcher: MessageDispatcher);
71
- /**
72
- * Start listening for a configured identity.
73
- *
74
- * Creates an SSE client, wires up email and/or SMS handlers based on
75
- * the provided account configs, and opens the connection. If a listener
76
- * for this identity already exists, the call is a no-op.
77
- *
78
- * @param config - Listener configuration for the identity.
79
- */
80
- addListener(config: ListenerConfig): void;
81
- /**
82
- * Update the bearer token for all active SSE connections.
83
- *
84
- * Called when the RaviClient refreshes the access token so SSE
85
- * reconnections use the new token instead of the expired one.
86
- */
87
- updateToken(newToken: string): void;
88
- /**
89
- * Remove a listener for an identity.
90
- *
91
- * Disconnects the SSE client and removes it from the active set.
92
- * No-op if the identity is not being listened to.
93
- *
94
- * @param identityUuid - The identity UUID to stop listening for.
95
- */
96
- removeListener(identityUuid: string): void;
97
- /**
98
- * Stop all listeners.
99
- *
100
- * Disconnects every active SSE client and clears the internal map.
101
- * Safe to call multiple times.
102
- */
103
- stopAll(): void;
104
- /** Get the number of active listeners. */
105
- get activeCount(): number;
106
- }
107
- //# sourceMappingURL=service.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../src/service.ts"],"names":[],"mappings":"AACA,OAAO,EAAoB,KAAK,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAGhF,OAAO,EAAkB,KAAK,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAO1E,2DAA2D;AAC3D,MAAM,WAAW,cAAc;IAC7B,0CAA0C;IAC1C,OAAO,EAAE,YAAY,GAAG,oBAAoB,GAAG,sBAAsB,GAAG,UAAU,GAAG,kBAAkB,GAAG,oBAAoB,CAAC;IAC/H,uDAAuD;IACvD,SAAS,EAAE,MAAM,CAAC;IAClB,yDAAyD;IACzD,QAAQ,EAAE,MAAM,CAAC;IACjB,8CAA8C;IAC9C,IAAI,EAAE,MAAM,CAAC;IACb,6DAA6D;IAC7D,QAAQ,EAAE,MAAM,CAAC;IACjB,8DAA8D;IAC9D,UAAU,EAAE,MAAM,CAAC;IACnB,6DAA6D;IAC7D,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAClC,wGAAwG;IACxG,QAAQ,EAAE,OAAO,CAAC;CACnB;AAID,4EAA4E;AAC5E,MAAM,MAAM,iBAAiB,GAAG,CAAC,OAAO,EAAE,cAAc,KAAK,IAAI,CAAC;AAElE,0DAA0D;AAC1D,MAAM,WAAW,cAAc;IAC7B,8DAA8D;IAC9D,MAAM,EAAE,MAAM,CAAC;IACf,2CAA2C;IAC3C,KAAK,EAAE,MAAM,CAAC;IACd,gDAAgD;IAChD,YAAY,EAAE,MAAM,CAAC;IACrB,gEAAgE;IAChE,OAAO,EAAE,MAAM,CAAC;IAChB,+DAA+D;IAC/D,YAAY,CAAC,EAAE,kBAAkB,CAAC;IAClC,2DAA2D;IAC3D,UAAU,CAAC,EAAE,gBAAgB,CAAC;IAC9B,sFAAsF;IACtF,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB;AAID;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,OAAO,CAAyC;IACxD,OAAO,CAAC,UAAU,CAAoB;gBAE1B,UAAU,EAAE,iBAAiB;IAIzC;;;;;;;;OAQG;IACH,WAAW,CAAC,MAAM,EAAE,cAAc,GAAG,IAAI;IAuJzC;;;;;OAKG;IACH,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAMnC;;;;;;;OAOG;IACH,cAAc,CAAC,YAAY,EAAE,MAAM,GAAG,IAAI;IAQ1C;;;;;OAKG;IACH,OAAO,IAAI,IAAI;IAOf,0CAA0C;IAC1C,IAAI,WAAW,IAAI,MAAM,CAExB;CACF"}