wuzapi 1.0.1 → 1.2.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.
@@ -0,0 +1,16 @@
1
+ import { AxiosInstance } from 'axios';
2
+ import { WuzapiConfig } from './types/common.js';
3
+ export declare class WuzapiError extends Error {
4
+ code: number;
5
+ details?: unknown;
6
+ constructor(code: number, message: string, details?: unknown);
7
+ }
8
+ export declare class BaseClient {
9
+ protected axios: AxiosInstance;
10
+ protected config: WuzapiConfig;
11
+ constructor(config: WuzapiConfig);
12
+ protected request<T>(method: "GET" | "POST" | "DELETE", endpoint: string, data?: unknown): Promise<T>;
13
+ protected get<T>(endpoint: string): Promise<T>;
14
+ protected post<T>(endpoint: string, data?: unknown): Promise<T>;
15
+ protected delete<T>(endpoint: string): Promise<T>;
16
+ }
@@ -0,0 +1,10 @@
1
+ export { WuzapiClient } from './wuzapi-client.js';
2
+ export { WuzapiError } from './client.js';
3
+ export * from './types/index.js';
4
+ export { AdminModule } from './modules/admin.js';
5
+ export { SessionModule } from './modules/session.js';
6
+ export { UserModule } from './modules/user.js';
7
+ export { ChatModule } from './modules/chat.js';
8
+ export { GroupModule } from './modules/group.js';
9
+ export { WebhookModule } from './modules/webhook.js';
10
+ export { WuzapiClient as default } from './wuzapi-client.js';
package/dist/index.js CHANGED
@@ -378,15 +378,322 @@ class WuzapiClient {
378
378
  }
379
379
  }
380
380
  }
