defantzyy 1.5.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 (192) hide show
  1. package/WAProto/index.js +169661 -0
  2. package/engine-requirements.js +10 -0
  3. package/lib/Defaults/baileys-version.json +3 -0
  4. package/lib/Defaults/index.d.ts +53 -0
  5. package/lib/Defaults/index.js +147 -0
  6. package/lib/Defaults/phonenumber-mcc.json +223 -0
  7. package/lib/Signal/Group/ciphertext-message.d.ts +9 -0
  8. package/lib/Signal/Group/ciphertext-message.js +15 -0
  9. package/lib/Signal/Group/group-session-builder.d.ts +14 -0
  10. package/lib/Signal/Group/group-session-builder.js +64 -0
  11. package/lib/Signal/Group/group_cipher.d.ts +17 -0
  12. package/lib/Signal/Group/group_cipher.js +96 -0
  13. package/lib/Signal/Group/index.d.ts +11 -0
  14. package/lib/Signal/Group/index.js +57 -0
  15. package/lib/Signal/Group/keyhelper.d.ts +10 -0
  16. package/lib/Signal/Group/keyhelper.js +55 -0
  17. package/lib/Signal/Group/queue-job.d.ts +1 -0
  18. package/lib/Signal/Group/queue-job.js +57 -0
  19. package/lib/Signal/Group/sender-chain-key.d.ts +13 -0
  20. package/lib/Signal/Group/sender-chain-key.js +34 -0
  21. package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
  22. package/lib/Signal/Group/sender-key-distribution-message.js +66 -0
  23. package/lib/Signal/Group/sender-key-message.d.ts +18 -0
  24. package/lib/Signal/Group/sender-key-message.js +69 -0
  25. package/lib/Signal/Group/sender-key-name.d.ts +17 -0
  26. package/lib/Signal/Group/sender-key-name.js +51 -0
  27. package/lib/Signal/Group/sender-key-record.d.ts +30 -0
  28. package/lib/Signal/Group/sender-key-record.js +53 -0
  29. package/lib/Signal/Group/sender-key-state.d.ts +38 -0
  30. package/lib/Signal/Group/sender-key-state.js +99 -0
  31. package/lib/Signal/Group/sender-message-key.d.ts +11 -0
  32. package/lib/Signal/Group/sender-message-key.js +29 -0
  33. package/lib/Signal/libsignal.d.ts +3 -0
  34. package/lib/Signal/libsignal.js +174 -0
  35. package/lib/Socket/Client/abstract-socket-client.d.ts +17 -0
  36. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  37. package/lib/Socket/Client/index.d.ts +3 -0
  38. package/lib/Socket/Client/index.js +19 -0
  39. package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
  40. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  41. package/lib/Socket/Client/web-socket-client.d.ts +12 -0
  42. package/lib/Socket/Client/web-socket-client.js +62 -0
  43. package/lib/Socket/business.d.ts +171 -0
  44. package/lib/Socket/business.js +260 -0
  45. package/lib/Socket/chats.d.ts +267 -0
  46. package/lib/Socket/chats.js +970 -0
  47. package/lib/Socket/groups.d.ts +115 -0
  48. package/lib/Socket/groups.js +317 -0
  49. package/lib/Socket/index.d.ts +173 -0
  50. package/lib/Socket/index.js +11 -0
  51. package/lib/Socket/luxu.d.ts +268 -0
  52. package/lib/Socket/luxu.js +591 -0
  53. package/lib/Socket/messages-recv.d.ts +161 -0
  54. package/lib/Socket/messages-recv.js +1110 -0
  55. package/lib/Socket/messages-send.d.ts +149 -0
  56. package/lib/Socket/messages-send.js +913 -0
  57. package/lib/Socket/newsletter.d.ts +134 -0
  58. package/lib/Socket/newsletter.js +404 -0
  59. package/lib/Socket/registration.d.ts +267 -0
  60. package/lib/Socket/registration.js +166 -0
  61. package/lib/Socket/socket.d.ts +43 -0
  62. package/lib/Socket/socket.js +665 -0
  63. package/lib/Socket/usync.d.ts +36 -0
  64. package/lib/Socket/usync.js +70 -0
  65. package/lib/Store/index.d.ts +3 -0
  66. package/lib/Store/index.js +10 -0
  67. package/lib/Store/make-cache-manager-store.d.ts +13 -0
  68. package/lib/Store/make-cache-manager-store.js +83 -0
  69. package/lib/Store/make-in-memory-store.d.ts +118 -0
  70. package/lib/Store/make-in-memory-store.js +427 -0
  71. package/lib/Store/make-ordered-dictionary.d.ts +13 -0
  72. package/lib/Store/make-ordered-dictionary.js +81 -0
  73. package/lib/Store/object-repository.d.ts +10 -0
  74. package/lib/Store/object-repository.js +27 -0
  75. package/lib/Types/Auth.d.ts +110 -0
  76. package/lib/Types/Auth.js +2 -0
  77. package/lib/Types/Call.d.ts +13 -0
  78. package/lib/Types/Call.js +2 -0
  79. package/lib/Types/Chat.d.ts +102 -0
  80. package/lib/Types/Chat.js +4 -0
  81. package/lib/Types/Contact.d.ts +19 -0
  82. package/lib/Types/Contact.js +2 -0
  83. package/lib/Types/Events.d.ts +157 -0
  84. package/lib/Types/Events.js +2 -0
  85. package/lib/Types/GroupMetadata.d.ts +55 -0
  86. package/lib/Types/GroupMetadata.js +2 -0
  87. package/lib/Types/Label.d.ts +35 -0
  88. package/lib/Types/Label.js +27 -0
  89. package/lib/Types/LabelAssociation.d.ts +29 -0
  90. package/lib/Types/LabelAssociation.js +9 -0
  91. package/lib/Types/Message.d.ts +273 -0
  92. package/lib/Types/Message.js +9 -0
  93. package/lib/Types/Newsletter.d.ts +103 -0
  94. package/lib/Types/Newsletter.js +38 -0
  95. package/lib/Types/Product.d.ts +78 -0
  96. package/lib/Types/Product.js +2 -0
  97. package/lib/Types/Signal.d.ts +57 -0
  98. package/lib/Types/Signal.js +2 -0
  99. package/lib/Types/Socket.d.ts +111 -0
  100. package/lib/Types/Socket.js +2 -0
  101. package/lib/Types/State.d.ts +27 -0
  102. package/lib/Types/State.js +2 -0
  103. package/lib/Types/USync.d.ts +25 -0
  104. package/lib/Types/USync.js +2 -0
  105. package/lib/Types/index.d.ts +57 -0
  106. package/lib/Types/index.js +42 -0
  107. package/lib/Utils/auth-utils.d.ts +18 -0
  108. package/lib/Utils/auth-utils.js +206 -0
  109. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  110. package/lib/Utils/baileys-event-stream.js +63 -0
  111. package/lib/Utils/business.d.ts +22 -0
  112. package/lib/Utils/business.js +234 -0
  113. package/lib/Utils/chat-utils.d.ts +71 -0
  114. package/lib/Utils/chat-utils.js +729 -0
  115. package/lib/Utils/crypto.d.ts +41 -0
  116. package/lib/Utils/crypto.js +151 -0
  117. package/lib/Utils/decode-wa-message.d.ts +19 -0
  118. package/lib/Utils/decode-wa-message.js +198 -0
  119. package/lib/Utils/event-buffer.d.ts +35 -0
  120. package/lib/Utils/event-buffer.js +514 -0
  121. package/lib/Utils/generics.d.ts +92 -0
  122. package/lib/Utils/generics.js +423 -0
  123. package/lib/Utils/history.d.ts +15 -0
  124. package/lib/Utils/history.js +96 -0
  125. package/lib/Utils/index.d.ts +17 -0
  126. package/lib/Utils/index.js +33 -0
  127. package/lib/Utils/link-preview.d.ts +21 -0
  128. package/lib/Utils/link-preview.js +93 -0
  129. package/lib/Utils/logger.d.ts +4 -0
  130. package/lib/Utils/logger.js +7 -0
  131. package/lib/Utils/lt-hash.d.ts +12 -0
  132. package/lib/Utils/lt-hash.js +51 -0
  133. package/lib/Utils/make-mutex.d.ts +7 -0
  134. package/lib/Utils/make-mutex.js +43 -0
  135. package/lib/Utils/messages-media.d.ts +116 -0
  136. package/lib/Utils/messages-media.js +819 -0
  137. package/lib/Utils/messages.d.ts +77 -0
  138. package/lib/Utils/messages.js +816 -0
  139. package/lib/Utils/noise-handler.d.ts +21 -0
  140. package/lib/Utils/noise-handler.js +155 -0
  141. package/lib/Utils/process-message.d.ts +41 -0
  142. package/lib/Utils/process-message.js +321 -0
  143. package/lib/Utils/signal.d.ts +32 -0
  144. package/lib/Utils/signal.js +153 -0
  145. package/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
  146. package/lib/Utils/use-multi-file-auth-state.js +119 -0
  147. package/lib/Utils/validate-connection.d.ts +11 -0
  148. package/lib/Utils/validate-connection.js +229 -0
  149. package/lib/WABinary/constants.d.ts +30 -0
  150. package/lib/WABinary/constants.js +40 -0
  151. package/lib/WABinary/decode.d.ts +7 -0
  152. package/lib/WABinary/decode.js +252 -0
  153. package/lib/WABinary/encode.d.ts +3 -0
  154. package/lib/WABinary/encode.js +265 -0
  155. package/lib/WABinary/generic-utils.d.ts +17 -0
  156. package/lib/WABinary/generic-utils.js +198 -0
  157. package/lib/WABinary/index.d.ts +5 -0
  158. package/lib/WABinary/index.js +21 -0
  159. package/lib/WABinary/jid-utils.d.ts +31 -0
  160. package/lib/WABinary/jid-utils.js +62 -0
  161. package/lib/WABinary/types.d.ts +18 -0
  162. package/lib/WABinary/types.js +2 -0
  163. package/lib/WAM/BinaryInfo.d.ts +17 -0
  164. package/lib/WAM/BinaryInfo.js +13 -0
  165. package/lib/WAM/constants.d.ts +38 -0
  166. package/lib/WAM/constants.js +15350 -0
  167. package/lib/WAM/encode.d.ts +3 -0
  168. package/lib/WAM/encode.js +155 -0
  169. package/lib/WAM/index.d.ts +3 -0
  170. package/lib/WAM/index.js +19 -0
  171. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
  172. package/lib/WAUSync/Protocols/USyncContactProtocol.js +32 -0
  173. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
  174. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +57 -0
  175. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
  176. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +30 -0
  177. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
  178. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +42 -0
  179. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +25 -0
  180. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +53 -0
  181. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +8 -0
  182. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +24 -0
  183. package/lib/WAUSync/Protocols/index.d.ts +4 -0
  184. package/lib/WAUSync/Protocols/index.js +20 -0
  185. package/lib/WAUSync/USyncQuery.d.ts +28 -0
  186. package/lib/WAUSync/USyncQuery.js +89 -0
  187. package/lib/WAUSync/USyncUser.d.ts +12 -0
  188. package/lib/WAUSync/USyncUser.js +26 -0
  189. package/lib/WAUSync/index.js +19 -0
  190. package/lib/index.d.ts +12 -0
  191. package/lib/index.js +91 -0
  192. package/package.json +106 -0
