@atribu/node 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 (46) hide show
  1. package/CHANGELOG.md +27 -0
  2. package/LICENSE +21 -0
  3. package/README.md +423 -0
  4. package/dist/admin/index.cjs +326 -0
  5. package/dist/admin/index.cjs.map +1 -0
  6. package/dist/admin/index.d.cts +46 -0
  7. package/dist/admin/index.d.ts +46 -0
  8. package/dist/admin/index.js +323 -0
  9. package/dist/admin/index.js.map +1 -0
  10. package/dist/api.d-BXINTQo6.d.cts +3547 -0
  11. package/dist/api.d-BXINTQo6.d.ts +3547 -0
  12. package/dist/errors-D3ApBz8J.d.cts +86 -0
  13. package/dist/errors-D3ApBz8J.d.ts +86 -0
  14. package/dist/index.cjs +549 -0
  15. package/dist/index.cjs.map +1 -0
  16. package/dist/index.d.cts +198 -0
  17. package/dist/index.d.ts +198 -0
  18. package/dist/index.js +536 -0
  19. package/dist/index.js.map +1 -0
  20. package/dist/next/index.cjs +153 -0
  21. package/dist/next/index.cjs.map +1 -0
  22. package/dist/next/index.d.cts +43 -0
  23. package/dist/next/index.d.ts +43 -0
  24. package/dist/next/index.js +151 -0
  25. package/dist/next/index.js.map +1 -0
  26. package/dist/oauth/index.cjs +299 -0
  27. package/dist/oauth/index.cjs.map +1 -0
  28. package/dist/oauth/index.d.cts +117 -0
  29. package/dist/oauth/index.d.ts +117 -0
  30. package/dist/oauth/index.js +291 -0
  31. package/dist/oauth/index.js.map +1 -0
  32. package/dist/test/index.cjs +443 -0
  33. package/dist/test/index.cjs.map +1 -0
  34. package/dist/test/index.d.cts +321 -0
  35. package/dist/test/index.d.ts +321 -0
  36. package/dist/test/index.js +437 -0
  37. package/dist/test/index.js.map +1 -0
  38. package/dist/types-Dc6tIN_V.d.cts +101 -0
  39. package/dist/types-Dc6tIN_V.d.ts +101 -0
  40. package/dist/webhooks/index.cjs +97 -0
  41. package/dist/webhooks/index.cjs.map +1 -0
  42. package/dist/webhooks/index.d.cts +35 -0
  43. package/dist/webhooks/index.d.ts +35 -0
  44. package/dist/webhooks/index.js +94 -0
  45. package/dist/webhooks/index.js.map +1 -0
  46. package/package.json +101 -0