381
+ var DisappearingModeInitiator = /* @__PURE__ */ ((DisappearingModeInitiator2) => {
382
+ DisappearingModeInitiator2[DisappearingModeInitiator2["CHANGED_IN_CHAT"] = 0] = "CHANGED_IN_CHAT";
383
+ DisappearingModeInitiator2[DisappearingModeInitiator2["INITIATED_BY_ME"] = 1] = "INITIATED_BY_ME";
384
+ DisappearingModeInitiator2[DisappearingModeInitiator2["INITIATED_BY_OTHER"] = 2] = "INITIATED_BY_OTHER";
385
+ return DisappearingModeInitiator2;
386
+ })(DisappearingModeInitiator || {});
387
+ var DisappearingModeTrigger = /* @__PURE__ */ ((DisappearingModeTrigger2) => {
388
+ DisappearingModeTrigger2[DisappearingModeTrigger2["UNKNOWN"] = 0] = "UNKNOWN";
389
+ DisappearingModeTrigger2[DisappearingModeTrigger2["CHAT_SETTING"] = 1] = "CHAT_SETTING";
390
+ DisappearingModeTrigger2[DisappearingModeTrigger2["ACCOUNT_SETTING"] = 2] = "ACCOUNT_SETTING";
391
+ DisappearingModeTrigger2[DisappearingModeTrigger2["BULK_CHANGE"] = 3] = "BULK_CHANGE";
392
+ return DisappearingModeTrigger2;
393
+ })(DisappearingModeTrigger || {});
394
+ var MediaType = /* @__PURE__ */ ((MediaType2) => {
395
+ MediaType2[MediaType2["UNKNOWN"] = 0] = "UNKNOWN";
396
+ MediaType2[MediaType2["IMAGE"] = 1] = "IMAGE";
397
+ MediaType2[MediaType2["VIDEO"] = 2] = "VIDEO";
398
+ MediaType2[MediaType2["AUDIO"] = 3] = "AUDIO";
399
+ MediaType2[MediaType2["DOCUMENT"] = 4] = "DOCUMENT";
400
+ MediaType2[MediaType2["STICKER"] = 5] = "STICKER";
401
+ return MediaType2;
402
+ })(MediaType || {});
403
+ var VideoAttribution = /* @__PURE__ */ ((VideoAttribution2) => {
404
+ VideoAttribution2[VideoAttribution2["NONE"] = 0] = "NONE";
405
+ VideoAttribution2[VideoAttribution2["GIPHY"] = 1] = "GIPHY";
406
+ VideoAttribution2[VideoAttribution2["TENOR"] = 2] = "TENOR";
407
+ VideoAttribution2[VideoAttribution2["KLIPY"] = 3] = "KLIPY";
408
+ return VideoAttribution2;
409
+ })(VideoAttribution || {});
410
+ var VideoSourceType = /* @__PURE__ */ ((VideoSourceType2) => {
411
+ VideoSourceType2[VideoSourceType2["USER_VIDEO"] = 0] = "USER_VIDEO";
412
+ VideoSourceType2[VideoSourceType2["AI_GENERATED"] = 1] = "AI_GENERATED";
413
+ return VideoSourceType2;
414
+ })(VideoSourceType || {});
415
+ var ExtendedTextMessageFontType = /* @__PURE__ */ ((ExtendedTextMessageFontType2) => {
416
+ ExtendedTextMessageFontType2[ExtendedTextMessageFontType2["SANS_SERIF"] = 0] = "SANS_SERIF";
417
+ ExtendedTextMessageFontType2[ExtendedTextMessageFontType2["SERIF"] = 1] = "SERIF";
418
+ ExtendedTextMessageFontType2[ExtendedTextMessageFontType2["NORICAN_REGULAR"] = 2] = "NORICAN_REGULAR";
419
+ ExtendedTextMessageFontType2[ExtendedTextMessageFontType2["BRYNDAN_WRITE"] = 3] = "BRYNDAN_WRITE";
420
+ ExtendedTextMessageFontType2[ExtendedTextMessageFontType2["BEBASNEUE_REGULAR"] = 4] = "BEBASNEUE_REGULAR";
421
+ ExtendedTextMessageFontType2[ExtendedTextMessageFontType2["OSWALD_HEAVY"] = 5] = "OSWALD_HEAVY";
422
+ return ExtendedTextMessageFontType2;
423
+ })(ExtendedTextMessageFontType || {});
424
+ var ExtendedTextMessagePreviewType = /* @__PURE__ */ ((ExtendedTextMessagePreviewType2) => {
425
+ ExtendedTextMessagePreviewType2[ExtendedTextMessagePreviewType2["NONE"] = 0] = "NONE";
426
+ ExtendedTextMessagePreviewType2[ExtendedTextMessagePreviewType2["VIDEO"] = 1] = "VIDEO";
427
+ ExtendedTextMessagePreviewType2[ExtendedTextMessagePreviewType2["PLACEHOLDER"] = 4] = "PLACEHOLDER";
428
+ ExtendedTextMessagePreviewType2[ExtendedTextMessagePreviewType2["IMAGE"] = 5] = "IMAGE";
429
+ return ExtendedTextMessagePreviewType2;
430
+ })(ExtendedTextMessagePreviewType || {});
431
+ var ExtendedTextMessageInviteLinkGroupType = /* @__PURE__ */ ((ExtendedTextMessageInviteLinkGroupType2) => {
432
+ ExtendedTextMessageInviteLinkGroupType2[ExtendedTextMessageInviteLinkGroupType2["DEFAULT"] = 0] = "DEFAULT";
433
+ ExtendedTextMessageInviteLinkGroupType2[ExtendedTextMessageInviteLinkGroupType2["PARENT"] = 1] = "PARENT";
434
+ ExtendedTextMessageInviteLinkGroupType2[ExtendedTextMessageInviteLinkGroupType2["SUB"] = 2] = "SUB";
435
+ ExtendedTextMessageInviteLinkGroupType2[ExtendedTextMessageInviteLinkGroupType2["DEFAULT_SUB"] = 3] = "DEFAULT_SUB";
436
+ return ExtendedTextMessageInviteLinkGroupType2;
437
+ })(ExtendedTextMessageInviteLinkGroupType || {});
438
+ var InviteLinkGroupType = /* @__PURE__ */ ((InviteLinkGroupType2) => {
439
+ InviteLinkGroupType2[InviteLinkGroupType2["DEFAULT"] = 0] = "DEFAULT";
440
+ InviteLinkGroupType2[InviteLinkGroupType2["PARENT"] = 1] = "PARENT";
441
+ InviteLinkGroupType2[InviteLinkGroupType2["SUB"] = 2] = "SUB";
442
+ InviteLinkGroupType2[InviteLinkGroupType2["DEFAULT_SUB"] = 3] = "DEFAULT_SUB";
443
+ return InviteLinkGroupType2;
444
+ })(InviteLinkGroupType || {});
445
+ var ButtonType = /* @__PURE__ */ ((ButtonType2) => {
446
+ ButtonType2[ButtonType2["UNKNOWN"] = 0] = "UNKNOWN";
447
+ ButtonType2[ButtonType2["RESPONSE"] = 1] = "RESPONSE";
448
+ ButtonType2[ButtonType2["NATIVE_FLOW"] = 2] = "NATIVE_FLOW";
449
+ return ButtonType2;
450
+ })(ButtonType || {});
451
+ var ButtonsMessageHeaderType = /* @__PURE__ */ ((ButtonsMessageHeaderType2) => {
452
+ ButtonsMessageHeaderType2[ButtonsMessageHeaderType2["UNKNOWN"] = 0] = "UNKNOWN";
453
+ ButtonsMessageHeaderType2[ButtonsMessageHeaderType2["EMPTY"] = 1] = "EMPTY";
454
+ ButtonsMessageHeaderType2[ButtonsMessageHeaderType2["TEXT"] = 2] = "TEXT";
455
+ ButtonsMessageHeaderType2[ButtonsMessageHeaderType2["DOCUMENT"] = 3] = "DOCUMENT";
456
+ ButtonsMessageHeaderType2[ButtonsMessageHeaderType2["IMAGE"] = 4] = "IMAGE";
457
+ ButtonsMessageHeaderType2[ButtonsMessageHeaderType2["VIDEO"] = 5] = "VIDEO";
458
+ ButtonsMessageHeaderType2[ButtonsMessageHeaderType2["LOCATION"] = 6] = "LOCATION";
459
+ return ButtonsMessageHeaderType2;
460
+ })(ButtonsMessageHeaderType || {});
461
+ var ListMessageListType = /* @__PURE__ */ ((ListMessageListType2) => {
462
+ ListMessageListType2[ListMessageListType2["UNKNOWN"] = 0] = "UNKNOWN";
463
+ ListMessageListType2[ListMessageListType2["SINGLE_SELECT"] = 1] = "SINGLE_SELECT";
464
+ ListMessageListType2[ListMessageListType2["PRODUCT_LIST"] = 2] = "PRODUCT_LIST";
465
+ return ListMessageListType2;
466
+ })(ListMessageListType || {});
467
+ var ButtonsResponseMessageType = /* @__PURE__ */ ((ButtonsResponseMessageType2) => {
468
+ ButtonsResponseMessageType2[ButtonsResponseMessageType2["UNKNOWN"] = 0] = "UNKNOWN";
469
+ ButtonsResponseMessageType2[ButtonsResponseMessageType2["DISPLAY_TEXT"] = 1] = "DISPLAY_TEXT";
470
+ return ButtonsResponseMessageType2;
471
+ })(ButtonsResponseMessageType || {});
472
+ var ListResponseMessageListType = /* @__PURE__ */ ((ListResponseMessageListType2) => {
473
+ ListResponseMessageListType2[ListResponseMessageListType2["UNKNOWN"] = 0] = "UNKNOWN";
474
+ ListResponseMessageListType2[ListResponseMessageListType2["SINGLE_SELECT"] = 1] = "SINGLE_SELECT";
475
+ return ListResponseMessageListType2;
476
+ })(ListResponseMessageListType || {});
477
+ var PaymentBackgroundType = /* @__PURE__ */ ((PaymentBackgroundType2) => {
478
+ PaymentBackgroundType2[PaymentBackgroundType2["UNKNOWN"] = 0] = "UNKNOWN";
479
+ PaymentBackgroundType2[PaymentBackgroundType2["DEFAULT"] = 1] = "DEFAULT";
480
+ return PaymentBackgroundType2;
481
+ })(PaymentBackgroundType || {});
482
+ var ProtocolMessageType = /* @__PURE__ */ ((ProtocolMessageType2) => {
483
+ ProtocolMessageType2[ProtocolMessageType2["REVOKE"] = 0] = "REVOKE";
484
+ ProtocolMessageType2[ProtocolMessageType2["EPHEMERAL_SETTING"] = 3] = "EPHEMERAL_SETTING";
485
+ ProtocolMessageType2[ProtocolMessageType2["EPHEMERAL_SYNC_RESPONSE"] = 4] = "EPHEMERAL_SYNC_RESPONSE";
486
+ ProtocolMessageType2[ProtocolMessageType2["HISTORY_SYNC_NOTIFICATION"] = 5] = "HISTORY_SYNC_NOTIFICATION";
487
+ ProtocolMessageType2[ProtocolMessageType2["APP_STATE_SYNC_KEY_SHARE"] = 6] = "APP_STATE_SYNC_KEY_SHARE";
488
+ ProtocolMessageType2[ProtocolMessageType2["APP_STATE_SYNC_KEY_REQUEST"] = 7] = "APP_STATE_SYNC_KEY_REQUEST";
489
+ ProtocolMessageType2[ProtocolMessageType2["MSG_FANOUT_BACKFILL_REQUEST"] = 8] = "MSG_FANOUT_BACKFILL_REQUEST";
490
+ ProtocolMessageType2[ProtocolMessageType2["INITIAL_SECURITY_NOTIFICATION_SETTING_SYNC"] = 9] = "INITIAL_SECURITY_NOTIFICATION_SETTING_SYNC";
491
+ ProtocolMessageType2[ProtocolMessageType2["APP_STATE_FATAL_EXCEPTION_NOTIFICATION"] = 10] = "APP_STATE_FATAL_EXCEPTION_NOTIFICATION";
492
+ ProtocolMessageType2[ProtocolMessageType2["SHARE_PHONE_NUMBER"] = 11] = "SHARE_PHONE_NUMBER";
493
+ ProtocolMessageType2[ProtocolMessageType2["MESSAGE_EDIT"] = 14] = "MESSAGE_EDIT";
494
+ ProtocolMessageType2[ProtocolMessageType2["PEER_DATA_OPERATION_REQUEST_MESSAGE"] = 16] = "PEER_DATA_OPERATION_REQUEST_MESSAGE";
495
+ ProtocolMessageType2[ProtocolMessageType2["PEER_DATA_OPERATION_REQUEST_RESPONSE_MESSAGE"] = 17] = "PEER_DATA_OPERATION_REQUEST_RESPONSE_MESSAGE";
496
+ return ProtocolMessageType2;
497
+ })(ProtocolMessageType || {});
498
+ var BotPluginType = /* @__PURE__ */ ((BotPluginType2) => {
499
+ BotPluginType2[BotPluginType2["REELS"] = 0] = "REELS";
500
+ BotPluginType2[BotPluginType2["SEARCH"] = 1] = "SEARCH";
501
+ return BotPluginType2;
502
+ })(BotPluginType || {});
503
+ var BotPluginSearchProvider = /* @__PURE__ */ ((BotPluginSearchProvider2) => {
504
+ BotPluginSearchProvider2[BotPluginSearchProvider2["BING"] = 0] = "BING";
505
+ BotPluginSearchProvider2[BotPluginSearchProvider2["GOOGLE"] = 1] = "GOOGLE";
506
+ return BotPluginSearchProvider2;
507
+ })(BotPluginSearchProvider || {});
508
+ var HistorySyncNotificationHistorySyncType = /* @__PURE__ */ ((HistorySyncNotificationHistorySyncType2) => {
509
+ HistorySyncNotificationHistorySyncType2[HistorySyncNotificationHistorySyncType2["INITIAL_BOOTSTRAP"] = 0] = "INITIAL_BOOTSTRAP";
510
+ HistorySyncNotificationHistorySyncType2[HistorySyncNotificationHistorySyncType2["INITIAL_STATUS_V3"] = 1] = "INITIAL_STATUS_V3";
511
+ HistorySyncNotificationHistorySyncType2[HistorySyncNotificationHistorySyncType2["FULL"] = 2] = "FULL";
512
+ HistorySyncNotificationHistorySyncType2[HistorySyncNotificationHistorySyncType2["RECENT"] = 3] = "RECENT";
513
+ HistorySyncNotificationHistorySyncType2[HistorySyncNotificationHistorySyncType2["PUSH_NAME"] = 4] = "PUSH_NAME";
514
+ HistorySyncNotificationHistorySyncType2[HistorySyncNotificationHistorySyncType2["NON_BLOCKING_DATA"] = 5] = "NON_BLOCKING_DATA";
515
+ HistorySyncNotificationHistorySyncType2[HistorySyncNotificationHistorySyncType2["ON_DEMAND"] = 6] = "ON_DEMAND";
516
+ return HistorySyncNotificationHistorySyncType2;
517
+ })(HistorySyncNotificationHistorySyncType || {});
518
+ var PeerDataOperationRequestType = /* @__PURE__ */ ((PeerDataOperationRequestType2) => {
519
+ PeerDataOperationRequestType2[PeerDataOperationRequestType2["UPLOAD_STICKER"] = 0] = "UPLOAD_STICKER";
520
+ PeerDataOperationRequestType2[PeerDataOperationRequestType2["SEND_RECENT_STICKER_BOOTSTRAP"] = 1] = "SEND_RECENT_STICKER_BOOTSTRAP";
521
+ PeerDataOperationRequestType2[PeerDataOperationRequestType2["GENERATE_LINK_PREVIEW"] = 2] = "GENERATE_LINK_PREVIEW";
522
+ return PeerDataOperationRequestType2;
523
+ })(PeerDataOperationRequestType || {});
524
+ var PeerDataOperationRequestResponseMessagePeerDataOperationResult = /* @__PURE__ */ ((PeerDataOperationRequestResponseMessagePeerDataOperationResult2) => {
525
+ PeerDataOperationRequestResponseMessagePeerDataOperationResult2[PeerDataOperationRequestResponseMessagePeerDataOperationResult2["SUCCESS"] = 0] = "SUCCESS";
526
+ PeerDataOperationRequestResponseMessagePeerDataOperationResult2[PeerDataOperationRequestResponseMessagePeerDataOperationResult2["NOT_AUTHORIZED"] = 1] = "NOT_AUTHORIZED";
527
+ PeerDataOperationRequestResponseMessagePeerDataOperationResult2[PeerDataOperationRequestResponseMessagePeerDataOperationResult2["NOT_FOUND"] = 2] = "NOT_FOUND";
528
+ PeerDataOperationRequestResponseMessagePeerDataOperationResult2[PeerDataOperationRequestResponseMessagePeerDataOperationResult2["THROTTLED"] = 3] = "THROTTLED";
529
+ PeerDataOperationRequestResponseMessagePeerDataOperationResult2[PeerDataOperationRequestResponseMessagePeerDataOperationResult2["UNKNOWN_ERROR"] = 4] = "UNKNOWN_ERROR";
530
+ return PeerDataOperationRequestResponseMessagePeerDataOperationResult2;
531
+ })(PeerDataOperationRequestResponseMessagePeerDataOperationResult || {});
532
+ function getMessageContent(message) {
533
+ if (message.conversation) {
534
+ return { type: "text", content: message.conversation };
535
+ }
536
+ if (message.extendedTextMessage) {
537
+ return { type: "extendedText", content: message.extendedTextMessage };
538
+ }
539
+ if (message.imageMessage) {
540
+ return { type: "image", content: message.imageMessage };
541
+ }
542
+ if (message.videoMessage) {
543
+ return { type: "video", content: message.videoMessage };
544
+ }
545
+ if (message.audioMessage) {
546
+ return { type: "audio", content: message.audioMessage };
547
+ }
548
+ if (message.documentMessage) {
549
+ return { type: "document", content: message.documentMessage };
550
+ }
551
+ if (message.stickerMessage) {
552
+ return { type: "sticker", content: message.stickerMessage };
553
+ }
554
+ if (message.locationMessage) {
555
+ return { type: "location", content: message.locationMessage };
556
+ }
557
+ if (message.liveLocationMessage) {
558
+ return { type: "liveLocation", content: message.liveLocationMessage };
559
+ }
560
+ if (message.contactMessage) {
561
+ return { type: "contact", content: message.contactMessage };
562
+ }
563
+ if (message.contactsArrayMessage) {
564
+ return { type: "contactsArray", content: message.contactsArrayMessage };
565
+ }
566
+ if (message.buttonsMessage) {
567
+ return { type: "buttons", content: message.buttonsMessage };
568
+ }
569
+ if (message.listMessage) {
570
+ return { type: "list", content: message.listMessage };
571
+ }
572
+ if (message.templateMessage) {
573
+ return { type: "template", content: message.templateMessage };
574
+ }
575
+ if (message.buttonsResponseMessage) {
576
+ return { type: "buttonsResponse", content: message.buttonsResponseMessage };
577
+ }
578
+ if (message.listResponseMessage) {
579
+ return { type: "listResponse", content: message.listResponseMessage };
580
+ }
581
+ if (message.groupInviteMessage) {
582
+ return { type: "groupInvite", content: message.groupInviteMessage };
583
+ }
584
+ if (message.pollCreationMessage) {
585
+ return { type: "poll", content: message.pollCreationMessage };
586
+ }
587
+ if (message.pollUpdateMessage) {
588
+ return { type: "pollUpdate", content: message.pollUpdateMessage };
589
+ }
590
+ if (message.reactionMessage) {
591
+ return { type: "reaction", content: message.reactionMessage };
592
+ }
593
+ if (message.protocolMessage) {
594
+ return { type: "protocol", content: message.protocolMessage };
595
+ }
596
+ if (message.ephemeralMessage) {
597
+ return { type: "ephemeral", content: message.ephemeralMessage };
598
+ }
599
+ if (message.viewOnceMessage) {
600
+ return { type: "viewOnce", content: message.viewOnceMessage };
601
+ }
602
+ return null;
603
+ }
604
+ var MessageStatus = /* @__PURE__ */ ((MessageStatus2) => {
605
+ MessageStatus2["ERROR"] = "ERROR";
606
+ MessageStatus2["PENDING"] = "PENDING";
607
+ MessageStatus2["SERVER_ACK"] = "SERVER_ACK";
608
+ MessageStatus2["DELIVERY_ACK"] = "DELIVERY_ACK";
609
+ MessageStatus2["READ"] = "READ";
610
+ MessageStatus2["PLAYED"] = "PLAYED";
611
+ return MessageStatus2;
612
+ })(MessageStatus || {});
613
+ var ReceiptType = /* @__PURE__ */ ((ReceiptType2) => {
614
+ ReceiptType2["UNKNOWN"] = "";
615
+ ReceiptType2["DELIVERY"] = "delivery";
616
+ ReceiptType2["READ"] = "read";
617
+ ReceiptType2["READ_SELF"] = "read-self";
618
+ ReceiptType2["PLAYED"] = "played";
619
+ ReceiptType2["SENDER"] = "sender";
620
+ ReceiptType2["INACTIVE"] = "inactive";
621
+ ReceiptType2["PEER_MSG"] = "peer_msg";
622
+ return ReceiptType2;
623
+ })(ReceiptType || {});
624
+ var DecryptFailMode = /* @__PURE__ */ ((DecryptFailMode2) => {
625
+ DecryptFailMode2["UNAVAILABLE"] = "unavailable";
626
+ DecryptFailMode2["DECRYPT_FAIL"] = "decrypt_fail";
627
+ return DecryptFailMode2;
628
+ })(DecryptFailMode || {});
629
+ var UnavailableType = /* @__PURE__ */ ((UnavailableType2) => {
630
+ UnavailableType2["UNKNOWN"] = "";
631
+ UnavailableType2["VIEW_ONCE"] = "view_once";
632
+ return UnavailableType2;
633
+ })(UnavailableType || {});
634
+ var ConnectFailureReason = /* @__PURE__ */ ((ConnectFailureReason2) => {
635
+ ConnectFailureReason2[ConnectFailureReason2["SOCKET_OPEN_TIMEOUT"] = 4001] = "SOCKET_OPEN_TIMEOUT";
636
+ ConnectFailureReason2[ConnectFailureReason2["SOCKET_PING_TIMEOUT"] = 4002] = "SOCKET_PING_TIMEOUT";
637
+ ConnectFailureReason2[ConnectFailureReason2["SOCKET_PONG_TIMEOUT"] = 4003] = "SOCKET_PONG_TIMEOUT";
638
+ ConnectFailureReason2[ConnectFailureReason2["UNKNOWN_LOGOUT"] = 4004] = "UNKNOWN_LOGOUT";
639
+ ConnectFailureReason2[ConnectFailureReason2["BAD_MAC"] = 4005] = "BAD_MAC";
640
+ ConnectFailureReason2[ConnectFailureReason2["INIT_TIMEOUT"] = 4006] = "INIT_TIMEOUT";
641
+ ConnectFailureReason2[ConnectFailureReason2["MULTI_DEVICE_MISMATCH"] = 4007] = "MULTI_DEVICE_MISMATCH";
642
+ ConnectFailureReason2[ConnectFailureReason2["MULTI_DEVICE_DISABLED"] = 4008] = "MULTI_DEVICE_DISABLED";
643
+ ConnectFailureReason2[ConnectFailureReason2["TEMP_BANNED"] = 4009] = "TEMP_BANNED";
644
+ ConnectFailureReason2[ConnectFailureReason2["CLIENT_OUTDATED"] = 4010] = "CLIENT_OUTDATED";
645
+ ConnectFailureReason2[ConnectFailureReason2["STREAM_ERROR"] = 4011] = "STREAM_ERROR";
646
+ ConnectFailureReason2[ConnectFailureReason2["DEVICE_GONE"] = 4012] = "DEVICE_GONE";
647
+ ConnectFailureReason2[ConnectFailureReason2["IDENTITY_MISSING"] = 4013] = "IDENTITY_MISSING";
648
+ ConnectFailureReason2[ConnectFailureReason2["RATE_LIMIT_HIT"] = 4014] = "RATE_LIMIT_HIT";
649
+ ConnectFailureReason2[ConnectFailureReason2["MAIN_DEVICE_GONE"] = 4015] = "MAIN_DEVICE_GONE";
650
+ return ConnectFailureReason2;
651
+ })(ConnectFailureReason || {});
652
+ var TempBanReason = /* @__PURE__ */ ((TempBanReason2) => {
653
+ TempBanReason2[TempBanReason2["SENT_TO_TOO_MANY_PEOPLE"] = 101] = "SENT_TO_TOO_MANY_PEOPLE";
654
+ TempBanReason2[TempBanReason2["BLOCKED_BY_USERS"] = 102] = "BLOCKED_BY_USERS";
655
+ TempBanReason2[TempBanReason2["CREATED_TOO_MANY_GROUPS"] = 103] = "CREATED_TOO_MANY_GROUPS";
656
+ TempBanReason2[TempBanReason2["SENT_TOO_MANY_SAME_MESSAGE"] = 104] = "SENT_TOO_MANY_SAME_MESSAGE";
657
+ TempBanReason2[TempBanReason2["BROADCAST_LIST"] = 106] = "BROADCAST_LIST";
658
+ return TempBanReason2;
659
+ })(TempBanReason || {});
381
660
  export {
382
661
  AdminModule,
662
+ BotPluginSearchProvider,
663
+ BotPluginType,
664
+ ButtonType,
665
+ ButtonsMessageHeaderType,
666
+ ButtonsResponseMessageType,
383
667
  ChatModule,
668
+ ConnectFailureReason,
669
+ DecryptFailMode,
670
+ DisappearingModeInitiator,
671
+ DisappearingModeTrigger,
672
+ ExtendedTextMessageFontType,
673
+ ExtendedTextMessageInviteLinkGroupType,
674
+ ExtendedTextMessagePreviewType,
384
675
  GroupModule,
676
+ HistorySyncNotificationHistorySyncType,
677
+ InviteLinkGroupType,
678
+ ListMessageListType,
679
+ ListResponseMessageListType,
680
+ MediaType,
681
+ MessageStatus,
682
+ PaymentBackgroundType,
683
+ PeerDataOperationRequestResponseMessagePeerDataOperationResult,
684
+ PeerDataOperationRequestType,
685
+ ProtocolMessageType,
686
+ ReceiptType,
385
687
  SessionModule,
688
+ TempBanReason,
689
+ UnavailableType,
386
690
  UserModule,
691
+ VideoAttribution,
692
+ VideoSourceType,
387
693
  WebhookModule,
388
694
  WuzapiClient,
389
695
  WuzapiError,
390
- WuzapiClient as default
696
+ WuzapiClient as default,
697
+ getMessageContent
391
698
  };