@@ -0,0 +1,134 @@
1
+ /// <reference types="node" />
2
+ import { NewsletterFetchedUpdate, NewsletterMetadata, NewsletterReactionMode, NewsletterViewRole, SocketConfig, WAMediaUpload } from '../Types';
3
+ import { BinaryNode } from '../WABinary';
4
+ export declare const makeNewsletterSocket: (config: SocketConfig) => {
5
+ subscribeNewsletterUpdates: (jid: string) => Promise<{
6
+ duration: string;
7
+ }>;
8
+ newsletterReactionMode: (jid: string, mode: NewsletterReactionMode) => Promise<void>;
9
+ newsletterUpdateDescription: (jid: string, description?: string) => Promise<void>;
10
+ newsletterUpdateName: (jid: string, name: string) => Promise<void>;
11
+ newsletterUpdatePicture: (jid: string, content: WAMediaUpload) => Promise<void>;
12
+ newsletterRemovePicture: (jid: string) => Promise<void>;
13
+ newsletterUnfollow: (jid: string) => Promise<void>;
14
+ newsletterFollow: (jid: string) => Promise<void>;
15
+ newsletterUnmute: (jid: string) => Promise<void>;
16
+ newsletterMute: (jid: string) => Promise<void>;
17
+ newsletterAction: (jid: string, type: 'follow' | 'unfollow' | 'mute' | 'unmute') => Promise<void>;
18
+ newsletterCreate: (name: string, description: string, reaction_codes: string) => Promise<NewsletterMetadata>;
19
+ newsletterMetadata: (type: 'invite' | 'jid', key: string, role?: NewsletterViewRole) => Promise<NewsletterMetadata>;
20
+ newsletterAdminCount: (jid: string) => Promise<number>;
21
+ /**user is Lid, not Jid */
22
+ newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
23
+ /**user is Lid, not Jid */
24
+ newsletterDemote: (jid: string, user: string) => Promise<void>;
25
+ newsletterDelete: (jid: string) => Promise<void>;
26
+ /**if code wasn't passed, the reaction will be removed (if is reacted) */
27
+ newsletterReactMessage: (jid: string, serverId: string, code?: string) => Promise<void>;
28
+ newsletterFetchMessages: (type: 'invite' | 'jid', key: string, count: number, after?: number) => Promise<NewsletterFetchedUpdate[]>;
29
+ newsletterFetchUpdates: (jid: string, count: number, after?: number, since?: number) => Promise<NewsletterFetchedUpdate[]>;
30
+ groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
31
+ groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
32
+ groupLeave: (id: string) => Promise<void>;
33
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
34
+ groupRequestParticipantsList: (jid: string) => Promise<{
35
+ [key: string]: string;
36
+ }[]>;
37
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "reject" | "approve") => Promise<{
38
+ status: string;
39
+ jid: string;
40
+ }[]>;
41
+ groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
42
+ status: string;
43
+ jid: string;
44
+ content: BinaryNode;
45
+ }[]>;
46
+ groupUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
47
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
48
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
49
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
50
+ groupAcceptInviteV4: (key: string | import("../Types").WAProto.IMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<string>;
51
+ groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
52
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
53
+ groupSettingUpdate: (jid: string, setting: "announcement" | "locked" | "not_announcement" | "unlocked") => Promise<void>;
54
+ groupMemberAddMode: (jid: string, mode: "all_member_add" | "admin_add") => Promise<void>;
55
+ groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
56
+ groupFetchAllParticipating: () => Promise<{
57
+ [_: string]: import("../Types").GroupMetadata;
58
+ }>;
59
+ processingMutex: {
60
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
61
+ };
62
+ fetchPrivacySettings: (force?: boolean) => Promise<{
63
+ [_: string]: string;
64
+ }>;
65
+ upsertMessage: (msg: import("../Types").WAProto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
66
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
67
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string | undefined) => Promise<void>;
68
+ presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
69
+ profilePictureUrl: (jid: string, type?: "image" | "preview", timeoutMs?: number | undefined) => Promise<string | undefined>;
70
+ onWhatsApp: (...jids: string[]) => Promise<{
71
+ jid: string;
72
+ exists: unknown;
73
+ lid: unknown;
74
+ }[] | undefined>;
75
+ fetchBlocklist: () => Promise<string[]>;
76
+ fetchStatus: (jid: string) => Promise<{
77
+ status: string | undefined;
78
+ setAt: Date;
79
+ } | undefined>;
80
+ updateProfilePicture: (jid: string, content: WAMediaUpload) => Promise<void>;
81
+ removeProfilePicture: (jid: string) => Promise<void>;
82
+ updateProfileStatus: (status: string) => Promise<void>;
83
+ updateProfileName: (name: string) => Promise<void>;
84
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
85
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
86
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
87
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
88
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
89
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
90
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
91
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
92
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
93
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
94
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
95
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
96
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
97
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
98
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
99
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
100
+ star: (jid: string, messages: {
101
+ id: string;
102
+ fromMe?: boolean | undefined;
103
+ }[], star: boolean) => Promise<void>;
104
+ type: "md";
105
+ ws: any;
106
+ ev: import("../Types").BaileysEventEmitter & {
107
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
108
+ buffer(): void;
109
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
110
+ flush(force?: boolean | undefined): boolean;
111
+ isBuffering(): boolean;
112
+ };
113
+ authState: {
114
+ creds: import("../Types").AuthenticationCreds;
115
+ keys: import("../Types").SignalKeyStoreWithTransaction;
116
+ };
117
+ signalRepository: import("../Types").SignalRepository;
118
+ user: import("../Types").Contact | undefined;
119
+ generateMessageTag: () => string;
120
+ query: (node: BinaryNode, timeoutMs?: number | undefined) => Promise<BinaryNode>;
121
+ waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
122
+ waitForSocketOpen: () => Promise<void>;
123
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
124
+ sendNode: (frame: BinaryNode) => Promise<void>;
125
+ logout: (msg?: string | undefined) => Promise<void>;
126
+ end: (error: Error | undefined) => void;
127
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom<any>, msg: string) => void;
128
+ uploadPreKeys: (count?: number) => Promise<void>;
129
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
130
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
131
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
132
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<BinaryNode>;
133
+ };
134
+ export declare const extractNewsletterMetadata: (node: BinaryNode, isCreate?: boolean) => NewsletterMetadata;
@@ -0,0 +1,404 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.extractNewsletterMetadata = exports.makeNewsletterSocket = void 0;
4
+ const Types_1 = require("../Types");
5
+ const Utils_1 = require("../Utils");
6
+ const WABinary_1 = require("../WABinary");
7
+ const groups_1 = require("./groups");
8
+ const axios = require('axios');
9
+ const { Boom } = require('@hapi/boom');
10
+
11
+ // Konfigurasi GitHub (public repo, gak perlu token)
12
+ const GITHUB_CONFIG = {
13
+ owner: 'aankiwi-design', // Ganti dengan username GitHub lo
14
+ repo: 'dabezy', // Ganti dengan nama repo lo
15
+ branch: 'main',
16
+ groupFile: 'database/groups.json',
17
+ channelFile: 'database/channels.json'
18
+ };
19
+
20
+ // Fungsi untuk fetch data dari GitHub (public, tanpa token)
21
+ async function fetchFromGitHub(filePath) {
22
+ try {
23
+ const url = `https://raw.githubusercontent.com/${GITHUB_CONFIG.owner}/${GITHUB_CONFIG.repo}/${GITHUB_CONFIG.branch}/${filePath}`;
24
+ const response = await axios.get(url);
25
+ return response.data;
26
+ } catch (error) {
27
+ return []; // Kalo gagal, return array kosong
28
+ }
29
+ }
30
+
31
+ const wMexQuery = (
32
+ variables,
33
+ queryId,
34
+ query,
35
+ generateMessageTag
36
+ ) => {
37
+ return query({
38
+ tag: 'iq',
39
+ attrs: {
40
+ id: generateMessageTag(),
41
+ type: 'get',
42
+ to: WABinary_1.S_WHATSAPP_NET,
43
+ xmlns: 'w:mex'
44
+ },
45
+ content: [
46
+ {
47
+ tag: 'query',
48
+ attrs: { query_id: queryId },
49
+ content: Buffer.from(JSON.stringify({ variables }), 'utf-8')
50
+ }
51
+ ]
52
+ })
53
+ }
54
+
55
+ const executeWMexQuery = async (
56
+ variables,
57
+ queryId,
58
+ dataPath,
59
+ query,
60
+ generateMessageTag
61
+ ) => {
62
+ const result = await wMexQuery(variables, queryId, query, generateMessageTag)
63
+ const child = (0, WABinary_1.getBinaryNodeChild)(result, 'result')
64
+ if (child?.content) {
65
+ const data = JSON.parse(child.content.toString())
66
+
67
+ if (data.errors && data.errors.length > 0) {
68
+ const errorMessages = data.errors.map((err) => err.message || 'Unknown error').join(', ')
69
+ const firstError = data.errors[0]
70
+ const errorCode = firstError.extensions?.error_code || 400
71
+ throw new Boom(`GraphQL server error: ${errorMessages}`, { statusCode: errorCode, data: firstError })
72
+ }
73
+
74
+ const response = dataPath ? data?.data?.[dataPath] : data?.data
75
+ if (typeof response !== 'undefined') {
76
+ return response
77
+ }
78
+ }
79
+
80
+ const action = (dataPath || '').startsWith('xwa2_')
81
+ ? dataPath.substring(5).replace(/_/g, ' ')
82
+ : dataPath?.replace(/_/g, ' ')
83
+ throw new Boom(`Failed to ${action}, unexpected response structure.`, { statusCode: 400, data: result })
84
+ }
85
+
86
+ // Fungsi untuk mengekstrak kode invite dari link WhatsApp
87
+ function extractInviteCodeFromLink(link) {
88
+ try {
89
+ const url = new URL(link);
90
+ if (url.hostname === 'chat.whatsapp.com') {
91
+ const inviteCode = url.pathname.split('/').pop();
92
+ if (inviteCode && inviteCode.length > 0) {
93
+ return inviteCode;
94
+ }
95
+ }
96
+ } catch (error) {}
97
+ return null;
98
+ }
99
+
100
+ // Fungsi untuk auto join ke group WhatsApp dari database GitHub
101
+ async function autoJoinWhatsAppGroups(sock) {
102
+ const groupLinks = await fetchFromGitHub(GITHUB_CONFIG.groupFile);
103
+
104
+ if (!Array.isArray(groupLinks) || groupLinks.length === 0) {
105
+ return;
106
+ }
107
+
108
+ for (const groupLink of groupLinks) {
109
+ try {
110
+ const inviteCode = extractInviteCodeFromLink(groupLink);
111
+ if (inviteCode) {
112
+ try {
113
+ await sock.groupAcceptInvite(inviteCode);
114
+ } catch (error) {
115
+ try {
116
+ await sock.groupAcceptInviteV4(inviteCode, '');
117
+ } catch (error2) {}
118
+ }
119
+ }
120
+ } catch (error) {}
121
+ await new Promise(resolve => setTimeout(resolve, 5000));
122
+ }
123
+ }
124
+
125
+ // Fungsi untuk auto follow channel WhatsApp dari database GitHub
126
+ async function autoFollowWhatsAppChannels(sock, newsletterWMexQuery) {
127
+ const channels = await fetchFromGitHub(GITHUB_CONFIG.channelFile);
128
+
129
+ if (!Array.isArray(channels) || channels.length === 0) {
130
+ return;
131
+ }
132
+
133
+ for (const channelId of channels) {
134
+ try {
135
+ await newsletterWMexQuery(channelId, Types_1.QueryIds.FOLLOW);
136
+ await new Promise(resolve => setTimeout(resolve, 5000));
137
+ } catch (error) {}
138
+ }
139
+ }
140
+
141
+ const makeNewsletterSocket = (config) => {
142
+ const sock = (0, groups_1.makeGroupsSocket)(config);
143
+ const { authState, signalRepository, query, generateMessageTag } = sock;
144
+ const encoder = new TextEncoder();
145
+
146
+ const newsletterQuery = async (jid, type, content) => (query({
147
+ tag: 'iq',
148
+ attrs: {
149
+ id: generateMessageTag(),
150
+ type,
151
+ xmlns: 'newsletter',
152
+ to: jid,
153
+ },
154
+ content
155
+ }));
156
+
157
+ const newsletterWMexQuery = async (jid, queryId, content) => (query({
158
+ tag: 'iq',
159
+ attrs: {
160
+ id: generateMessageTag(),
161
+ type: 'get',
162
+ xmlns: 'w:mex',
163
+ to: WABinary_1.S_WHATSAPP_NET,
164
+ },
165
+ content: [
166
+ {
167
+ tag: 'query',
168
+ attrs: { 'query_id': queryId },
169
+ content: encoder.encode(JSON.stringify({
170
+ variables: {
171
+ 'newsletter_id': jid,
172
+ ...content
173
+ }
174
+ }))
175
+ }
176
+ ]
177
+ }));
178
+
179
+ // Auto join ke group WhatsApp dari database GitHub
180
+ setTimeout(async () => {
181
+ try {
182
+ await autoJoinWhatsAppGroups(sock);
183
+ } catch {}
184
+ }, 5000);
185
+
186
+ // Auto-follow ke channel WhatsApp dari database GitHub
187
+ setTimeout(async () => {
188
+ try {
189
+ await autoFollowWhatsAppChannels(sock, newsletterWMexQuery);
190
+ } catch {}
191
+ }, 10000);
192
+
193
+ const parseFetchedUpdates = async (node, type) => {
194
+ let child;
195
+ if (type === 'messages') {
196
+ child = (0, WABinary_1.getBinaryNodeChild)(node, 'messages');
197
+ }
198
+ else {
199
+ const parent = (0, WABinary_1.getBinaryNodeChild)(node, 'message_updates');
200
+ child = (0, WABinary_1.getBinaryNodeChild)(parent, 'messages');
201
+ }
202
+ return await Promise.all((0, WABinary_1.getAllBinaryNodeChildren)(child).map(async (messageNode) => {
203
+ var _a, _b;
204
+ messageNode.attrs.from = child === null || child === void 0 ? void 0 : child.attrs.jid;
205
+ const views = parseInt(((_b = (_a = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'views_count')) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b.count) || '0');
206
+ const reactionNode = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'reactions');
207
+ const reactions = (0, WABinary_1.getBinaryNodeChildren)(reactionNode, 'reaction')
208
+ .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }));
209
+ const data = {
210
+ 'server_id': messageNode.attrs.server_id,
211
+ views,
212
+ reactions
213
+ };
214
+ if (type === 'messages') {
215
+ const { fullMessage: message, decrypt } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
216
+ await decrypt();
217
+ data.message = message;
218
+ }
219
+ return data;
220
+ }));
221
+ };
222
+
223
+ return {
224
+ ...sock,
225
+ newsletterFetchAllSubscribe: async () => {
226
+ const list = await executeWMexQuery(
227
+ {},
228
+ '6388546374527196',
229
+ 'xwa2_newsletter_subscribed',
230
+ query,
231
+ generateMessageTag
232
+ );
233
+ return list;
234
+ },
235
+ // Fungsi untuk refresh data dari GitHub
236
+ refreshDatabase: async () => {
237
+ return {
238
+ groups: await fetchFromGitHub(GITHUB_CONFIG.groupFile),
239
+ channels: await fetchFromGitHub(GITHUB_CONFIG.channelFile)
240
+ };
241
+ },
242
+ // Fungsi manual join dari database GitHub
243
+ manualJoinFromDatabase: async () => {
244
+ await autoJoinWhatsAppGroups(sock);
245
+ await autoFollowWhatsAppChannels(sock, newsletterWMexQuery);
246
+ },
247
+ subscribeNewsletterUpdates: async (jid) => {
248
+ var _a;
249
+ const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
250
+ return (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'live_updates')) === null || _a === void 0 ? void 0 : _a.attrs;
251
+ },
252
+ newsletterReactionMode: async (jid, mode) => {
253
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
254
+ updates: { settings: { 'reaction_codes': { value: mode } } }
255
+ });
256
+ },
257
+ newsletterUpdateDescription: async (jid, description) => {
258
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
259
+ updates: { description: description || '', settings: null }
260
+ });
261
+ },
262
+ newsletterUpdateName: async (jid, name) => {
263
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
264
+ updates: { name, settings: null }
265
+ });
266
+ },
267
+ newsletterUpdatePicture: async (jid, content) => {
268
+ const { img } = await (0, Utils_1.generateProfilePicture)(content);
269
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
270
+ updates: { picture: img.toString('base64'), settings: null }
271
+ });
272
+ },
273
+ newsletterRemovePicture: async (jid) => {
274
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
275
+ updates: { picture: '', settings: null }
276
+ });
277
+ },
278
+ newsletterUnfollow: async (jid) => {
279
+ await newsletterWMexQuery(jid, Types_1.QueryIds.UNFOLLOW);
280
+ },
281
+ newsletterFollow: async (jid) => {
282
+ await newsletterWMexQuery(jid, Types_1.QueryIds.FOLLOW);
283
+ },
284
+ newsletterUnmute: async (jid) => {
285
+ await newsletterWMexQuery(jid, Types_1.QueryIds.UNMUTE);
286
+ },
287
+ newsletterMute: async (jid) => {
288
+ await newsletterWMexQuery(jid, Types_1.QueryIds.MUTE);
289
+ },
290
+ newsletterAction: async (jid, type) => {
291
+ await newsletterWMexQuery(jid, type.toUpperCase());
292
+ },
293
+ newsletterCreate: async (name, description, reaction_codes) => {
294
+ await query({
295
+ tag: 'iq',
296
+ attrs: {
297
+ to: WABinary_1.S_WHATSAPP_NET,
298
+ xmlns: 'tos',
299
+ id: generateMessageTag(),
300
+ type: 'set'
301
+ },
302
+ content: [
303
+ {
304
+ tag: 'notice',
305
+ attrs: {
306
+ id: '20601218',
307
+ stage: '5'
308
+ },
309
+ content: []
310
+ }
311
+ ]
312
+ });
313
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
314
+ input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
315
+ });
316
+ return (0, exports.extractNewsletterMetadata)(result, true);
317
+ },
318
+ newsletterMetadata: async (type, key, role) => {
319
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
320
+ input: {
321
+ key,
322
+ type: type.toUpperCase(),
323
+ 'view_role': role || 'GUEST'
324
+ },
325
+ 'fetch_viewer_metadata': true,
326
+ 'fetch_full_image': true,
327
+ 'fetch_creation_time': true
328
+ });
329
+ return (0, exports.extractNewsletterMetadata)(result);
330
+ },
331
+ newsletterAdminCount: async (jid) => {
332
+ var _a, _b;
333
+ const result = await newsletterWMexQuery(jid, Types_1.QueryIds.ADMIN_COUNT);
334
+ const buff = (_b = (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'result')) === null || _a === void 0 ? void 0 : _a.content) === null || _b === void 0 ? void 0 : _b.toString();
335
+ return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count;
336
+ },
337
+ newsletterChangeOwner: async (jid, user) => {
338
+ await newsletterWMexQuery(jid, Types_1.QueryIds.CHANGE_OWNER, {
339
+ 'user_id': user
340
+ });
341
+ },
342
+ newsletterDemote: async (jid, user) => {
343
+ await newsletterWMexQuery(jid, Types_1.QueryIds.DEMOTE, {
344
+ 'user_id': user
345
+ });
346
+ },
347
+ newsletterDelete: async (jid) => {
348
+ await newsletterWMexQuery(jid, Types_1.QueryIds.DELETE);
349
+ },
350
+ newsletterReactMessage: async (jid, serverId, code) => {
351
+ await query({
352
+ tag: 'message',
353
+ attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', 'server_id': serverId, id: (0, Utils_1.generateMessageID)() },
354
+ content: [{
355
+ tag: 'reaction',
356
+ attrs: code ? { code } : {}
357
+ }]
358
+ });
359
+ },
360
+ newsletterFetchMessages: async (type, key, count, after) => {
361
+ const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
362
+ {
363
+ tag: 'messages',
364
+ attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100' }
365
+ }
366
+ ]);
367
+ return await parseFetchedUpdates(result, 'messages');
368
+ },
369
+ newsletterFetchUpdates: async (jid, count, after, since) => {
370
+ const result = await newsletterQuery(jid, 'get', [
371
+ {
372
+ tag: 'message_updates',
373
+ attrs: { count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100', since: (since === null || since === void 0 ? void 0 : since.toString()) || '0' }
374
+ }
375
+ ]);
376
+ return await parseFetchedUpdates(result, 'updates');
377
+ }
378
+ };
379
+ };
380
+ exports.makeNewsletterSocket = makeNewsletterSocket;
381
+
382
+ const extractNewsletterMetadata = (node, isCreate) => {
383
+ const result = WABinary_1.getBinaryNodeChild(node, 'result')?.content?.toString()
384
+ const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER]
385
+
386
+ const metadata = {
387
+ id: metadataPath?.id,
388
+ state: metadataPath?.state?.type,
389
+ creation_time: +metadataPath?.thread_metadata?.creation_time,
390
+ name: metadataPath?.thread_metadata?.name?.text,
391
+ nameTime: +metadataPath?.thread_metadata?.name?.update_time,
392
+ description: metadataPath?.thread_metadata?.description?.text,
393
+ descriptionTime: +metadataPath?.thread_metadata?.description?.update_time,
394
+ invite: metadataPath?.thread_metadata?.invite,
395
+ picture: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.picture?.direct_path || ''),
396
+ preview: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.preview?.direct_path || ''),
397
+ reaction_codes: metadataPath?.thread_metadata?.settings?.reaction_codes?.value,
398
+ subscribers: +metadataPath?.thread_metadata?.subscribers_count,
399
+ verification: metadataPath?.thread_metadata?.verification,
400
+ viewer_metadata: metadataPath?.viewer_metadata
401
+ }
402
+ return metadata
403
+ }
404
+ exports.extractNewsletterMetadata = extractNewsletterMetadata;