@@ -0,0 +1,443 @@
1
+ 'use strict';
2
+
3
+ var msw = require('msw');
4
+
5
+ // src/test/handlers.ts
6
+
7
+ // src/test/fixtures.ts
8
+ function deepMerge(base, override) {
9
+ if (!override || typeof override !== "object") return base;
10
+ const out = { ...base };
11
+ for (const [k, v] of Object.entries(override)) {
12
+ const baseVal = base[k];
13
+ if (v && typeof v === "object" && !Array.isArray(v) && baseVal && typeof baseVal === "object" && !Array.isArray(baseVal)) {
14
+ out[k] = deepMerge(baseVal, v);
15
+ } else if (v !== void 0) {
16
+ out[k] = v;
17
+ }
18
+ }
19
+ return out;
20
+ }
21
+ var SAMPLE_APP_ID = "00000000-0000-0000-0000-000000000aaa";
22
+ var SAMPLE_CONNECTION_ID = "00000000-0000-0000-0000-000000000bbb";
23
+ var SAMPLE_PROFILE_ID = "00000000-0000-0000-0000-000000000ccc";
24
+ var SAMPLE_WORKSPACE_ID = "00000000-0000-0000-0000-000000000ddd";
25
+ var SAMPLE_SUBSCRIPTION_ID = "00000000-0000-0000-0000-000000000eee";
26
+ var sampleIds = {
27
+ appId: SAMPLE_APP_ID,
28
+ connectionId: SAMPLE_CONNECTION_ID,
29
+ profileId: SAMPLE_PROFILE_ID,
30
+ workspaceId: SAMPLE_WORKSPACE_ID,
31
+ subscriptionId: SAMPLE_SUBSCRIPTION_ID
32
+ };
33
+ var eventFixtures = {
34
+ whatsappMessageReceived(overrides) {
35
+ return deepMerge(
36
+ {
37
+ id: "evt_wa_received_01",
38
+ type: "message.received",
39
+ occurred_at: "2026-05-15T10:00:00Z",
40
+ app_id: SAMPLE_APP_ID,
41
+ provider: "whatsapp",
42
+ connection_id: SAMPLE_CONNECTION_ID,
43
+ data: {
44
+ wa_message_id: "wamid.HBgM",
45
+ from: "+15551234567",
46
+ to: "+15559876543",
47
+ contact_name: "Alice",
48
+ type: "text",
49
+ text: "Hi! Is this still available?",
50
+ raw: {}
51
+ }
52
+ },
53
+ overrides
54
+ );
55
+ },
56
+ whatsappMessageDelivery(overrides) {
57
+ return deepMerge(
58
+ {
59
+ id: "evt_wa_delivery_01",
60
+ type: "message.delivery",
61
+ occurred_at: "2026-05-15T10:00:01Z",
62
+ app_id: SAMPLE_APP_ID,
63
+ provider: "whatsapp",
64
+ connection_id: SAMPLE_CONNECTION_ID,
65
+ data: {
66
+ wa_message_id: "wamid.HBgM",
67
+ recipient_id: "15551234567",
68
+ status: "delivered",
69
+ raw: {}
70
+ }
71
+ },
72
+ overrides
73
+ );
74
+ },
75
+ instagramFbLoginMessage(overrides) {
76
+ return deepMerge(
77
+ {
78
+ id: "evt_ig_msg_01",
79
+ type: "message.received",
80
+ occurred_at: "2026-05-15T10:00:00Z",
81
+ app_id: SAMPLE_APP_ID,
82
+ provider: "instagram",
83
+ connection_id: SAMPLE_CONNECTION_ID,
84
+ data: {
85
+ sender_id: "17841400000000001",
86
+ recipient_id: "17841400000000002",
87
+ mid: "m_BNvxxxx",
88
+ text: "\u{1F44B}",
89
+ is_echo: false,
90
+ attachments: null,
91
+ referral: null,
92
+ raw: {}
93
+ }
94
+ },
95
+ overrides
96
+ );
97
+ },
98
+ instagramPostback(overrides) {
99
+ return deepMerge(
100
+ {
101
+ id: "evt_ig_pb_01",
102
+ type: "message.received",
103
+ occurred_at: "2026-05-15T10:00:00Z",
104
+ app_id: SAMPLE_APP_ID,
105
+ provider: "instagram",
106
+ connection_id: SAMPLE_CONNECTION_ID,
107
+ data: {
108
+ sender_id: "17841400000000001",
109
+ recipient_id: "17841400000000002",
110
+ kind: "postback",
111
+ title: "Get Started",
112
+ payload: "GET_STARTED",
113
+ raw: {}
114
+ }
115
+ },
116
+ overrides
117
+ );
118
+ },
119
+ instagramIgLoginChange(overrides) {
120
+ return deepMerge(
121
+ {
122
+ id: "evt_ig_change_01",
123
+ type: "message.received",
124
+ occurred_at: "2026-05-15T10:00:00Z",
125
+ app_id: SAMPLE_APP_ID,
126
+ provider: "instagram",
127
+ connection_id: SAMPLE_CONNECTION_ID,
128
+ data: {
129
+ sender_id: "17841400000000001",
130
+ recipient_id: "17841400000000002",
131
+ from_username: "alice.example",
132
+ mid: "m_BNvxxxx",
133
+ text: "Hello!",
134
+ raw: {}
135
+ }
136
+ },
137
+ overrides
138
+ );
139
+ },
140
+ instagramMessageDelivery(overrides) {
141
+ return deepMerge(
142
+ {
143
+ id: "evt_ig_delivery_01",
144
+ type: "message.delivery",
145
+ occurred_at: "2026-05-15T10:00:01Z",
146
+ app_id: SAMPLE_APP_ID,
147
+ provider: "instagram",
148
+ connection_id: SAMPLE_CONNECTION_ID,
149
+ data: {
150
+ sender_id: "17841400000000001",
151
+ recipient_id: "17841400000000002",
152
+ mids: ["m_BNvxxxx"],
153
+ watermark: 17157696e5
154
+ }
155
+ },
156
+ overrides
157
+ );
158
+ }
159
+ };
160
+ var responseFixtures = {
161
+ messageSent(overrides) {
162
+ return {
163
+ data: {
164
+ connection_id: SAMPLE_CONNECTION_ID,
165
+ channel: "whatsapp",
166
+ to: "+15551234567",
167
+ provider_message_id: overrides?.provider_message_id ?? "wamid.HBgM",
168
+ sent_at: overrides?.sent_at ?? (/* @__PURE__ */ new Date()).toISOString()
169
+ }
170
+ };
171
+ },
172
+ commentReply(overrides) {
173
+ return {
174
+ data: {
175
+ comment_id: "ig_comment_01",
176
+ kind: "private_reply",
177
+ connection_id: SAMPLE_CONNECTION_ID,
178
+ provider_message_id: overrides?.provider_message_id ?? "wamid.reply.x",
179
+ sent_at: (/* @__PURE__ */ new Date()).toISOString()
180
+ },
181
+ meta: { profile_id: SAMPLE_PROFILE_ID }
182
+ };
183
+ },
184
+ subscriptionCreated(overrides) {
185
+ return {
186
+ data: {
187
+ id: SAMPLE_SUBSCRIPTION_ID,
188
+ app_id: SAMPLE_APP_ID,
189
+ profile_id: SAMPLE_PROFILE_ID,
190
+ url: overrides?.url ?? "https://example.com/webhook",
191
+ events: ["message.received", "message.delivery"],
192
+ providers: ["whatsapp", "instagram"],
193
+ status: "active",
194
+ last_delivery_at: null,
195
+ consecutive_failures: 0,
196
+ previous_secret_expires_at: null,
197
+ created_at: (/* @__PURE__ */ new Date()).toISOString(),
198
+ updated_at: (/* @__PURE__ */ new Date()).toISOString(),
199
+ secret: overrides?.secret ?? "whsec_fixture_test_secret_value"
200
+ }
201
+ };
202
+ },
203
+ subscriptionList(overrides) {
204
+ const items = overrides?.items ?? 1;
205
+ return {
206
+ data: Array.from({ length: items }, (_, i) => ({
207
+ id: `00000000-0000-0000-0000-${String(i).padStart(12, "0")}`,
208
+ app_id: SAMPLE_APP_ID,
209
+ profile_id: SAMPLE_PROFILE_ID,
210
+ url: `https://example.com/webhook/${i}`,
211
+ events: ["message.received", "message.delivery"],
212
+ providers: ["whatsapp", "instagram"],
213
+ status: "active",
214
+ last_delivery_at: null,
215
+ consecutive_failures: 0,
216
+ previous_secret_expires_at: null,
217
+ created_at: (/* @__PURE__ */ new Date()).toISOString(),
218
+ updated_at: (/* @__PURE__ */ new Date()).toISOString()
219
+ })),
220
+ meta: { profile_id: SAMPLE_PROFILE_ID }
221
+ };
222
+ },
223
+ rotatedSecret(overrides) {
224
+ const graceDays = overrides?.graceDays ?? 7;
225
+ return {
226
+ data: {
227
+ subscription_id: SAMPLE_SUBSCRIPTION_ID,
228
+ secret: overrides?.secret ?? "whsec_rotated_test_secret",
229
+ grace_days: graceDays,
230
+ previous_secret_expires_at: new Date(
231
+ Date.now() + graceDays * 864e5
232
+ ).toISOString()
233
+ },
234
+ meta: { profile_id: SAMPLE_PROFILE_ID }
235
+ };
236
+ },
237
+ oauthTokenResponse(overrides) {
238
+ return {
239
+ access_token: overrides?.accessToken ?? "atb_live_test_fixture_key",
240
+ token_type: "bearer",
241
+ scope: overrides?.scope ?? "whatsapp",
242
+ connection_id: SAMPLE_CONNECTION_ID,
243
+ profile_id: SAMPLE_PROFILE_ID,
244
+ workspace_id: SAMPLE_WORKSPACE_ID
245
+ };
246
+ },
247
+ oauthError(error = "invalid_grant", description = "code expired") {
248
+ return { error, error_description: description };
249
+ },
250
+ apiError(code, message, status) {
251
+ return { error: { code, message, status, request_id: "req_fixture" } };
252
+ }
253
+ };
254
+ var fixtures = {
255
+ ids: sampleIds,
256
+ events: eventFixtures,
257
+ responses: responseFixtures
258
+ };
259
+
260
+ // src/test/handlers.ts
261
+ var DEFAULT_BASE_URL = "https://www.atribu.app";
262
+ function resolve(override, fallbackStatus, fallbackBody) {
263
+ const status = override?.status ?? fallbackStatus;
264
+ const body = override?.body ?? fallbackBody;
265
+ if (status === 204) return new msw.HttpResponse(null, { status: 204 });
266
+ return msw.HttpResponse.json(body, {
267
+ status,
268
+ headers: { "x-request-id": "req_mock" }
269
+ });
270
+ }
271
+ function atribuMockHandlers(overrides = {}) {
272
+ const baseUrl = (overrides.baseUrl ?? DEFAULT_BASE_URL).replace(/\/+$/, "");
273
+ const u = (p) => `${baseUrl}${p}`;
274
+ return [
275
+ // ----- Messaging -----
276
+ msw.http.post(
277
+ u("/api/v1/messages"),
278
+ () => resolve(overrides.messages?.send, 200, responseFixtures.messageSent())
279
+ ),
280
+ // ----- IG Comments -----
281
+ msw.http.post(
282
+ u("/api/v1/comments/:commentId/reply"),
283
+ () => resolve(overrides.comments?.reply, 200, responseFixtures.commentReply())
284
+ ),
285
+ msw.http.post(
286
+ u("/api/v1/comments/:commentId/private-reply"),
287
+ () => resolve(
288
+ overrides.comments?.privateReply,
289
+ 200,
290
+ responseFixtures.commentReply()
291
+ )
292
+ ),
293
+ // ----- Webhook subscriptions -----
294
+ msw.http.get(
295
+ u("/api/v1/webhooks/subscriptions"),
296
+ () => resolve(
297
+ overrides.webhooks?.subscriptions?.list,
298
+ 200,
299
+ responseFixtures.subscriptionList()
300
+ )
301
+ ),
302
+ msw.http.post(
303
+ u("/api/v1/webhooks/subscriptions"),
304
+ () => resolve(
305
+ overrides.webhooks?.subscriptions?.create,
306
+ 201,
307
+ responseFixtures.subscriptionCreated()
308
+ )
309
+ ),
310
+ msw.http.patch(
311
+ u("/api/v1/webhooks/subscriptions/:id"),
312
+ () => resolve(
313
+ overrides.webhooks?.subscriptions?.update,
314
+ 200,
315
+ responseFixtures.subscriptionList({ items: 1 })
316
+ )
317
+ ),
318
+ msw.http.delete(
319
+ u("/api/v1/webhooks/subscriptions/:id"),
320
+ () => resolve(overrides.webhooks?.subscriptions?.delete, 204, null)
321
+ ),
322
+ msw.http.post(
323
+ u("/api/v1/webhooks/subscriptions/:id/rotate-secret"),
324
+ () => resolve(
325
+ overrides.webhooks?.subscriptions?.rotateSecret,
326
+ 200,
327
+ responseFixtures.rotatedSecret()
328
+ )
329
+ ),
330
+ msw.http.post(
331
+ u("/api/v1/webhooks/test/:id"),
332
+ () => resolve(overrides.webhooks?.subscriptions?.test, 200, {
333
+ data: {
334
+ enqueued: true,
335
+ event_id: "00000000-0000-0000-0000-000000000fff",
336
+ subscription_id: "00000000-0000-0000-0000-000000000eee"
337
+ },
338
+ meta: { profile_id: "00000000-0000-0000-0000-000000000ccc" }
339
+ })
340
+ ),
341
+ // ----- Webhook deliveries -----
342
+ msw.http.post(
343
+ u("/api/v1/webhooks/deliveries/:id/replay"),
344
+ () => resolve(overrides.webhooks?.deliveries?.replay, 200, {
345
+ data: {
346
+ enqueued: true,
347
+ delivery_id: "00000000-0000-0000-0000-000000000fff",
348
+ event_id: "00000000-0000-0000-0000-000000000fff",
349
+ subscription_id: "00000000-0000-0000-0000-000000000eee"
350
+ },
351
+ meta: { profile_id: "00000000-0000-0000-0000-000000000ccc" }
352
+ })
353
+ ),
354
+ // ----- OAuth -----
355
+ msw.http.post(
356
+ u("/oauth/token"),
357
+ () => resolve(overrides.oauth?.token, 200, responseFixtures.oauthTokenResponse())
358
+ ),
359
+ msw.http.post(
360
+ u("/oauth/revoke"),
361
+ () => overrides.oauth?.revoke ? resolve(overrides.oauth.revoke, 200, null) : new msw.HttpResponse(null, { status: 200 })
362
+ ),
363
+ // ----- Admin -----
364
+ msw.http.post(
365
+ u("/api/v1/admin/oauth-apps"),
366
+ () => resolve(overrides.admin?.create, 201, {
367
+ data: {
368
+ id: "00000000-0000-0000-0000-000000000aaa",
369
+ client_id: "test-app",
370
+ name: "Test App",
371
+ description: null,
372
+ logo_url: null,
373
+ redirect_uris: ["https://example.com/cb"],
374
+ allowed_scopes: ["whatsapp"],
375
+ status: "active",
376
+ created_at: (/* @__PURE__ */ new Date()).toISOString(),
377
+ client_secret: "test_client_secret_shown_once",
378
+ jwt_signing_secret: "test_jwt_signing_secret_shown_once"
379
+ }
380
+ })
381
+ ),
382
+ msw.http.patch(
383
+ u("/api/v1/admin/oauth-apps/:id"),
384
+ () => resolve(overrides.admin?.update, 200, {
385
+ data: {
386
+ id: "00000000-0000-0000-0000-000000000aaa",
387
+ client_id: "test-app",
388
+ name: "Updated Name",
389
+ description: null,
390
+ logo_url: null,
391
+ redirect_uris: ["https://example.com/cb"],
392
+ allowed_scopes: ["whatsapp", "instagram"],
393
+ status: "active",
394
+ created_at: (/* @__PURE__ */ new Date()).toISOString()
395
+ }
396
+ })
397
+ ),
398
+ msw.http.delete(
399
+ u("/api/v1/admin/oauth-apps/:id"),
400
+ () => resolve(overrides.admin?.suspend, 200, {
401
+ data: {
402
+ id: "00000000-0000-0000-0000-000000000aaa",
403
+ status: "suspended",
404
+ keys_revoked: 0
405
+ }
406
+ })
407
+ ),
408
+ msw.http.post(
409
+ u("/api/v1/admin/oauth-apps/:id/rotate-client-secret"),
410
+ () => resolve(overrides.admin?.rotateClientSecret, 200, {
411
+ data: {
412
+ oauth_app_id: "00000000-0000-0000-0000-000000000aaa",
413
+ client_secret: "rotated_client_secret",
414
+ grace_days: 7,
415
+ previous_client_secret_expires_at: new Date(
416
+ Date.now() + 7 * 864e5
417
+ ).toISOString()
418
+ }
419
+ })
420
+ ),
421
+ msw.http.post(
422
+ u("/api/v1/admin/oauth-apps/:id/rotate-jwt-secret"),
423
+ () => resolve(overrides.admin?.rotateJwtSecret, 200, {
424
+ data: {
425
+ oauth_app_id: "00000000-0000-0000-0000-000000000aaa",
426
+ jwt_signing_secret: "rotated_jwt_secret",
427
+ grace_days: 7,
428
+ previous_jwt_signing_secret_expires_at: new Date(
429
+ Date.now() + 7 * 864e5
430
+ ).toISOString()
431
+ }
432
+ })
433
+ )
434
+ ];
435
+ }
436
+
437
+ exports.atribuMockHandlers = atribuMockHandlers;
438
+ exports.eventFixtures = eventFixtures;
439
+ exports.fixtures = fixtures;
440
+ exports.responseFixtures = responseFixtures;
441
+ exports.sampleIds = sampleIds;
442
+ //# sourceMappingURL=index.cjs.map
443
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/test/fixtures.ts","../../src/test/handlers.ts"],"names":["HttpResponse","http"],"mappings":"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","file":"index.cjs","sourcesContent":["/**\n * Canned fixtures for testing against the Atribu SDK.\n *\n * Use these to drive your test cases with realistic event shapes, or pass\n * `body` overrides into `atribuMockHandlers({...})` to customize responses.\n */\n\nimport type {\n AtribuWebhookEvent,\n WhatsAppMessageReceivedEvent,\n WhatsAppMessageDeliveryEvent,\n InstagramMessageReceivedEvent,\n InstagramMessageDeliveryEvent,\n} from \"../webhooks/types\";\n\ntype DeepPartial<T> = T extends object ? { [K in keyof T]?: DeepPartial<T[K]> } : T;\nfunction deepMerge<T>(base: T, override?: DeepPartial<T>): T {\n if (!override || typeof override !== \"object\") return base;\n const out: Record<string, unknown> = { ...(base as Record<string, unknown>) };\n for (const [k, v] of Object.entries(override as Record<string, unknown>)) {\n const baseVal = (base as Record<string, unknown>)[k];\n if (v && typeof v === \"object\" && !Array.isArray(v) && baseVal && typeof baseVal === \"object\" && !Array.isArray(baseVal)) {\n out[k] = deepMerge(baseVal, v as DeepPartial<typeof baseVal>);\n } else if (v !== undefined) {\n out[k] = v;\n }\n }\n return out as T;\n}\n\nconst SAMPLE_APP_ID = \"00000000-0000-0000-0000-000000000aaa\";\nconst SAMPLE_CONNECTION_ID = \"00000000-0000-0000-0000-000000000bbb\";\nconst SAMPLE_PROFILE_ID = \"00000000-0000-0000-0000-000000000ccc\";\nconst SAMPLE_WORKSPACE_ID = \"00000000-0000-0000-0000-000000000ddd\";\nconst SAMPLE_SUBSCRIPTION_ID = \"00000000-0000-0000-0000-000000000eee\";\n\nexport const sampleIds = {\n appId: SAMPLE_APP_ID,\n connectionId: SAMPLE_CONNECTION_ID,\n profileId: SAMPLE_PROFILE_ID,\n workspaceId: SAMPLE_WORKSPACE_ID,\n subscriptionId: SAMPLE_SUBSCRIPTION_ID,\n} as const;\n\n/** Canned webhook event fixtures — deep-merge any field you care about. */\nexport const eventFixtures = {\n whatsappMessageReceived(\n overrides?: DeepPartial<WhatsAppMessageReceivedEvent>,\n ): WhatsAppMessageReceivedEvent {\n return deepMerge<WhatsAppMessageReceivedEvent>(\n {\n id: \"evt_wa_received_01\",\n type: \"message.received\",\n occurred_at: \"2026-05-15T10:00:00Z\",\n app_id: SAMPLE_APP_ID,\n provider: \"whatsapp\",\n connection_id: SAMPLE_CONNECTION_ID,\n data: {\n wa_message_id: \"wamid.HBgM\",\n from: \"+15551234567\",\n to: \"+15559876543\",\n contact_name: \"Alice\",\n type: \"text\",\n text: \"Hi! Is this still available?\",\n raw: {},\n },\n },\n overrides,\n );\n },\n\n whatsappMessageDelivery(\n overrides?: DeepPartial<WhatsAppMessageDeliveryEvent>,\n ): WhatsAppMessageDeliveryEvent {\n return deepMerge<WhatsAppMessageDeliveryEvent>(\n {\n id: \"evt_wa_delivery_01\",\n type: \"message.delivery\",\n occurred_at: \"2026-05-15T10:00:01Z\",\n app_id: SAMPLE_APP_ID,\n provider: \"whatsapp\",\n connection_id: SAMPLE_CONNECTION_ID,\n data: {\n wa_message_id: \"wamid.HBgM\",\n recipient_id: \"15551234567\",\n status: \"delivered\",\n raw: {},\n },\n },\n overrides,\n );\n },\n\n instagramFbLoginMessage(\n overrides?: DeepPartial<InstagramMessageReceivedEvent>,\n ): InstagramMessageReceivedEvent {\n return deepMerge<InstagramMessageReceivedEvent>(\n {\n id: \"evt_ig_msg_01\",\n type: \"message.received\",\n occurred_at: \"2026-05-15T10:00:00Z\",\n app_id: SAMPLE_APP_ID,\n provider: \"instagram\",\n connection_id: SAMPLE_CONNECTION_ID,\n data: {\n sender_id: \"17841400000000001\",\n recipient_id: \"17841400000000002\",\n mid: \"m_BNvxxxx\",\n text: \"👋\",\n is_echo: false,\n attachments: null,\n referral: null,\n raw: {},\n },\n },\n overrides,\n );\n },\n\n instagramPostback(\n overrides?: DeepPartial<InstagramMessageReceivedEvent>,\n ): InstagramMessageReceivedEvent {\n return deepMerge<InstagramMessageReceivedEvent>(\n {\n id: \"evt_ig_pb_01\",\n type: \"message.received\",\n occurred_at: \"2026-05-15T10:00:00Z\",\n app_id: SAMPLE_APP_ID,\n provider: \"instagram\",\n connection_id: SAMPLE_CONNECTION_ID,\n data: {\n sender_id: \"17841400000000001\",\n recipient_id: \"17841400000000002\",\n kind: \"postback\",\n title: \"Get Started\",\n payload: \"GET_STARTED\",\n raw: {},\n },\n },\n overrides,\n );\n },\n\n instagramIgLoginChange(\n overrides?: DeepPartial<InstagramMessageReceivedEvent>,\n ): InstagramMessageReceivedEvent {\n return deepMerge<InstagramMessageReceivedEvent>(\n {\n id: \"evt_ig_change_01\",\n type: \"message.received\",\n occurred_at: \"2026-05-15T10:00:00Z\",\n app_id: SAMPLE_APP_ID,\n provider: \"instagram\",\n connection_id: SAMPLE_CONNECTION_ID,\n data: {\n sender_id: \"17841400000000001\",\n recipient_id: \"17841400000000002\",\n from_username: \"alice.example\",\n mid: \"m_BNvxxxx\",\n text: \"Hello!\",\n raw: {},\n },\n },\n overrides,\n );\n },\n\n instagramMessageDelivery(\n overrides?: DeepPartial<InstagramMessageDeliveryEvent>,\n ): InstagramMessageDeliveryEvent {\n return deepMerge<InstagramMessageDeliveryEvent>(\n {\n id: \"evt_ig_delivery_01\",\n type: \"message.delivery\",\n occurred_at: \"2026-05-15T10:00:01Z\",\n app_id: SAMPLE_APP_ID,\n provider: \"instagram\",\n connection_id: SAMPLE_CONNECTION_ID,\n data: {\n sender_id: \"17841400000000001\",\n recipient_id: \"17841400000000002\",\n mids: [\"m_BNvxxxx\"],\n watermark: 1715769600000,\n },\n },\n overrides,\n );\n },\n};\n\n/** Canned API response envelopes (matches what the server returns on 200). */\nexport const responseFixtures = {\n messageSent(overrides?: { provider_message_id?: string; sent_at?: string }) {\n return {\n data: {\n connection_id: SAMPLE_CONNECTION_ID,\n channel: \"whatsapp\" as const,\n to: \"+15551234567\",\n provider_message_id: overrides?.provider_message_id ?? \"wamid.HBgM\",\n sent_at: overrides?.sent_at ?? new Date().toISOString(),\n },\n };\n },\n\n commentReply(overrides?: { provider_message_id?: string }) {\n return {\n data: {\n comment_id: \"ig_comment_01\",\n kind: \"private_reply\" as const,\n connection_id: SAMPLE_CONNECTION_ID,\n provider_message_id: overrides?.provider_message_id ?? \"wamid.reply.x\",\n sent_at: new Date().toISOString(),\n },\n meta: { profile_id: SAMPLE_PROFILE_ID },\n };\n },\n\n subscriptionCreated(overrides?: { secret?: string; url?: string }) {\n return {\n data: {\n id: SAMPLE_SUBSCRIPTION_ID,\n app_id: SAMPLE_APP_ID,\n profile_id: SAMPLE_PROFILE_ID,\n url: overrides?.url ?? \"https://example.com/webhook\",\n events: [\"message.received\", \"message.delivery\"],\n providers: [\"whatsapp\", \"instagram\"],\n status: \"active\" as const,\n last_delivery_at: null,\n consecutive_failures: 0,\n previous_secret_expires_at: null,\n created_at: new Date().toISOString(),\n updated_at: new Date().toISOString(),\n secret: overrides?.secret ?? \"whsec_fixture_test_secret_value\",\n },\n };\n },\n\n subscriptionList(overrides?: { items?: number }) {\n const items = overrides?.items ?? 1;\n return {\n data: Array.from({ length: items }, (_, i) => ({\n id: `00000000-0000-0000-0000-${String(i).padStart(12, \"0\")}`,\n app_id: SAMPLE_APP_ID,\n profile_id: SAMPLE_PROFILE_ID,\n url: `https://example.com/webhook/${i}`,\n events: [\"message.received\", \"message.delivery\"],\n providers: [\"whatsapp\", \"instagram\"],\n status: \"active\" as const,\n last_delivery_at: null,\n consecutive_failures: 0,\n previous_secret_expires_at: null,\n created_at: new Date().toISOString(),\n updated_at: new Date().toISOString(),\n })),\n meta: { profile_id: SAMPLE_PROFILE_ID },\n };\n },\n\n rotatedSecret(overrides?: { secret?: string; graceDays?: number }) {\n const graceDays = overrides?.graceDays ?? 7;\n return {\n data: {\n subscription_id: SAMPLE_SUBSCRIPTION_ID,\n secret: overrides?.secret ?? \"whsec_rotated_test_secret\",\n grace_days: graceDays,\n previous_secret_expires_at: new Date(\n Date.now() + graceDays * 86400_000,\n ).toISOString(),\n },\n meta: { profile_id: SAMPLE_PROFILE_ID },\n };\n },\n\n oauthTokenResponse(overrides?: { accessToken?: string; scope?: string }) {\n return {\n access_token: overrides?.accessToken ?? \"atb_live_test_fixture_key\",\n token_type: \"bearer\" as const,\n scope: overrides?.scope ?? \"whatsapp\",\n connection_id: SAMPLE_CONNECTION_ID,\n profile_id: SAMPLE_PROFILE_ID,\n workspace_id: SAMPLE_WORKSPACE_ID,\n };\n },\n\n oauthError(error = \"invalid_grant\", description = \"code expired\") {\n return { error, error_description: description };\n },\n\n apiError(code: string, message: string, status: number) {\n return { error: { code, message, status, request_id: \"req_fixture\" } };\n },\n};\n\n/** Combined export so consumers can `import { fixtures } from \"@atribu/sdk/test\"`. */\nexport const fixtures = {\n ids: sampleIds,\n events: eventFixtures,\n responses: responseFixtures,\n};\n\nexport type FixtureWebhookEvent = AtribuWebhookEvent;\n","/**\n * Drop-in MSW v2 handlers for testing against `@atribu/sdk`.\n *\n * Consumers add these to their MSW server setup:\n *\n * import { setupServer } from \"msw/node\";\n * import { atribuMockHandlers } from \"@atribu/sdk/test\";\n *\n * const server = setupServer(...atribuMockHandlers());\n *\n * Per-endpoint defaults reflect the wire shape the real Atribu API returns.\n * Override any response by passing `MockOverrides` — the handler returns\n * the override directly if `body` is provided; otherwise the default\n * envelope from `responseFixtures`.\n *\n * MSW v2 is a peer dependency. Consumers must install it.\n */\n\nimport { http, HttpResponse, type HttpHandler } from \"msw\";\nimport { responseFixtures } from \"./fixtures\";\n\ninterface EndpointOverride {\n status?: number;\n body?: unknown;\n}\n\nexport interface MockOverrides {\n baseUrl?: string;\n messages?: { send?: EndpointOverride };\n comments?: {\n reply?: EndpointOverride;\n privateReply?: EndpointOverride;\n };\n webhooks?: {\n subscriptions?: {\n list?: EndpointOverride;\n create?: EndpointOverride;\n update?: EndpointOverride;\n delete?: EndpointOverride;\n rotateSecret?: EndpointOverride;\n test?: EndpointOverride;\n };\n deliveries?: {\n replay?: EndpointOverride;\n };\n };\n oauth?: {\n token?: EndpointOverride;\n revoke?: EndpointOverride;\n };\n admin?: {\n create?: EndpointOverride;\n update?: EndpointOverride;\n suspend?: EndpointOverride;\n rotateClientSecret?: EndpointOverride;\n rotateJwtSecret?: EndpointOverride;\n };\n}\n\nconst DEFAULT_BASE_URL = \"https://www.atribu.app\";\n\nfunction resolve(\n override: EndpointOverride | undefined,\n fallbackStatus: number,\n fallbackBody: unknown,\n): Response {\n const status = override?.status ?? fallbackStatus;\n const body = override?.body ?? fallbackBody;\n if (status === 204) return new HttpResponse(null, { status: 204 });\n return HttpResponse.json(body as Record<string, unknown> | unknown[] | null, {\n status,\n headers: { \"x-request-id\": \"req_mock\" },\n });\n}\n\nexport function atribuMockHandlers(overrides: MockOverrides = {}): HttpHandler[] {\n const baseUrl = (overrides.baseUrl ?? DEFAULT_BASE_URL).replace(/\\/+$/, \"\");\n const u = (p: string): string => `${baseUrl}${p}`;\n\n return [\n // ----- Messaging -----\n http.post(u(\"/api/v1/messages\"), () =>\n resolve(overrides.messages?.send, 200, responseFixtures.messageSent()),\n ),\n\n // ----- IG Comments -----\n http.post(u(\"/api/v1/comments/:commentId/reply\"), () =>\n resolve(overrides.comments?.reply, 200, responseFixtures.commentReply()),\n ),\n http.post(u(\"/api/v1/comments/:commentId/private-reply\"), () =>\n resolve(\n overrides.comments?.privateReply,\n 200,\n responseFixtures.commentReply(),\n ),\n ),\n\n // ----- Webhook subscriptions -----\n http.get(u(\"/api/v1/webhooks/subscriptions\"), () =>\n resolve(\n overrides.webhooks?.subscriptions?.list,\n 200,\n responseFixtures.subscriptionList(),\n ),\n ),\n http.post(u(\"/api/v1/webhooks/subscriptions\"), () =>\n resolve(\n overrides.webhooks?.subscriptions?.create,\n 201,\n responseFixtures.subscriptionCreated(),\n ),\n ),\n http.patch(u(\"/api/v1/webhooks/subscriptions/:id\"), () =>\n resolve(\n overrides.webhooks?.subscriptions?.update,\n 200,\n responseFixtures.subscriptionList({ items: 1 }),\n ),\n ),\n http.delete(u(\"/api/v1/webhooks/subscriptions/:id\"), () =>\n resolve(overrides.webhooks?.subscriptions?.delete, 204, null),\n ),\n http.post(u(\"/api/v1/webhooks/subscriptions/:id/rotate-secret\"), () =>\n resolve(\n overrides.webhooks?.subscriptions?.rotateSecret,\n 200,\n responseFixtures.rotatedSecret(),\n ),\n ),\n http.post(u(\"/api/v1/webhooks/test/:id\"), () =>\n resolve(overrides.webhooks?.subscriptions?.test, 200, {\n data: {\n enqueued: true,\n event_id: \"00000000-0000-0000-0000-000000000fff\",\n subscription_id: \"00000000-0000-0000-0000-000000000eee\",\n },\n meta: { profile_id: \"00000000-0000-0000-0000-000000000ccc\" },\n }),\n ),\n\n // ----- Webhook deliveries -----\n http.post(u(\"/api/v1/webhooks/deliveries/:id/replay\"), () =>\n resolve(overrides.webhooks?.deliveries?.replay, 200, {\n data: {\n enqueued: true,\n delivery_id: \"00000000-0000-0000-0000-000000000fff\",\n event_id: \"00000000-0000-0000-0000-000000000fff\",\n subscription_id: \"00000000-0000-0000-0000-000000000eee\",\n },\n meta: { profile_id: \"00000000-0000-0000-0000-000000000ccc\" },\n }),\n ),\n\n // ----- OAuth -----\n http.post(u(\"/oauth/token\"), () =>\n resolve(overrides.oauth?.token, 200, responseFixtures.oauthTokenResponse()),\n ),\n http.post(u(\"/oauth/revoke\"), () =>\n overrides.oauth?.revoke\n ? resolve(overrides.oauth.revoke, 200, null)\n : new HttpResponse(null, { status: 200 }),\n ),\n\n // ----- Admin -----\n http.post(u(\"/api/v1/admin/oauth-apps\"), () =>\n resolve(overrides.admin?.create, 201, {\n data: {\n id: \"00000000-0000-0000-0000-000000000aaa\",\n client_id: \"test-app\",\n name: \"Test App\",\n description: null,\n logo_url: null,\n redirect_uris: [\"https://example.com/cb\"],\n allowed_scopes: [\"whatsapp\"],\n status: \"active\",\n created_at: new Date().toISOString(),\n client_secret: \"test_client_secret_shown_once\",\n jwt_signing_secret: \"test_jwt_signing_secret_shown_once\",\n },\n }),\n ),\n http.patch(u(\"/api/v1/admin/oauth-apps/:id\"), () =>\n resolve(overrides.admin?.update, 200, {\n data: {\n id: \"00000000-0000-0000-0000-000000000aaa\",\n client_id: \"test-app\",\n name: \"Updated Name\",\n description: null,\n logo_url: null,\n redirect_uris: [\"https://example.com/cb\"],\n allowed_scopes: [\"whatsapp\", \"instagram\"],\n status: \"active\",\n created_at: new Date().toISOString(),\n },\n }),\n ),\n http.delete(u(\"/api/v1/admin/oauth-apps/:id\"), () =>\n resolve(overrides.admin?.suspend, 200, {\n data: {\n id: \"00000000-0000-0000-0000-000000000aaa\",\n status: \"suspended\",\n keys_revoked: 0,\n },\n }),\n ),\n http.post(u(\"/api/v1/admin/oauth-apps/:id/rotate-client-secret\"), () =>\n resolve(overrides.admin?.rotateClientSecret, 200, {\n data: {\n oauth_app_id: \"00000000-0000-0000-0000-000000000aaa\",\n client_secret: \"rotated_client_secret\",\n grace_days: 7,\n previous_client_secret_expires_at: new Date(\n Date.now() + 7 * 86400_000,\n ).toISOString(),\n },\n }),\n ),\n http.post(u(\"/api/v1/admin/oauth-apps/:id/rotate-jwt-secret\"), () =>\n resolve(overrides.admin?.rotateJwtSecret, 200, {\n data: {\n oauth_app_id: \"00000000-0000-0000-0000-000000000aaa\",\n jwt_signing_secret: \"rotated_jwt_secret\",\n grace_days: 7,\n previous_jwt_signing_secret_expires_at: new Date(\n Date.now() + 7 * 86400_000,\n ).toISOString(),\n },\n }),\n ),\n ];\n}\n"]}