392
699
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/client.ts","../src/modules/admin.ts","../src/modules/session.ts","../src/modules/user.ts","../src/modules/chat.ts","../src/modules/group.ts","../src/modules/webhook.ts","../src/wuzapi-client.ts"],"sourcesContent":["import axios, { AxiosInstance, AxiosResponse } from \"axios\";\nimport { WuzapiConfig, WuzapiResponse } from \"./types/common.js\";\n\nexport class WuzapiError extends Error {\n public code: number;\n public details?: unknown;\n\n constructor(code: number, message: string, details?: unknown) {\n super(message);\n this.name = \"WuzapiError\";\n this.code = code;\n this.details = details;\n }\n}\n\nexport class BaseClient {\n protected axios: AxiosInstance;\n protected config: WuzapiConfig;\n\n constructor(config: WuzapiConfig) {\n this.config = config;\n this.axios = axios.create({\n baseURL: config.apiUrl,\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: config.token,\n },\n });\n\n // Add response interceptor for error handling\n this.axios.interceptors.response.use(\n (response: AxiosResponse) => response,\n (error) => {\n if (error.response) {\n // Server responded with error status\n const data = error.response.data;\n throw new WuzapiError(\n data.code || error.response.status,\n data.message || error.message,\n data\n );\n } else if (error.request) {\n // Request was made but no response received\n throw new WuzapiError(0, \"Network error: No response from server\");\n } else {\n // Something else happened\n throw new WuzapiError(0, error.message);\n }\n }\n );\n }\n\n protected async request<T>(\n method: \"GET\" | \"POST\" | \"DELETE\",\n endpoint: string,\n data?: unknown\n ): Promise<T> {\n const response = await this.axios.request<WuzapiResponse<T>>({\n method,\n url: endpoint,\n data,\n });\n\n if (!response.data.success) {\n throw new WuzapiError(\n response.data.code,\n \"API request failed\",\n response.data\n );\n }\n\n return response.data.data;\n }\n\n protected async get<T>(endpoint: string): Promise<T> {\n return this.request<T>(\"GET\", endpoint);\n }\n\n protected async post<T>(endpoint: string, data?: unknown): Promise<T> {\n return this.request<T>(\"POST\", endpoint, data);\n }\n\n protected async delete<T>(endpoint: string): Promise<T> {\n return this.request<T>(\"DELETE\", endpoint);\n }\n}\n","import { BaseClient } from \"../client.js\";\nimport {\n User,\n CreateUserRequest,\n CreateUserResponse,\n DeleteUserResponse,\n} from \"../types/admin.js\";\n\nexport class AdminModule extends BaseClient {\n /**\n * List all users\n */\n async listUsers(): Promise<User[]> {\n return this.get<User[]>(\"/admin/users\");\n }\n\n /**\n * Add a new user\n */\n async addUser(user: CreateUserRequest): Promise<CreateUserResponse> {\n return this.post<CreateUserResponse>(\"/admin/users\", user);\n }\n\n /**\n * Delete a user by ID\n */\n async deleteUser(id: number): Promise<DeleteUserResponse> {\n return this.delete<DeleteUserResponse>(`/admin/users/${id}`);\n }\n}\n","import { BaseClient } from \"../client.js\";\nimport {\n ConnectRequest,\n ConnectResponse,\n DisconnectResponse,\n LogoutResponse,\n StatusResponse,\n QRCodeResponse,\n S3ConfigResponse,\n S3TestResponse,\n} from \"../types/session.js\";\nimport { S3Config } from \"../types/common.js\";\n\nexport class SessionModule extends BaseClient {\n /**\n * Connect to WhatsApp servers\n */\n async connect(options: ConnectRequest): Promise<ConnectResponse> {\n return this.post<ConnectResponse>(\"/session/connect\", options);\n }\n\n /**\n * Disconnect from WhatsApp servers\n */\n async disconnect(): Promise<DisconnectResponse> {\n return this.post<DisconnectResponse>(\"/session/disconnect\");\n }\n\n /**\n * Logout and finish the session\n */\n async logout(): Promise<LogoutResponse> {\n return this.post<LogoutResponse>(\"/session/logout\");\n }\n\n /**\n * Get session status\n */\n async getStatus(): Promise<StatusResponse> {\n return this.get<StatusResponse>(\"/session/status\");\n }\n\n /**\n * Get QR code for scanning\n */\n async getQRCode(): Promise<QRCodeResponse> {\n return this.get<QRCodeResponse>(\"/session/qr\");\n }\n\n /**\n * Configure S3 storage\n */\n async configureS3(config: S3Config): Promise<S3ConfigResponse> {\n return this.post<S3ConfigResponse>(\"/session/s3/config\", config);\n }\n\n /**\n * Get S3 configuration\n */\n async getS3Config(): Promise<S3ConfigResponse> {\n return this.get<S3ConfigResponse>(\"/session/s3/config\");\n }\n\n /**\n * Test S3 connection\n */\n async testS3(): Promise<S3TestResponse> {\n return this.post<S3TestResponse>(\"/session/s3/test\");\n }\n\n /**\n * Delete S3 configuration\n */\n async deleteS3Config(): Promise<{ Details: string }> {\n return this.delete<{ Details: string }>(\"/session/s3/config\");\n }\n}\n","import { BaseClient } from \"../client.js\";\nimport {\n UserInfoRequest,\n UserInfoResponse,\n UserCheckRequest,\n UserCheckResponse,\n UserAvatarRequest,\n UserAvatarResponse,\n ContactsResponse,\n} from \"../types/user.js\";\n\nexport class UserModule extends BaseClient {\n /**\n * Get user details for specified phone numbers\n */\n async getInfo(phones: string[]): Promise<UserInfoResponse> {\n const request: UserInfoRequest = { Phone: phones };\n return this.post<UserInfoResponse>(\"/user/info\", request);\n }\n\n /**\n * Check if phone numbers are registered WhatsApp users\n */\n async check(phones: string[]): Promise<UserCheckResponse> {\n const request: UserCheckRequest = { Phone: phones };\n return this.post<UserCheckResponse>(\"/user/check\", request);\n }\n\n /**\n * Get user avatar/profile picture\n */\n async getAvatar(\n phone: string,\n preview: boolean = true\n ): Promise<UserAvatarResponse> {\n const request: UserAvatarRequest = { Phone: phone, Preview: preview };\n return this.post<UserAvatarResponse>(\"/user/avatar\", request);\n }\n\n /**\n * Get all contacts\n */\n async getContacts(): Promise<ContactsResponse> {\n return this.get<ContactsResponse>(\"/user/contacts\");\n }\n}\n","import { BaseClient } from \"../client.js\";\nimport {\n SendMessageResponse,\n SendTextRequest,\n SendTemplateRequest,\n SendAudioRequest,\n SendImageRequest,\n SendDocumentRequest,\n SendVideoRequest,\n SendStickerRequest,\n SendLocationRequest,\n SendContactRequest,\n ChatPresenceRequest,\n MarkReadRequest,\n ReactRequest,\n DownloadMediaRequest,\n DownloadMediaResponse,\n} from \"../types/chat.js\";\n\nexport class ChatModule extends BaseClient {\n /**\n * Send a text message\n */\n async sendText(request: SendTextRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/text\", request);\n }\n\n /**\n * Send a template message with buttons\n */\n async sendTemplate(\n request: SendTemplateRequest\n ): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/template\", request);\n }\n\n /**\n * Send an audio message\n */\n async sendAudio(request: SendAudioRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/audio\", request);\n }\n\n /**\n * Send an image message\n */\n async sendImage(request: SendImageRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/image\", request);\n }\n\n /**\n * Send a document message\n */\n async sendDocument(\n request: SendDocumentRequest\n ): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/document\", request);\n }\n\n /**\n * Send a video message\n */\n async sendVideo(request: SendVideoRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/video\", request);\n }\n\n /**\n * Send a sticker message\n */\n async sendSticker(request: SendStickerRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/sticker\", request);\n }\n\n /**\n * Send a location message\n */\n async sendLocation(\n request: SendLocationRequest\n ): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/location\", request);\n }\n\n /**\n * Send a contact message\n */\n async sendContact(request: SendContactRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/contact\", request);\n }\n\n /**\n * Send chat presence indication (typing indicator)\n */\n async sendPresence(request: ChatPresenceRequest): Promise<void> {\n await this.post<void>(\"/chat/presence\", request);\n }\n\n /**\n * Mark messages as read\n */\n async markRead(request: MarkReadRequest): Promise<void> {\n await this.post<void>(\"/chat/markread\", request);\n }\n\n /**\n * React to a message\n */\n async react(request: ReactRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/react\", request);\n }\n\n /**\n * Download an image from a message\n */\n async downloadImage(\n request: DownloadMediaRequest\n ): Promise<DownloadMediaResponse> {\n return this.post<DownloadMediaResponse>(\"/chat/downloadimage\", request);\n }\n\n /**\n * Download a video from a message\n */\n async downloadVideo(\n request: DownloadMediaRequest\n ): Promise<DownloadMediaResponse> {\n return this.post<DownloadMediaResponse>(\"/chat/downloadvideo\", request);\n }\n\n /**\n * Download an audio from a message\n */\n async downloadAudio(\n request: DownloadMediaRequest\n ): Promise<DownloadMediaResponse> {\n return this.post<DownloadMediaResponse>(\"/chat/downloadaudio\", request);\n }\n\n /**\n * Download a document from a message\n */\n async downloadDocument(\n request: DownloadMediaRequest\n ): Promise<DownloadMediaResponse> {\n return this.post<DownloadMediaResponse>(\"/chat/downloaddocument\", request);\n }\n}\n","import { BaseClient } from \"../client.js\";\nimport {\n GroupListResponse,\n GroupInviteLinkRequest,\n GroupInviteLinkResponse,\n GroupInfoRequest,\n GroupInfo,\n GroupPhotoRequest,\n GroupPhotoResponse,\n GroupNameRequest,\n GroupNameResponse,\n GroupCreateRequest,\n GroupCreateResponse,\n GroupLockedRequest,\n GroupLockedResponse,\n GroupEphemeralRequest,\n GroupEphemeralResponse,\n GroupPhotoRemoveRequest,\n GroupPhotoRemoveResponse,\n} from \"../types/group.js\";\n\nexport class GroupModule extends BaseClient {\n /**\n * List all subscribed groups\n */\n async list(): Promise<GroupListResponse> {\n return this.get<GroupListResponse>(\"/group/list\");\n }\n\n /**\n * Get group invite link\n */\n async getInviteLink(groupJID: string): Promise<GroupInviteLinkResponse> {\n const request: GroupInviteLinkRequest = { GroupJID: groupJID };\n return this.post<GroupInviteLinkResponse>(\"/group/invitelink\", request);\n }\n\n /**\n * Get group information\n */\n async getInfo(groupJID: string): Promise<GroupInfo> {\n const request: GroupInfoRequest = { GroupJID: groupJID };\n return this.post<GroupInfo>(\"/group/info\", request);\n }\n\n /**\n * Change group photo (JPEG only)\n */\n async setPhoto(groupJID: string, image: string): Promise<GroupPhotoResponse> {\n const request: GroupPhotoRequest = { GroupJID: groupJID, Image: image };\n return this.post<GroupPhotoResponse>(\"/group/photo\", request);\n }\n\n /**\n * Change group name\n */\n async setName(groupJID: string, name: string): Promise<GroupNameResponse> {\n const request: GroupNameRequest = { GroupJID: groupJID, Name: name };\n return this.post<GroupNameResponse>(\"/group/name\", request);\n }\n\n /**\n * Create a new group\n */\n async create(\n name: string,\n participants: string[]\n ): Promise<GroupCreateResponse> {\n const request: GroupCreateRequest = { name, participants };\n return this.post<GroupCreateResponse>(\"/group/create\", request);\n }\n\n /**\n * Set group locked status\n */\n async setLocked(\n groupJID: string,\n locked: boolean\n ): Promise<GroupLockedResponse> {\n const request: GroupLockedRequest = { groupjid: groupJID, locked };\n return this.post<GroupLockedResponse>(\"/group/locked\", request);\n }\n\n /**\n * Set disappearing messages timer\n */\n async setEphemeral(\n groupJID: string,\n duration: \"24h\" | \"7d\" | \"90d\" | \"off\"\n ): Promise<GroupEphemeralResponse> {\n const request: GroupEphemeralRequest = { groupjid: groupJID, duration };\n return this.post<GroupEphemeralResponse>(\"/group/ephemeral\", request);\n }\n\n /**\n * Remove group photo\n */\n async removePhoto(groupJID: string): Promise<GroupPhotoRemoveResponse> {\n const request: GroupPhotoRemoveRequest = { groupjid: groupJID };\n return this.post<GroupPhotoRemoveResponse>(\"/group/photo/remove\", request);\n }\n}\n","import { BaseClient } from \"../client.js\";\nimport {\n SetWebhookRequest,\n SetWebhookResponse,\n GetWebhookResponse,\n} from \"../types/webhook.js\";\n\nexport class WebhookModule extends BaseClient {\n /**\n * Set webhook URL and events to subscribe to\n */\n async setWebhook(webhookURL: string): Promise<SetWebhookResponse> {\n const request: SetWebhookRequest = { webhookURL };\n return this.post<SetWebhookResponse>(\"/webhook\", request);\n }\n\n /**\n * Get current webhook configuration\n */\n async getWebhook(): Promise<GetWebhookResponse> {\n return this.get<GetWebhookResponse>(\"/webhook\");\n }\n}\n","import { WuzapiConfig } from \"./types/common.js\";\nimport { AdminModule } from \"./modules/admin.js\";\nimport { SessionModule } from \"./modules/session.js\";\nimport { UserModule } from \"./modules/user.js\";\nimport { ChatModule } from \"./modules/chat.js\";\nimport { GroupModule } from \"./modules/group.js\";\nimport { WebhookModule } from \"./modules/webhook.js\";\n\nexport class WuzapiClient {\n public readonly admin: AdminModule;\n public readonly session: SessionModule;\n public readonly user: UserModule;\n public readonly chat: ChatModule;\n public readonly group: GroupModule;\n public readonly webhook: WebhookModule;\n\n // Legacy aliases for convenience\n public readonly users: UserModule;\n public readonly message: ChatModule;\n\n constructor(config: WuzapiConfig) {\n // Initialize all modules with the same config\n this.admin = new AdminModule(config);\n this.session = new SessionModule(config);\n this.user = new UserModule(config);\n this.chat = new ChatModule(config);\n this.group = new GroupModule(config);\n this.webhook = new WebhookModule(config);\n\n // Legacy aliases\n this.users = this.user;\n this.message = this.chat;\n }\n\n /**\n * Test connection to the API\n */\n async ping(): Promise<boolean> {\n try {\n await this.session.getStatus();\n return true;\n } catch {\n return false;\n }\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../src/client.ts","../src/modules/admin.ts","../src/modules/session.ts","../src/modules/user.ts","../src/modules/chat.ts","../src/modules/group.ts","../src/modules/webhook.ts","../src/wuzapi-client.ts","../src/types/message.ts","../src/types/events.ts"],"sourcesContent":["import axios, { AxiosInstance, AxiosResponse } from \"axios\";\nimport { WuzapiConfig, WuzapiResponse } from \"./types/common.js\";\n\nexport class WuzapiError extends Error {\n public code: number;\n public details?: unknown;\n\n constructor(code: number, message: string, details?: unknown) {\n super(message);\n this.name = \"WuzapiError\";\n this.code = code;\n this.details = details;\n }\n}\n\nexport class BaseClient {\n protected axios: AxiosInstance;\n protected config: WuzapiConfig;\n\n constructor(config: WuzapiConfig) {\n this.config = config;\n this.axios = axios.create({\n baseURL: config.apiUrl,\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: config.token,\n },\n });\n\n // Add response interceptor for error handling\n this.axios.interceptors.response.use(\n (response: AxiosResponse) => response,\n (error) => {\n if (error.response) {\n // Server responded with error status\n const data = error.response.data;\n throw new WuzapiError(\n data.code || error.response.status,\n data.message || error.message,\n data\n );\n } else if (error.request) {\n // Request was made but no response received\n throw new WuzapiError(0, \"Network error: No response from server\");\n } else {\n // Something else happened\n throw new WuzapiError(0, error.message);\n }\n }\n );\n }\n\n protected async request<T>(\n method: \"GET\" | \"POST\" | \"DELETE\",\n endpoint: string,\n data?: unknown\n ): Promise<T> {\n const response = await this.axios.request<WuzapiResponse<T>>({\n method,\n url: endpoint,\n data,\n });\n\n if (!response.data.success) {\n throw new WuzapiError(\n response.data.code,\n \"API request failed\",\n response.data\n );\n }\n\n return response.data.data;\n }\n\n protected async get<T>(endpoint: string): Promise<T> {\n return this.request<T>(\"GET\", endpoint);\n }\n\n protected async post<T>(endpoint: string, data?: unknown): Promise<T> {\n return this.request<T>(\"POST\", endpoint, data);\n }\n\n protected async delete<T>(endpoint: string): Promise<T> {\n return this.request<T>(\"DELETE\", endpoint);\n }\n}\n","import { BaseClient } from \"../client.js\";\nimport {\n User,\n CreateUserRequest,\n CreateUserResponse,\n DeleteUserResponse,\n} from \"../types/admin.js\";\n\nexport class AdminModule extends BaseClient {\n /**\n * List all users\n */\n async listUsers(): Promise<User[]> {\n return this.get<User[]>(\"/admin/users\");\n }\n\n /**\n * Add a new user\n */\n async addUser(user: CreateUserRequest): Promise<CreateUserResponse> {\n return this.post<CreateUserResponse>(\"/admin/users\", user);\n }\n\n /**\n * Delete a user by ID\n */\n async deleteUser(id: number): Promise<DeleteUserResponse> {\n return this.delete<DeleteUserResponse>(`/admin/users/${id}`);\n }\n}\n","import { BaseClient } from \"../client.js\";\nimport {\n ConnectRequest,\n ConnectResponse,\n DisconnectResponse,\n LogoutResponse,\n StatusResponse,\n QRCodeResponse,\n S3ConfigResponse,\n S3TestResponse,\n} from \"../types/session.js\";\nimport { S3Config } from \"../types/common.js\";\n\nexport class SessionModule extends BaseClient {\n /**\n * Connect to WhatsApp servers\n */\n async connect(options: ConnectRequest): Promise<ConnectResponse> {\n return this.post<ConnectResponse>(\"/session/connect\", options);\n }\n\n /**\n * Disconnect from WhatsApp servers\n */\n async disconnect(): Promise<DisconnectResponse> {\n return this.post<DisconnectResponse>(\"/session/disconnect\");\n }\n\n /**\n * Logout and finish the session\n */\n async logout(): Promise<LogoutResponse> {\n return this.post<LogoutResponse>(\"/session/logout\");\n }\n\n /**\n * Get session status\n */\n async getStatus(): Promise<StatusResponse> {\n return this.get<StatusResponse>(\"/session/status\");\n }\n\n /**\n * Get QR code for scanning\n */\n async getQRCode(): Promise<QRCodeResponse> {\n return this.get<QRCodeResponse>(\"/session/qr\");\n }\n\n /**\n * Configure S3 storage\n */\n async configureS3(config: S3Config): Promise<S3ConfigResponse> {\n return this.post<S3ConfigResponse>(\"/session/s3/config\", config);\n }\n\n /**\n * Get S3 configuration\n */\n async getS3Config(): Promise<S3ConfigResponse> {\n return this.get<S3ConfigResponse>(\"/session/s3/config\");\n }\n\n /**\n * Test S3 connection\n */\n async testS3(): Promise<S3TestResponse> {\n return this.post<S3TestResponse>(\"/session/s3/test\");\n }\n\n /**\n * Delete S3 configuration\n */\n async deleteS3Config(): Promise<{ Details: string }> {\n return this.delete<{ Details: string }>(\"/session/s3/config\");\n }\n}\n","import { BaseClient } from \"../client.js\";\nimport {\n UserInfoRequest,\n UserInfoResponse,\n UserCheckRequest,\n UserCheckResponse,\n UserAvatarRequest,\n UserAvatarResponse,\n ContactsResponse,\n} from \"../types/user.js\";\n\nexport class UserModule extends BaseClient {\n /**\n * Get user details for specified phone numbers\n */\n async getInfo(phones: string[]): Promise<UserInfoResponse> {\n const request: UserInfoRequest = { Phone: phones };\n return this.post<UserInfoResponse>(\"/user/info\", request);\n }\n\n /**\n * Check if phone numbers are registered WhatsApp users\n */\n async check(phones: string[]): Promise<UserCheckResponse> {\n const request: UserCheckRequest = { Phone: phones };\n return this.post<UserCheckResponse>(\"/user/check\", request);\n }\n\n /**\n * Get user avatar/profile picture\n */\n async getAvatar(\n phone: string,\n preview: boolean = true\n ): Promise<UserAvatarResponse> {\n const request: UserAvatarRequest = { Phone: phone, Preview: preview };\n return this.post<UserAvatarResponse>(\"/user/avatar\", request);\n }\n\n /**\n * Get all contacts\n */\n async getContacts(): Promise<ContactsResponse> {\n return this.get<ContactsResponse>(\"/user/contacts\");\n }\n}\n","import { BaseClient } from \"../client.js\";\nimport {\n SendMessageResponse,\n SendTextRequest,\n SendTemplateRequest,\n SendAudioRequest,\n SendImageRequest,\n SendDocumentRequest,\n SendVideoRequest,\n SendStickerRequest,\n SendLocationRequest,\n SendContactRequest,\n ChatPresenceRequest,\n MarkReadRequest,\n ReactRequest,\n DownloadMediaRequest,\n DownloadMediaResponse,\n} from \"../types/chat.js\";\n\nexport class ChatModule extends BaseClient {\n /**\n * Send a text message\n */\n async sendText(request: SendTextRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/text\", request);\n }\n\n /**\n * Send a template message with buttons\n */\n async sendTemplate(\n request: SendTemplateRequest\n ): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/template\", request);\n }\n\n /**\n * Send an audio message\n */\n async sendAudio(request: SendAudioRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/audio\", request);\n }\n\n /**\n * Send an image message\n */\n async sendImage(request: SendImageRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/image\", request);\n }\n\n /**\n * Send a document message\n */\n async sendDocument(\n request: SendDocumentRequest\n ): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/document\", request);\n }\n\n /**\n * Send a video message\n */\n async sendVideo(request: SendVideoRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/video\", request);\n }\n\n /**\n * Send a sticker message\n */\n async sendSticker(request: SendStickerRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/sticker\", request);\n }\n\n /**\n * Send a location message\n */\n async sendLocation(\n request: SendLocationRequest\n ): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/location\", request);\n }\n\n /**\n * Send a contact message\n */\n async sendContact(request: SendContactRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/send/contact\", request);\n }\n\n /**\n * Send chat presence indication (typing indicator)\n */\n async sendPresence(request: ChatPresenceRequest): Promise<void> {\n await this.post<void>(\"/chat/presence\", request);\n }\n\n /**\n * Mark messages as read\n */\n async markRead(request: MarkReadRequest): Promise<void> {\n await this.post<void>(\"/chat/markread\", request);\n }\n\n /**\n * React to a message\n */\n async react(request: ReactRequest): Promise<SendMessageResponse> {\n return this.post<SendMessageResponse>(\"/chat/react\", request);\n }\n\n /**\n * Download an image from a message\n */\n async downloadImage(\n request: DownloadMediaRequest\n ): Promise<DownloadMediaResponse> {\n return this.post<DownloadMediaResponse>(\"/chat/downloadimage\", request);\n }\n\n /**\n * Download a video from a message\n */\n async downloadVideo(\n request: DownloadMediaRequest\n ): Promise<DownloadMediaResponse> {\n return this.post<DownloadMediaResponse>(\"/chat/downloadvideo\", request);\n }\n\n /**\n * Download an audio from a message\n */\n async downloadAudio(\n request: DownloadMediaRequest\n ): Promise<DownloadMediaResponse> {\n return this.post<DownloadMediaResponse>(\"/chat/downloadaudio\", request);\n }\n\n /**\n * Download a document from a message\n */\n async downloadDocument(\n request: DownloadMediaRequest\n ): Promise<DownloadMediaResponse> {\n return this.post<DownloadMediaResponse>(\"/chat/downloaddocument\", request);\n }\n}\n","import { BaseClient } from \"../client.js\";\nimport {\n GroupListResponse,\n GroupInviteLinkRequest,\n GroupInviteLinkResponse,\n GroupInfoRequest,\n GroupInfo,\n GroupPhotoRequest,\n GroupPhotoResponse,\n GroupNameRequest,\n GroupNameResponse,\n GroupCreateRequest,\n GroupCreateResponse,\n GroupLockedRequest,\n GroupLockedResponse,\n GroupEphemeralRequest,\n GroupEphemeralResponse,\n GroupPhotoRemoveRequest,\n GroupPhotoRemoveResponse,\n} from \"../types/group.js\";\n\nexport class GroupModule extends BaseClient {\n /**\n * List all subscribed groups\n */\n async list(): Promise<GroupListResponse> {\n return this.get<GroupListResponse>(\"/group/list\");\n }\n\n /**\n * Get group invite link\n */\n async getInviteLink(groupJID: string): Promise<GroupInviteLinkResponse> {\n const request: GroupInviteLinkRequest = { GroupJID: groupJID };\n return this.post<GroupInviteLinkResponse>(\"/group/invitelink\", request);\n }\n\n /**\n * Get group information\n */\n async getInfo(groupJID: string): Promise<GroupInfo> {\n const request: GroupInfoRequest = { GroupJID: groupJID };\n return this.post<GroupInfo>(\"/group/info\", request);\n }\n\n /**\n * Change group photo (JPEG only)\n */\n async setPhoto(groupJID: string, image: string): Promise<GroupPhotoResponse> {\n const request: GroupPhotoRequest = { GroupJID: groupJID, Image: image };\n return this.post<GroupPhotoResponse>(\"/group/photo\", request);\n }\n\n /**\n * Change group name\n */\n async setName(groupJID: string, name: string): Promise<GroupNameResponse> {\n const request: GroupNameRequest = { GroupJID: groupJID, Name: name };\n return this.post<GroupNameResponse>(\"/group/name\", request);\n }\n\n /**\n * Create a new group\n */\n async create(\n name: string,\n participants: string[]\n ): Promise<GroupCreateResponse> {\n const request: GroupCreateRequest = { name, participants };\n return this.post<GroupCreateResponse>(\"/group/create\", request);\n }\n\n /**\n * Set group locked status\n */\n async setLocked(\n groupJID: string,\n locked: boolean\n ): Promise<GroupLockedResponse> {\n const request: GroupLockedRequest = { groupjid: groupJID, locked };\n return this.post<GroupLockedResponse>(\"/group/locked\", request);\n }\n\n /**\n * Set disappearing messages timer\n */\n async setEphemeral(\n groupJID: string,\n duration: \"24h\" | \"7d\" | \"90d\" | \"off\"\n ): Promise<GroupEphemeralResponse> {\n const request: GroupEphemeralRequest = { groupjid: groupJID, duration };\n return this.post<GroupEphemeralResponse>(\"/group/ephemeral\", request);\n }\n\n /**\n * Remove group photo\n */\n async removePhoto(groupJID: string): Promise<GroupPhotoRemoveResponse> {\n const request: GroupPhotoRemoveRequest = { groupjid: groupJID };\n return this.post<GroupPhotoRemoveResponse>(\"/group/photo/remove\", request);\n }\n}\n","import { BaseClient } from \"../client.js\";\nimport {\n SetWebhookRequest,\n SetWebhookResponse,\n GetWebhookResponse,\n} from \"../types/webhook.js\";\n\nexport class WebhookModule extends BaseClient {\n /**\n * Set webhook URL and events to subscribe to\n */\n async setWebhook(webhookURL: string): Promise<SetWebhookResponse> {\n const request: SetWebhookRequest = { webhookURL };\n return this.post<SetWebhookResponse>(\"/webhook\", request);\n }\n\n /**\n * Get current webhook configuration\n */\n async getWebhook(): Promise<GetWebhookResponse> {\n return this.get<GetWebhookResponse>(\"/webhook\");\n }\n}\n","import { WuzapiConfig } from \"./types/common.js\";\nimport { AdminModule } from \"./modules/admin.js\";\nimport { SessionModule } from \"./modules/session.js\";\nimport { UserModule } from \"./modules/user.js\";\nimport { ChatModule } from \"./modules/chat.js\";\nimport { GroupModule } from \"./modules/group.js\";\nimport { WebhookModule } from \"./modules/webhook.js\";\n\nexport class WuzapiClient {\n public readonly admin: AdminModule;\n public readonly session: SessionModule;\n public readonly user: UserModule;\n public readonly chat: ChatModule;\n public readonly group: GroupModule;\n public readonly webhook: WebhookModule;\n\n // Legacy aliases for convenience\n public readonly users: UserModule;\n public readonly message: ChatModule;\n\n constructor(config: WuzapiConfig) {\n // Initialize all modules with the same config\n this.admin = new AdminModule(config);\n this.session = new SessionModule(config);\n this.user = new UserModule(config);\n this.chat = new ChatModule(config);\n this.group = new GroupModule(config);\n this.webhook = new WebhookModule(config);\n\n // Legacy aliases\n this.users = this.user;\n this.message = this.chat;\n }\n\n /**\n * Test connection to the API\n */\n async ping(): Promise<boolean> {\n try {\n await this.session.getStatus();\n return true;\n } catch {\n return false;\n }\n }\n}\n","// WhatsApp Message types based on whatsmeow protobuf definitions\n// Reference: https://pkg.go.dev/go.mau.fi/whatsmeow@v0.0.0-20250829123043-72d2ed58e998/proto/waE2E#Message\n\n// Base message context and metadata types\nexport interface ContextInfo {\n stanzaId?: string;\n participant?: string;\n quotedMessage?: Message;\n remoteJid?: string;\n mentionedJid?: string[];\n conversionSource?: string;\n conversionData?: string;\n conversionDelaySeconds?: number;\n forwardingScore?: number;\n isForwarded?: boolean;\n quotedAd?: AdReplyInfo;\n placeholderKey?: MessageKey;\n expiration?: number;\n ephemeralSettingTimestamp?: number;\n ephemeralSharedSecret?: string;\n externalAdReply?: ExternalAdReplyInfo;\n entryPointConversionSource?: string;\n entryPointConversionApp?: string;\n entryPointConversionDelaySeconds?: number;\n disappearingMode?: DisappearingMode;\n actionLink?: ActionLink;\n groupSubject?: string;\n parentGroupJid?: string;\n trustBannerType?: string;\n trustBannerAction?: number;\n isSampled?: boolean;\n utm?: UTMInfo;\n}\n\nexport interface MessageKey {\n remoteJid?: string;\n fromMe?: boolean;\n id?: string;\n participant?: string;\n}\n\nexport interface DisappearingMode {\n initiator?: DisappearingModeInitiator;\n trigger?: DisappearingModeTrigger;\n initiatorDeviceJid?: string;\n}\n\nexport enum DisappearingModeInitiator {\n CHANGED_IN_CHAT = 0,\n INITIATED_BY_ME = 1,\n INITIATED_BY_OTHER = 2,\n}\n\nexport enum DisappearingModeTrigger {\n UNKNOWN = 0,\n CHAT_SETTING = 1,\n ACCOUNT_SETTING = 2,\n BULK_CHANGE = 3,\n}\n\nexport interface AdReplyInfo {\n advertiserName?: string;\n mediaType?: MediaType;\n jpegThumbnail?: Uint8Array;\n caption?: string;\n}\n\nexport interface ExternalAdReplyInfo {\n title?: string;\n body?: string;\n mediaType?: MediaType;\n thumbnailUrl?: string;\n mediaUrl?: string;\n thumbnail?: Uint8Array;\n sourceType?: string;\n sourceId?: string;\n sourceUrl?: string;\n containsAutoReply?: boolean;\n renderLargerThumbnail?: boolean;\n showAdAttribution?: boolean;\n ctwaClid?: string;\n ref?: string;\n}\n\nexport interface ActionLink {\n url?: string;\n buttonTitle?: string;\n}\n\nexport interface UTMInfo {\n utmSource?: string;\n utmCampaign?: string;\n}\n\nexport enum MediaType {\n UNKNOWN = 0,\n IMAGE = 1,\n VIDEO = 2,\n AUDIO = 3,\n DOCUMENT = 4,\n STICKER = 5,\n}\n\n// Interactive elements\nexport interface InteractiveAnnotation {\n polygonVertices?: Point[];\n location?: Location;\n}\n\nexport interface Point {\n xDeprecated?: number;\n yDeprecated?: number;\n x?: number;\n y?: number;\n}\n\n// Location types\nexport interface LocationMessage {\n degreesLatitude?: number;\n degreesLongitude?: number;\n name?: string;\n address?: string;\n url?: string;\n isLiveLocation?: boolean;\n accuracyInMeters?: number;\n speedInMps?: number;\n degreesClockwiseFromMagneticNorth?: number;\n comment?: string;\n jpegThumbnail?: Uint8Array;\n contextInfo?: ContextInfo;\n}\n\nexport interface LiveLocationMessage {\n degreesLatitude?: number;\n degreesLongitude?: number;\n accuracyInMeters?: number;\n speedInMps?: number;\n degreesClockwiseFromMagneticNorth?: number;\n caption?: string;\n sequenceNumber?: number;\n timeOffset?: number;\n jpegThumbnail?: Uint8Array;\n contextInfo?: ContextInfo;\n}\n\nexport interface Location {\n degreesLatitude?: number;\n degreesLongitude?: number;\n name?: string;\n}\n\n// Media message types\nexport interface ImageMessage {\n url?: string;\n mimetype?: string;\n caption?: string;\n fileSha256?: Uint8Array;\n fileLength?: number;\n height?: number;\n width?: number;\n mediaKey?: Uint8Array;\n fileEncSha256?: Uint8Array;\n interactiveAnnotations?: InteractiveAnnotation[];\n directPath?: string;\n mediaKeyTimestamp?: number;\n jpegThumbnail?: Uint8Array;\n contextInfo?: ContextInfo;\n firstScanSidecar?: Uint8Array;\n firstScanLength?: number;\n experimentGroupId?: number;\n scansSidecar?: Uint8Array;\n scanLengths?: number[];\n midQualityFileSha256?: Uint8Array;\n midQualityFileEncSha256?: Uint8Array;\n viewOnce?: boolean;\n thumbnailDirectPath?: string;\n thumbnailSha256?: Uint8Array;\n thumbnailEncSha256?: Uint8Array;\n staticUrl?: string;\n annotations?: InteractiveAnnotation[];\n originalFileName?: string;\n}\n\nexport interface VideoMessage {\n url?: string;\n mimetype?: string;\n fileSha256?: Uint8Array;\n fileLength?: number;\n seconds?: number;\n mediaKey?: Uint8Array;\n caption?: string;\n gifPlayback?: boolean;\n height?: number;\n width?: number;\n fileEncSha256?: Uint8Array;\n interactiveAnnotations?: InteractiveAnnotation[];\n directPath?: string;\n mediaKeyTimestamp?: number;\n jpegThumbnail?: Uint8Array;\n contextInfo?: ContextInfo;\n streamingSidecar?: Uint8Array;\n gifAttribution?: VideoAttribution;\n viewOnce?: boolean;\n thumbnailDirectPath?: string;\n thumbnailSha256?: Uint8Array;\n thumbnailEncSha256?: Uint8Array;\n staticUrl?: string;\n annotations?: InteractiveAnnotation[];\n accessibilityLabel?: string;\n processedVideos?: ProcessedVideo[];\n externalShareFullVideoDurationInSeconds?: number;\n motionPhotoPresentationOffsetMS?: number;\n metadataUrl?: string;\n videoSourceType?: VideoSourceType;\n}\n\nexport enum VideoAttribution {\n NONE = 0,\n GIPHY = 1,\n TENOR = 2,\n KLIPY = 3,\n}\n\nexport enum VideoSourceType {\n USER_VIDEO = 0,\n AI_GENERATED = 1,\n}\n\nexport interface ProcessedVideo {\n url?: string;\n fileLength?: number;\n fileSha256?: Uint8Array;\n fileEncSha256?: Uint8Array;\n}\n\nexport interface AudioMessage {\n url?: string;\n mimetype?: string;\n fileSha256?: Uint8Array;\n fileLength?: number;\n seconds?: number;\n ptt?: boolean;\n mediaKey?: Uint8Array;\n fileEncSha256?: Uint8Array;\n directPath?: string;\n mediaKeyTimestamp?: number;\n contextInfo?: ContextInfo;\n streamingSidecar?: Uint8Array;\n waveform?: Uint8Array;\n backgroundArgb?: number;\n viewOnce?: boolean;\n}\n\nexport interface DocumentMessage {\n url?: string;\n mimetype?: string;\n title?: string;\n fileSha256?: Uint8Array;\n fileLength?: number;\n pageCount?: number;\n mediaKey?: Uint8Array;\n fileName?: string;\n fileEncSha256?: Uint8Array;\n directPath?: string;\n mediaKeyTimestamp?: number;\n contactVcard?: boolean;\n thumbnailDirectPath?: string;\n thumbnailSha256?: Uint8Array;\n thumbnailEncSha256?: Uint8Array;\n jpegThumbnail?: Uint8Array;\n contextInfo?: ContextInfo;\n thumbnailHeight?: number;\n thumbnailWidth?: number;\n caption?: string;\n}\n\nexport interface StickerMessage {\n url?: string;\n fileSha256?: Uint8Array;\n fileEncSha256?: Uint8Array;\n mediaKey?: Uint8Array;\n mimetype?: string;\n height?: number;\n width?: number;\n directPath?: string;\n fileLength?: number;\n mediaKeyTimestamp?: number;\n firstFrameLength?: number;\n firstFrameSidecar?: Uint8Array;\n isAnimated?: boolean;\n pngThumbnail?: Uint8Array;\n contextInfo?: ContextInfo;\n stickerSentTs?: number;\n isAvatar?: boolean;\n isAiSticker?: boolean;\n isLottie?: boolean;\n}\n\n// Contact message types\nexport interface ContactMessage {\n displayName?: string;\n vcard?: string;\n contextInfo?: ContextInfo;\n}\n\nexport interface ContactsArrayMessage {\n displayName?: string;\n contacts?: ContactMessage[];\n contextInfo?: ContextInfo;\n}\n\n// Text and extended text messages\nexport interface ExtendedTextMessage {\n text?: string;\n matchedText?: string;\n canonicalUrl?: string;\n description?: string;\n title?: string;\n textArgb?: number;\n backgroundArgb?: number;\n font?: ExtendedTextMessageFontType;\n previewType?: ExtendedTextMessagePreviewType;\n jpegThumbnail?: Uint8Array;\n contextInfo?: ContextInfo;\n doNotPlayInline?: boolean;\n thumbnailDirectPath?: string;\n thumbnailSha256?: Uint8Array;\n thumbnailEncSha256?: Uint8Array;\n mediaKey?: Uint8Array;\n mediaKeyTimestamp?: number;\n thumbnailHeight?: number;\n thumbnailWidth?: number;\n inviteLinkGroupType?: ExtendedTextMessageInviteLinkGroupType;\n inviteLinkParentGroupSubject?: string;\n inviteLinkParentGroupThumbnailJpeg?: Uint8Array;\n inviteLinkGroupTypeV2?: InviteLinkGroupType;\n viewOnce?: boolean;\n}\n\nexport enum ExtendedTextMessageFontType {\n SANS_SERIF = 0,\n SERIF = 1,\n NORICAN_REGULAR = 2,\n BRYNDAN_WRITE = 3,\n BEBASNEUE_REGULAR = 4,\n OSWALD_HEAVY = 5,\n}\n\nexport enum ExtendedTextMessagePreviewType {\n NONE = 0,\n VIDEO = 1,\n PLACEHOLDER = 4,\n IMAGE = 5,\n}\n\nexport enum ExtendedTextMessageInviteLinkGroupType {\n DEFAULT = 0,\n PARENT = 1,\n SUB = 2,\n DEFAULT_SUB = 3,\n}\n\nexport enum InviteLinkGroupType {\n DEFAULT = 0,\n PARENT = 1,\n SUB = 2,\n DEFAULT_SUB = 3,\n}\n\n// Interactive messages\nexport interface ButtonsMessage {\n contentText?: string;\n footerText?: string;\n contextInfo?: ContextInfo;\n buttons?: Button[];\n headerType?: ButtonsMessageHeaderType;\n text?: string;\n documentMessage?: DocumentMessage;\n imageMessage?: ImageMessage;\n videoMessage?: VideoMessage;\n locationMessage?: LocationMessage;\n}\n\nexport interface Button {\n buttonId?: string;\n buttonText?: ButtonText;\n type?: ButtonType;\n nativeFlowInfo?: NativeFlowInfo;\n}\n\nexport interface ButtonText {\n displayText?: string;\n}\n\nexport enum ButtonType {\n UNKNOWN = 0,\n RESPONSE = 1,\n NATIVE_FLOW = 2,\n}\n\nexport interface NativeFlowInfo {\n name?: string;\n paramsJson?: string;\n}\n\nexport enum ButtonsMessageHeaderType {\n UNKNOWN = 0,\n EMPTY = 1,\n TEXT = 2,\n DOCUMENT = 3,\n IMAGE = 4,\n VIDEO = 5,\n LOCATION = 6,\n}\n\nexport interface ListMessage {\n title?: string;\n description?: string;\n buttonText?: string;\n listType?: ListMessageListType;\n sections?: Section[];\n productListInfo?: ProductListInfo;\n footerText?: string;\n contextInfo?: ContextInfo;\n}\n\nexport interface Section {\n title?: string;\n rows?: Row[];\n}\n\nexport interface Row {\n title?: string;\n description?: string;\n rowId?: string;\n}\n\nexport interface ProductListInfo {\n productSections?: ProductSection[];\n headerImage?: ImageMessage;\n businessOwnerJid?: string;\n}\n\nexport interface ProductSection {\n title?: string;\n products?: ProductListItem[];\n}\n\nexport interface ProductListItem {\n productId?: string;\n}\n\nexport enum ListMessageListType {\n UNKNOWN = 0,\n SINGLE_SELECT = 1,\n PRODUCT_LIST = 2,\n}\n\n// Template and interactive response messages\nexport interface TemplateMessage {\n contextInfo?: ContextInfo;\n hydratedTemplate?: HydratedFourRowTemplate;\n templateId?: string;\n documentMessage?: DocumentMessage;\n imageMessage?: ImageMessage;\n videoMessage?: VideoMessage;\n locationMessage?: LocationMessage;\n}\n\nexport interface HydratedFourRowTemplate {\n documentMessage?: DocumentMessage;\n imageMessage?: ImageMessage;\n videoMessage?: VideoMessage;\n locationMessage?: LocationMessage;\n title?: string;\n hydratedContentText?: string;\n hydratedFooterText?: string;\n hydratedButtons?: HydratedTemplateButton[];\n templateId?: string;\n mask?: string;\n}\n\nexport interface HydratedTemplateButton {\n index?: number;\n quickReplyButton?: HydratedQuickReplyButton;\n urlButton?: HydratedURLButton;\n callButton?: HydratedCallButton;\n}\n\nexport interface HydratedQuickReplyButton {\n displayText?: string;\n id?: string;\n}\n\nexport interface HydratedURLButton {\n displayText?: string;\n url?: string;\n}\n\nexport interface HydratedCallButton {\n displayText?: string;\n phoneNumber?: string;\n}\n\n// Response messages\nexport interface ButtonsResponseMessage {\n selectedButtonId?: string;\n contextInfo?: ContextInfo;\n type?: ButtonsResponseMessageType;\n selectedDisplayText?: string;\n}\n\nexport enum ButtonsResponseMessageType {\n UNKNOWN = 0,\n DISPLAY_TEXT = 1,\n}\n\nexport interface ListResponseMessage {\n title?: string;\n listType?: ListResponseMessageListType;\n singleSelectReply?: SingleSelectReply;\n contextInfo?: ContextInfo;\n description?: string;\n}\n\nexport interface SingleSelectReply {\n selectedRowId?: string;\n}\n\nexport enum ListResponseMessageListType {\n UNKNOWN = 0,\n SINGLE_SELECT = 1,\n}\n\n// Payment and order messages\nexport interface SendPaymentMessage {\n noteMessage?: Message;\n requestMessageKey?: MessageKey;\n background?: PaymentBackground;\n}\n\nexport interface PaymentBackground {\n id?: string;\n fileEncSha256?: Uint8Array;\n directPath?: string;\n mediaKey?: Uint8Array;\n type?: PaymentBackgroundType;\n mediaKeyTimestamp?: number;\n}\n\nexport enum PaymentBackgroundType {\n UNKNOWN = 0,\n DEFAULT = 1,\n}\n\nexport interface RequestPaymentMessage {\n noteMessage?: Message;\n currencyCodeIso4217?: string;\n amount1000?: number;\n requestFrom?: string;\n expiryTimestamp?: number;\n background?: PaymentBackground;\n}\n\nexport interface DeclinePaymentRequestMessage {\n key?: MessageKey;\n}\n\nexport interface CancelPaymentRequestMessage {\n key?: MessageKey;\n}\n\n// Group invite message\nexport interface GroupInviteMessage {\n groupJid?: string;\n inviteCode?: string;\n inviteExpiration?: number;\n groupName?: string;\n jpegThumbnail?: Uint8Array;\n caption?: string;\n contextInfo?: ContextInfo;\n}\n\n// Poll message\nexport interface PollCreationMessage {\n name?: string;\n options?: PollOption[];\n selectableOptionsCount?: number;\n contextInfo?: ContextInfo;\n}\n\nexport interface PollOption {\n optionName?: string;\n}\n\nexport interface PollUpdateMessage {\n pollCreationMessageKey?: MessageKey;\n vote?: PollEncValue;\n metadata?: PollUpdateMetadata;\n senderTimestampMs?: number;\n}\n\nexport interface PollEncValue {\n encPayload?: Uint8Array;\n encIv?: Uint8Array;\n}\n\nexport interface PollUpdateMetadata {\n // Metadata about the poll update\n}\n\n// Chat and conversation messages\nexport interface Chat {\n displayName?: string;\n id?: string;\n}\n\nexport interface Call {\n callKey?: Uint8Array;\n conversionSource?: string;\n conversionData?: Uint8Array;\n conversionDelaySeconds?: number;\n}\n\n// Main Message union type\nexport interface Message {\n // Text messages\n conversation?: string;\n extendedTextMessage?: ExtendedTextMessage;\n\n // Media messages\n imageMessage?: ImageMessage;\n videoMessage?: VideoMessage;\n audioMessage?: AudioMessage;\n documentMessage?: DocumentMessage;\n stickerMessage?: StickerMessage;\n\n // Location messages\n locationMessage?: LocationMessage;\n liveLocationMessage?: LiveLocationMessage;\n\n // Contact messages\n contactMessage?: ContactMessage;\n contactsArrayMessage?: ContactsArrayMessage;\n\n // Interactive messages\n buttonsMessage?: ButtonsMessage;\n listMessage?: ListMessage;\n templateMessage?: TemplateMessage;\n\n // Response messages\n buttonsResponseMessage?: ButtonsResponseMessage;\n listResponseMessage?: ListResponseMessage;\n\n // Payment messages\n sendPaymentMessage?: SendPaymentMessage;\n requestPaymentMessage?: RequestPaymentMessage;\n declinePaymentRequestMessage?: DeclinePaymentRequestMessage;\n cancelPaymentRequestMessage?: CancelPaymentRequestMessage;\n\n // Group messages\n groupInviteMessage?: GroupInviteMessage;\n\n // Poll messages\n pollCreationMessage?: PollCreationMessage;\n pollUpdateMessage?: PollUpdateMessage;\n\n // System messages\n protocolMessage?: ProtocolMessage;\n ephemeralMessage?: EphemeralMessage;\n viewOnceMessage?: ViewOnceMessage;\n reactionMessage?: ReactionMessage;\n stickerSyncRmrMessage?: StickerSyncRmrMessage;\n\n // Call messages\n call?: Call;\n chat?: Chat;\n\n // MessageContextInfo\n messageContextInfo?: MessageContextInfo;\n}\n\n// System and protocol messages\nexport interface ProtocolMessage {\n key?: MessageKey;\n type?: ProtocolMessageType;\n ephemeralExpiration?: number;\n ephemeralSettingTimestamp?: number;\n historySyncNotification?: HistorySyncNotification;\n appStateSyncKeyShare?: AppStateSyncKeyShare;\n appStateSyncKeyRequest?: AppStateSyncKeyRequest;\n initialSecurityNotificationSettingSync?: InitialSecurityNotificationSettingSync;\n appStateFatalExceptionNotification?: AppStateFatalExceptionNotification;\n disappearingMode?: DisappearingMode;\n editedMessage?: Message;\n timestampMs?: number;\n peerDataOperationRequestMessage?: PeerDataOperationRequestMessage;\n peerDataOperationRequestResponseMessage?: PeerDataOperationRequestResponseMessage;\n}\n\nexport enum ProtocolMessageType {\n REVOKE = 0,\n EPHEMERAL_SETTING = 3,\n EPHEMERAL_SYNC_RESPONSE = 4,\n HISTORY_SYNC_NOTIFICATION = 5,\n APP_STATE_SYNC_KEY_SHARE = 6,\n APP_STATE_SYNC_KEY_REQUEST = 7,\n MSG_FANOUT_BACKFILL_REQUEST = 8,\n INITIAL_SECURITY_NOTIFICATION_SETTING_SYNC = 9,\n APP_STATE_FATAL_EXCEPTION_NOTIFICATION = 10,\n SHARE_PHONE_NUMBER = 11,\n MESSAGE_EDIT = 14,\n PEER_DATA_OPERATION_REQUEST_MESSAGE = 16,\n PEER_DATA_OPERATION_REQUEST_RESPONSE_MESSAGE = 17,\n}\n\nexport interface EphemeralMessage {\n message?: Message;\n}\n\nexport interface ViewOnceMessage {\n message?: Message;\n}\n\nexport interface ReactionMessage {\n key?: MessageKey;\n text?: string;\n groupingKey?: string;\n senderTimestampMs?: number;\n unread?: boolean;\n}\n\nexport interface StickerSyncRmrMessage {\n filehash?: string[];\n rmrSource?: string;\n requestTimestamp?: number;\n}\n\nexport interface MessageContextInfo {\n deviceListMetadata?: DeviceListMetadata;\n deviceListMetadataVersion?: number;\n messageSecret?: Uint8Array;\n paddingBytes?: Uint8Array;\n messageAddOnDurationInSecs?: number;\n botMessageInvoker?: BotMessageInvoker;\n botResponseCorrelationId?: string;\n botPluginType?: BotPluginType;\n botPluginReferenceIndex?: number;\n botPluginSearchProvider?: BotPluginSearchProvider;\n botPluginSearchUrl?: string;\n botPluginMaybeParentPluginType?: BotPluginType;\n botReelPluginThumbnailCdnUrl?: string;\n expiredBotResponseCorrelationId?: string;\n}\n\nexport interface DeviceListMetadata {\n senderKeyHash?: Uint8Array;\n senderTimestamp?: number;\n senderKeyIndexes?: number[];\n recipientKeyHash?: Uint8Array;\n recipientTimestamp?: number;\n recipientKeyIndexes?: number[];\n}\n\nexport interface BotMessageInvoker {\n // Bot message invoker details\n}\n\nexport enum BotPluginType {\n REELS = 0,\n SEARCH = 1,\n}\n\nexport enum BotPluginSearchProvider {\n BING = 0,\n GOOGLE = 1,\n}\n\n// Additional system notification types\nexport interface HistorySyncNotification {\n fileSha256?: Uint8Array;\n fileLength?: number;\n mediaKey?: Uint8Array;\n fileEncSha256?: Uint8Array;\n directPath?: string;\n syncType?: HistorySyncNotificationHistorySyncType;\n chunkOrder?: number;\n originalMessageId?: string;\n progress?: number;\n oldestMsgInChunkTimestampSec?: number;\n initialHistBootstrapInlinePayload?: Uint8Array;\n peerDataRequestSessionId?: string;\n}\n\nexport enum HistorySyncNotificationHistorySyncType {\n INITIAL_BOOTSTRAP = 0,\n INITIAL_STATUS_V3 = 1,\n FULL = 2,\n RECENT = 3,\n PUSH_NAME = 4,\n NON_BLOCKING_DATA = 5,\n ON_DEMAND = 6,\n}\n\nexport interface AppStateSyncKeyShare {\n keys?: AppStateSyncKey[];\n}\n\nexport interface AppStateSyncKey {\n keyId?: AppStateSyncKeyId;\n keyData?: AppStateSyncKeyData;\n}\n\nexport interface AppStateSyncKeyId {\n keyId?: Uint8Array;\n}\n\nexport interface AppStateSyncKeyData {\n keyData?: Uint8Array;\n fingerprint?: AppStateSyncKeyFingerprint;\n timestamp?: number;\n}\n\nexport interface AppStateSyncKeyFingerprint {\n rawId?: number;\n currentIndex?: number;\n deviceIndexes?: number[];\n}\n\nexport interface AppStateSyncKeyRequest {\n keyIds?: AppStateSyncKeyId[];\n}\n\nexport interface InitialSecurityNotificationSettingSync {\n securityNotificationEnabled?: boolean;\n}\n\nexport interface AppStateFatalExceptionNotification {\n collectionNames?: string[];\n timestamp?: number;\n}\n\nexport interface PeerDataOperationRequestMessage {\n peerDataOperationRequestType?: PeerDataOperationRequestType;\n requestId?: string;\n}\n\nexport interface PeerDataOperationRequestResponseMessage {\n peerDataOperationResult?: PeerDataOperationRequestResponseMessagePeerDataOperationResult;\n stanzaId?: string;\n}\n\nexport enum PeerDataOperationRequestType {\n UPLOAD_STICKER = 0,\n SEND_RECENT_STICKER_BOOTSTRAP = 1,\n GENERATE_LINK_PREVIEW = 2,\n}\n\nexport enum PeerDataOperationRequestResponseMessagePeerDataOperationResult {\n SUCCESS = 0,\n NOT_AUTHORIZED = 1,\n NOT_FOUND = 2,\n THROTTLED = 3,\n UNKNOWN_ERROR = 4,\n}\n\n// Helper type to get the active message type\nexport type MessageContent =\n | { type: \"text\"; content: string }\n | { type: \"extendedText\"; content: ExtendedTextMessage }\n | { type: \"image\"; content: ImageMessage }\n | { type: \"video\"; content: VideoMessage }\n | { type: \"audio\"; content: AudioMessage }\n | { type: \"document\"; content: DocumentMessage }\n | { type: \"sticker\"; content: StickerMessage }\n | { type: \"location\"; content: LocationMessage }\n | { type: \"liveLocation\"; content: LiveLocationMessage }\n | { type: \"contact\"; content: ContactMessage }\n | { type: \"contactsArray\"; content: ContactsArrayMessage }\n | { type: \"buttons\"; content: ButtonsMessage }\n | { type: \"list\"; content: ListMessage }\n | { type: \"template\"; content: TemplateMessage }\n | { type: \"buttonsResponse\"; content: ButtonsResponseMessage }\n | { type: \"listResponse\"; content: ListResponseMessage }\n | { type: \"groupInvite\"; content: GroupInviteMessage }\n | { type: \"poll\"; content: PollCreationMessage }\n | { type: \"pollUpdate\"; content: PollUpdateMessage }\n | { type: \"reaction\"; content: ReactionMessage }\n | { type: \"protocol\"; content: ProtocolMessage }\n | { type: \"ephemeral\"; content: EphemeralMessage }\n | { type: \"viewOnce\"; content: ViewOnceMessage };\n\n// Utility function to extract message content and type\nexport function getMessageContent(message: Message): MessageContent | null {\n if (message.conversation) {\n return { type: \"text\", content: message.conversation };\n }\n if (message.extendedTextMessage) {\n return { type: \"extendedText\", content: message.extendedTextMessage };\n }\n if (message.imageMessage) {\n return { type: \"image\", content: message.imageMessage };\n }\n if (message.videoMessage) {\n return { type: \"video\", content: message.videoMessage };\n }\n if (message.audioMessage) {\n return { type: \"audio\", content: message.audioMessage };\n }\n if (message.documentMessage) {\n return { type: \"document\", content: message.documentMessage };\n }\n if (message.stickerMessage) {\n return { type: \"sticker\", content: message.stickerMessage };\n }\n if (message.locationMessage) {\n return { type: \"location\", content: message.locationMessage };\n }\n if (message.liveLocationMessage) {\n return { type: \"liveLocation\", content: message.liveLocationMessage };\n }\n if (message.contactMessage) {\n return { type: \"contact\", content: message.contactMessage };\n }\n if (message.contactsArrayMessage) {\n return { type: \"contactsArray\", content: message.contactsArrayMessage };\n }\n if (message.buttonsMessage) {\n return { type: \"buttons\", content: message.buttonsMessage };\n }\n if (message.listMessage) {\n return { type: \"list\", content: message.listMessage };\n }\n if (message.templateMessage) {\n return { type: \"template\", content: message.templateMessage };\n }\n if (message.buttonsResponseMessage) {\n return { type: \"buttonsResponse\", content: message.buttonsResponseMessage };\n }\n if (message.listResponseMessage) {\n return { type: \"listResponse\", content: message.listResponseMessage };\n }\n if (message.groupInviteMessage) {\n return { type: \"groupInvite\", content: message.groupInviteMessage };\n }\n if (message.pollCreationMessage) {\n return { type: \"poll\", content: message.pollCreationMessage };\n }\n if (message.pollUpdateMessage) {\n return { type: \"pollUpdate\", content: message.pollUpdateMessage };\n }\n if (message.reactionMessage) {\n return { type: \"reaction\", content: message.reactionMessage };\n }\n if (message.protocolMessage) {\n return { type: \"protocol\", content: message.protocolMessage };\n }\n if (message.ephemeralMessage) {\n return { type: \"ephemeral\", content: message.ephemeralMessage };\n }\n if (message.viewOnceMessage) {\n return { type: \"viewOnce\", content: message.viewOnceMessage };\n }\n\n return null;\n}\n","// WhatsApp events types based on whatsmeow package\n// Reference: https://pkg.go.dev/go.mau.fi/whatsmeow@v0.0.0-20250829123043-72d2ed58e998/types/events\n\nimport { Message } from \"./message.js\";\n\n// Additional specific types from whatsmeow\nexport interface WaBinaryNode {\n Tag: string;\n Attrs: Record<string, string>;\n Content: unknown;\n}\n\nexport interface SyncAction {\n timestamp: Date;\n action: unknown;\n}\n\nexport interface StarAction extends SyncAction {\n starred: boolean;\n}\n\nexport interface ArchiveAction extends SyncAction {\n archived: boolean;\n}\n\nexport interface ClearChatAction extends SyncAction {\n messageRange?: {\n lastMessageTimestamp?: Date;\n lastSystemMessageTimestamp?: Date;\n };\n}\n\nexport interface DeleteChatAction extends SyncAction {}\n\nexport interface DeleteMessageForMeAction extends SyncAction {}\n\nexport interface MarkChatAsReadAction extends SyncAction {\n read: boolean;\n messageRange?: {\n lastMessageTimestamp?: Date;\n lastSystemMessageTimestamp?: Date;\n };\n}\n\nexport interface MuteAction extends SyncAction {\n muted: boolean;\n muteEndTimestamp?: Date;\n}\n\nexport interface PinAction extends SyncAction {\n pinned: boolean;\n}\n\nexport interface PushNameSettingAction extends SyncAction {\n name: string;\n}\n\nexport interface UnarchiveChatsSettingAction extends SyncAction {\n unarchiveChats: boolean;\n}\n\nexport interface LabelAssociationAction extends SyncAction {\n labeled: boolean;\n}\n\nexport interface LabelEditAction extends SyncAction {\n name: string;\n color: number;\n predefinedId?: string;\n deleted: boolean;\n}\n\nexport interface BusinessNameAction extends SyncAction {\n businessName: string;\n verified: number;\n}\n\nexport interface UserStatusMuteAction extends SyncAction {\n muted: boolean;\n}\n\nexport interface Armadillo {\n payload?: unknown;\n}\n\nexport interface ConsumerApplication {\n metadata?: unknown;\n}\n\nexport interface BasicCallMeta {\n from: JID;\n timestamp: Date;\n callId: string;\n callCreator: JID;\n}\n\nexport interface CallRemoteMeta {\n remoteJid: JID;\n fromMe: boolean;\n}\n\nexport interface EventGroupParticipant {\n JID: JID;\n IsAdmin: boolean;\n IsSuperAdmin: boolean;\n}\n\nexport interface HistorySyncData {\n conversations?: unknown[];\n messages?: unknown[];\n}\n\n// Common types used in events\nexport interface JID {\n User: string;\n Agent: number;\n Device: number;\n Integrator: number;\n Server: string;\n AD: boolean;\n}\n\nexport interface MessageInfo {\n ID: string;\n Type: string;\n PushName: string;\n Timestamp: Date;\n Source: MessageSource;\n DeviceSentMeta?: DeviceSentMeta;\n ServerID?: number;\n Status?: MessageStatus;\n}\n\nexport interface MessageSource {\n Chat: JID;\n Sender: JID;\n IsFromMe: boolean;\n IsGroup: boolean;\n BroadcastListOwner?: JID;\n}\n\nexport interface DeviceSentMeta {\n DestinationJID: string;\n Phash: string;\n}\n\nexport enum MessageStatus {\n ERROR = \"ERROR\",\n PENDING = \"PENDING\",\n SERVER_ACK = \"SERVER_ACK\",\n DELIVERY_ACK = \"DELIVERY_ACK\",\n READ = \"READ\",\n PLAYED = \"PLAYED\",\n}\n\nexport enum ReceiptType {\n UNKNOWN = \"\",\n DELIVERY = \"delivery\",\n READ = \"read\",\n READ_SELF = \"read-self\",\n PLAYED = \"played\",\n SENDER = \"sender\",\n INACTIVE = \"inactive\",\n PEER_MSG = \"peer_msg\",\n}\n\nexport enum DecryptFailMode {\n UNAVAILABLE = \"unavailable\",\n DECRYPT_FAIL = \"decrypt_fail\",\n}\n\nexport enum UnavailableType {\n UNKNOWN = \"\",\n VIEW_ONCE = \"view_once\",\n}\n\nexport enum ConnectFailureReason {\n SOCKET_OPEN_TIMEOUT = 4001,\n SOCKET_PING_TIMEOUT = 4002,\n SOCKET_PONG_TIMEOUT = 4003,\n UNKNOWN_LOGOUT = 4004,\n BAD_MAC = 4005,\n INIT_TIMEOUT = 4006,\n MULTI_DEVICE_MISMATCH = 4007,\n MULTI_DEVICE_DISABLED = 4008,\n TEMP_BANNED = 4009,\n CLIENT_OUTDATED = 4010,\n STREAM_ERROR = 4011,\n DEVICE_GONE = 4012,\n IDENTITY_MISSING = 4013,\n RATE_LIMIT_HIT = 4014,\n MAIN_DEVICE_GONE = 4015,\n}\n\nexport enum TempBanReason {\n SENT_TO_TOO_MANY_PEOPLE = 101,\n BLOCKED_BY_USERS = 102,\n CREATED_TOO_MANY_GROUPS = 103,\n SENT_TOO_MANY_SAME_MESSAGE = 104,\n BROADCAST_LIST = 106,\n}\n\n// Event types\nexport interface AppState {\n name: string;\n version: number;\n hash: string[];\n}\n\nexport interface AppStateSyncComplete {\n name: string;\n}\n\nexport interface Archive {\n JID: JID;\n Timestamp: Date;\n Action: ArchiveAction;\n FromFullSync: boolean;\n}\n\nexport interface Blocklist {\n JID: JID;\n action: string;\n dhash: string;\n}\n\nexport interface BlocklistAction {\n action: string;\n}\n\nexport interface BlocklistChange {\n JID: JID;\n action: BlocklistChangeAction;\n}\n\nexport interface BlocklistChangeAction {\n action: string;\n}\n\nexport interface BusinessName {\n BusinessJID: JID;\n PushName: string;\n VerifiedName: string;\n VerifiedLevel: string;\n Action: BusinessNameAction;\n FromFullSync: boolean;\n}\n\nexport interface CATRefreshError {\n code: string;\n text: string;\n}\n\nexport interface CallAccept {\n BasicCallMeta: BasicCallMeta;\n}\n\nexport interface CallOffer {\n BasicCallMeta: BasicCallMeta;\n CallRemoteMeta: CallRemoteMeta;\n Data: string;\n}\n\nexport interface CallOfferNotice {\n BasicCallMeta: BasicCallMeta;\n Media: string;\n Type: string;\n Data: string;\n}\n\nexport interface CallPreAccept {\n BasicCallMeta: BasicCallMeta;\n CallRemoteMeta: CallRemoteMeta;\n}\n\nexport interface CallReject {\n BasicCallMeta: BasicCallMeta;\n}\n\nexport interface CallRelayLatency {\n BasicCallMeta: BasicCallMeta;\n Latency: number;\n}\n\nexport interface CallTerminate {\n BasicCallMeta: BasicCallMeta;\n Reason: string;\n}\n\nexport interface CallTransport {\n BasicCallMeta: BasicCallMeta;\n}\n\nexport interface ChatPresence {\n MessageSource: MessageSource;\n State: string;\n Media: string;\n}\n\nexport interface ClearChat {\n ChatJID: JID;\n Timestamp: Date;\n Action: ClearChatAction;\n FromFullSync: boolean;\n}\n\nexport interface ClientOutdated {\n // Event indicating the client version is outdated\n}\n\nexport interface ConnectFailure {\n Reason: ConnectFailureReason;\n Raw: WaBinaryNode;\n}\n\nexport interface Connected {\n // Event indicating successful connection\n}\n\nexport interface EventContact {\n JID: JID;\n Found: boolean;\n FirstName: string;\n FullName: string;\n PushName: string;\n BusinessName: string;\n}\n\nexport interface DeleteChat {\n ChatJID: JID;\n Timestamp: Date;\n Action: DeleteChatAction;\n FromFullSync: boolean;\n}\n\nexport interface DeleteForMe {\n ChatJID: JID;\n SenderJID: JID;\n IsFromMe: boolean;\n MessageID: string;\n Timestamp: Date;\n Action: DeleteMessageForMeAction;\n FromFullSync: boolean;\n}\n\nexport interface Disconnected {\n // Event indicating disconnection\n}\n\nexport interface FBMessage {\n Info: MessageInfo;\n IsEphemeral: boolean;\n IsViewOnce: boolean;\n IsDocumentWithCaption: boolean;\n IsEdit: boolean;\n Message: Armadillo;\n}\n\nexport interface EventGroupInfo {\n JID: JID;\n GroupName: string;\n GroupTopic: string;\n GroupLocked: boolean;\n GroupAnnounce: boolean;\n GroupEphemeral: boolean;\n GroupParent?: JID;\n GroupLinkedParent?: JID;\n GroupIsDefaultSub: boolean;\n GroupCreated: Date;\n ParticipantVersionID: string;\n Participants: EventGroupParticipant[];\n PendingParticipants: EventGroupParticipant[];\n JoinedAt: Date;\n CreateKey: string;\n Sender: JID;\n Timestamp: Date;\n}\n\nexport interface HistorySync {\n Data: HistorySyncData;\n}\n\nexport interface IdentityChange {\n JID: JID;\n Timestamp: Date;\n Implicit: boolean;\n}\n\nexport interface JoinedGroup {\n Reason: string;\n Type: string;\n CreateKey: string;\n Participants: EventGroupParticipant[];\n}\n\nexport interface KeepAliveRestored {\n // Event indicating keep-alive connection restored\n}\n\nexport interface KeepAliveTimeout {\n // Event indicating keep-alive timeout\n}\n\nexport interface LabelAssociationChat {\n ChatJID: JID;\n LabelID: string;\n Labeled: boolean;\n Timestamp: Date;\n Action: LabelAssociationAction;\n FromFullSync: boolean;\n}\n\nexport interface LabelAssociationMessage {\n ChatJID: JID;\n SenderJID: JID;\n IsFromMe: boolean;\n MessageID: string;\n LabelID: string;\n Labeled: boolean;\n Timestamp: Date;\n Action: LabelAssociationAction;\n FromFullSync: boolean;\n}\n\nexport interface LabelEdit {\n ID: string;\n Name: string;\n Color: number;\n Deleted: boolean;\n Timestamp: Date;\n Action: LabelEditAction;\n FromFullSync: boolean;\n}\n\nexport interface LoggedOut {\n OnConnect: boolean;\n Reason: string;\n}\n\nexport interface ManualLoginReconnect {\n // Event indicating manual login reconnection required\n}\n\nexport interface MarkChatAsRead {\n ChatJID: JID;\n Timestamp: Date;\n Action: MarkChatAsReadAction;\n FromFullSync: boolean;\n}\n\nexport interface MediaRetry {\n MessageID: string;\n ChatJID: JID;\n SenderJID: JID;\n IsFromMe: boolean;\n Timestamp: Date;\n}\n\nexport interface MediaRetryError {\n MessageID: string;\n ChatJID: JID;\n SenderJID: JID;\n IsFromMe: boolean;\n Timestamp: Date;\n Error: string;\n}\n\nexport interface MessageEvent {\n Info: MessageInfo;\n Message: Message;\n IsEphemeral: boolean;\n IsViewOnce: boolean;\n IsDocumentWithCaption: boolean;\n IsEdit: boolean;\n RawMessage: WaBinaryNode;\n}\n\nexport interface Mute {\n ChatJID: JID;\n Timestamp: Date;\n Action: MuteAction;\n FromFullSync: boolean;\n}\n\nexport interface NewsletterJoin {\n ID: JID;\n NewsletterMeta: {\n name: string;\n description?: string;\n invite?: string;\n creationTime?: Date;\n };\n}\n\nexport interface NewsletterLeave {\n ID: JID;\n}\n\nexport interface NewsletterLiveUpdate {\n ID: JID;\n Time: Date;\n Messages: unknown[];\n}\n\nexport interface NewsletterMessageMeta {\n ID: JID;\n MessageServerID: number;\n MessageID: string;\n ReactionCounts: Record<string, number>;\n Views: number;\n}\n\nexport interface NewsletterMuteChange {\n ID: JID;\n Mute: string;\n}\n\nexport interface OfflineSyncCompleted {\n Count: number;\n}\n\nexport interface OfflineSyncPreview {\n Messages: unknown[];\n IsLatest: boolean;\n}\n\nexport interface PairError {\n ID: string;\n Error: string;\n}\n\nexport interface PairSuccess {\n ID: string;\n BusinessName: string;\n Platform: string;\n}\n\nexport interface PermanentDisconnect {\n // Event indicating permanent disconnection\n}\n\nexport interface Picture {\n JID: JID;\n Author: JID;\n Timestamp: Date;\n Remove: boolean;\n NewPicture?: {\n id: string;\n type: string;\n directPath: string;\n };\n OldPicture?: {\n id: string;\n type: string;\n directPath: string;\n };\n}\n\nexport interface Pin {\n ChatJID: JID;\n SenderJID: JID;\n IsFromMe: boolean;\n MessageID: string;\n Timestamp: Date;\n Action: PinAction;\n FromFullSync: boolean;\n}\n\nexport interface Presence {\n From: JID;\n Unavailable: boolean;\n LastSeen: Date;\n}\n\nexport interface PrivacySettings {\n GroupAddChanged: boolean;\n LastSeenChanged: boolean;\n StatusChanged: boolean;\n ProfileChanged: boolean;\n ReadReceiptsChanged: boolean;\n OnlineChanged: boolean;\n CallAddChanged: boolean;\n}\n\nexport interface PushName {\n JID: JID;\n Message: MessageInfo;\n OldPushName: string;\n NewPushName: string;\n}\n\nexport interface PushNameSetting {\n Timestamp: Date;\n Action: PushNameSettingAction;\n FromFullSync: boolean;\n}\n\nexport interface QR {\n Codes: string[];\n}\n\nexport interface QRScannedWithoutMultidevice {\n // Event indicating QR was scanned but multidevice not enabled\n}\n\nexport interface Receipt {\n MessageSource: MessageSource;\n MessageIDs: string[];\n Timestamp: Date;\n Type: ReceiptType;\n MessageSender: JID;\n}\n\nexport interface Star {\n ChatJID: JID;\n SenderJID: JID;\n IsFromMe: boolean;\n MessageID: string;\n Timestamp: Date;\n Action: StarAction;\n FromFullSync: boolean;\n}\n\nexport interface StreamError {\n Code: string;\n Raw: WaBinaryNode;\n}\n\nexport interface StreamReplaced {\n // Event indicating stream was replaced by another connection\n}\n\nexport interface TemporaryBan {\n Code: TempBanReason;\n Expire: number; // Duration in seconds\n}\n\nexport interface UnarchiveChatsSetting {\n Timestamp: Date;\n Action: UnarchiveChatsSettingAction;\n FromFullSync: boolean;\n}\n\nexport interface UndecryptableMessage {\n Info: MessageInfo;\n IsUnavailable: boolean;\n UnavailableType: UnavailableType;\n DecryptFailMode: DecryptFailMode;\n}\n\nexport interface UnknownCallEvent {\n Node: WaBinaryNode;\n}\n\nexport interface UserAbout {\n JID: JID;\n Status: string;\n Timestamp: Date;\n}\n\nexport interface UserStatusMute {\n JID: JID;\n Timestamp: Date;\n Action: UserStatusMuteAction;\n FromFullSync: boolean;\n}\n\n// Union type for all possible events\nexport type WhatsAppEvent =\n | AppState\n | AppStateSyncComplete\n | Archive\n | Blocklist\n | BlocklistAction\n | BlocklistChange\n | BusinessName\n | CATRefreshError\n | CallAccept\n | CallOffer\n | CallOfferNotice\n | CallPreAccept\n | CallReject\n | CallRelayLatency\n | CallTerminate\n | CallTransport\n | ChatPresence\n | ClearChat\n | ClientOutdated\n | ConnectFailure\n | Connected\n | EventContact\n | DeleteChat\n | DeleteForMe\n | Disconnected\n | FBMessage\n | EventGroupInfo\n | HistorySync\n | IdentityChange\n | JoinedGroup\n | KeepAliveRestored\n | KeepAliveTimeout\n | LabelAssociationChat\n | LabelAssociationMessage\n | LabelEdit\n | LoggedOut\n | ManualLoginReconnect\n | MarkChatAsRead\n | MediaRetry\n | MediaRetryError\n | MessageEvent\n | Mute\n | NewsletterJoin\n | NewsletterLeave\n | NewsletterLiveUpdate\n | NewsletterMessageMeta\n | NewsletterMuteChange\n | OfflineSyncCompleted\n | OfflineSyncPreview\n | PairError\n | PairSuccess\n | PermanentDisconnect\n | Picture\n | Pin\n | Presence\n | PrivacySettings\n | PushName\n | PushNameSetting\n | QR\n | QRScannedWithoutMultidevice\n | Receipt\n | Star\n | StreamError\n | StreamReplaced\n | TemporaryBan\n | UnarchiveChatsSetting\n | UndecryptableMessage\n | UnknownCallEvent\n | UserAbout\n | UserStatusMute;\n\n// Event handler type\nexport type EventHandler<T extends WhatsAppEvent = WhatsAppEvent> = (\n event: T\n) => void | Promise<void>;\n\n// Event emitter interface\nexport interface EventEmitter {\n on<T extends WhatsAppEvent>(\n eventType: string,\n handler: EventHandler<T>\n ): void;\n off<T extends WhatsAppEvent>(\n eventType: string,\n handler: EventHandler<T>\n ): void;\n emit<T extends WhatsAppEvent>(eventType: string, event: T): void;\n}\n"],"names":["DisappearingModeInitiator","DisappearingModeTrigger","MediaType","VideoAttribution","VideoSourceType","ExtendedTextMessageFontType","ExtendedTextMessagePreviewType","ExtendedTextMessageInviteLinkGroupType","InviteLinkGroupType","ButtonType","ButtonsMessageHeaderType","ListMessageListType","ButtonsResponseMessageType","ListResponseMessageListType","PaymentBackgroundType","ProtocolMessageType","BotPluginType","BotPluginSearchProvider","HistorySyncNotificationHistorySyncType","PeerDataOperationRequestType","PeerDataOperationRequestResponseMessagePeerDataOperationResult","MessageStatus","ReceiptType","DecryptFailMode","UnavailableType","ConnectFailureReason","TempBanReason"],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import { BaseClient } from '../client.js';
2
+ import { User, CreateUserRequest, CreateUserResponse, DeleteUserResponse } from '../types/admin.js';
3
+ export declare class AdminModule extends BaseClient {
4
+ /**
5
+ * List all users
6
+ */
7
+ listUsers(): Promise<User[]>;
8
+ /**
9
+ * Add a new user
10
+ */
11
+ addUser(user: CreateUserRequest): Promise<CreateUserResponse>;
12
+ /**
13
+ * Delete a user by ID
14
+ */
15
+ deleteUser(id: number): Promise<DeleteUserResponse>;
16
+ }