violetics 7.0.1-alpha → 7.0.3-alpha
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/LICENSE +3 -2
- package/README.md +1001 -232
- package/WAProto/index.js +75379 -142631
- package/engine-requirements.js +11 -8
- package/lib/Defaults/index.js +132 -146
- package/lib/Signal/Group/ciphertext-message.js +2 -6
- package/lib/Signal/Group/group-session-builder.js +7 -42
- package/lib/Signal/Group/group_cipher.js +37 -52
- package/lib/Signal/Group/index.js +11 -57
- package/lib/Signal/Group/keyhelper.js +7 -45
- package/lib/Signal/Group/sender-chain-key.js +7 -16
- package/lib/Signal/Group/sender-key-distribution-message.js +8 -12
- package/lib/Signal/Group/sender-key-message.js +9 -13
- package/lib/Signal/Group/sender-key-name.js +2 -6
- package/lib/Signal/Group/sender-key-record.js +9 -22
- package/lib/Signal/Group/sender-key-state.js +27 -43
- package/lib/Signal/Group/sender-message-key.js +4 -8
- package/lib/Signal/libsignal.js +319 -94
- package/lib/Signal/lid-mapping.js +224 -139
- package/lib/Socket/Client/index.js +2 -19
- package/lib/Socket/Client/types.js +10 -0
- package/lib/Socket/Client/websocket.js +53 -0
- package/lib/Socket/business.js +162 -44
- package/lib/Socket/chats.js +477 -418
- package/lib/Socket/communities.js +430 -0
- package/lib/Socket/groups.js +110 -99
- package/lib/Socket/index.js +10 -10
- package/lib/Socket/messages-recv.js +884 -561
- package/lib/Socket/messages-send.js +859 -428
- package/lib/Socket/mex.js +41 -0
- package/lib/Socket/newsletter.js +195 -390
- package/lib/Socket/socket.js +465 -315
- package/lib/Store/index.js +3 -10
- package/lib/Store/make-in-memory-store.js +73 -79
- package/lib/Store/make-ordered-dictionary.js +4 -7
- package/lib/Store/object-repository.js +2 -6
- package/lib/Types/Auth.js +1 -2
- package/lib/Types/Bussines.js +1 -0
- package/lib/Types/Call.js +1 -2
- package/lib/Types/Chat.js +7 -4
- package/lib/Types/Contact.js +1 -2
- package/lib/Types/Events.js +1 -2
- package/lib/Types/GroupMetadata.js +1 -2
- package/lib/Types/Label.js +2 -5
- package/lib/Types/LabelAssociation.js +2 -5
- package/lib/Types/Message.js +17 -9
- package/lib/Types/Newsletter.js +33 -38
- package/lib/Types/Product.js +1 -2
- package/lib/Types/Signal.js +1 -2
- package/lib/Types/Socket.js +2 -2
- package/lib/Types/State.js +12 -2
- package/lib/Types/USync.js +1 -2
- package/lib/Types/index.js +14 -31
- package/lib/Utils/auth-utils.js +228 -152
- package/lib/Utils/browser-utils.js +28 -0
- package/lib/Utils/business.js +66 -70
- package/lib/Utils/chat-utils.js +331 -249
- package/lib/Utils/crypto.js +57 -91
- package/lib/Utils/decode-wa-message.js +168 -84
- package/lib/Utils/event-buffer.js +138 -80
- package/lib/Utils/generics.js +180 -297
- package/lib/Utils/history.js +83 -49
- package/lib/Utils/identity-change-handler.js +48 -0
- package/lib/Utils/index.js +19 -33
- package/lib/Utils/link-preview.js +14 -23
- package/lib/Utils/logger.js +2 -7
- package/lib/Utils/lt-hash.js +2 -46
- package/lib/Utils/make-mutex.js +24 -47
- package/lib/Utils/message-retry-manager.js +224 -0
- package/lib/Utils/messages-media.js +501 -496
- package/lib/Utils/messages.js +1428 -362
- package/lib/Utils/noise-handler.js +145 -100
- package/lib/Utils/pre-key-manager.js +105 -0
- package/lib/Utils/process-message.js +356 -150
- package/lib/Utils/reporting-utils.js +257 -0
- package/lib/Utils/signal.js +78 -73
- package/lib/Utils/sync-action-utils.js +47 -0
- package/lib/Utils/tc-token-utils.js +17 -0
- package/lib/Utils/use-multi-file-auth-state.js +35 -45
- package/lib/Utils/validate-connection.js +91 -107
- package/lib/WABinary/constants.js +1300 -1304
- package/lib/WABinary/decode.js +26 -48
- package/lib/WABinary/encode.js +109 -155
- package/lib/WABinary/generic-utils.js +161 -149
- package/lib/WABinary/index.js +5 -21
- package/lib/WABinary/jid-utils.js +73 -40
- package/lib/WABinary/types.js +1 -2
- package/lib/WAM/BinaryInfo.js +2 -6
- package/lib/WAM/constants.js +19070 -11568
- package/lib/WAM/encode.js +17 -23
- package/lib/WAM/index.js +3 -19
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +8 -12
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +11 -15
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +9 -13
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +9 -14
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +20 -23
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +13 -9
- package/lib/WAUSync/Protocols/index.js +4 -20
- package/lib/WAUSync/USyncQuery.js +40 -36
- package/lib/WAUSync/USyncUser.js +2 -6
- package/lib/WAUSync/index.js +3 -19
- package/lib/index.js +11 -44
- package/package.json +74 -107
- package/lib/Defaults/baileys-version.json +0 -3
- package/lib/Defaults/phonenumber-mcc.json +0 -223
- package/lib/Signal/Group/queue-job.js +0 -57
- package/lib/Socket/Client/abstract-socket-client.js +0 -13
- package/lib/Socket/Client/mobile-socket-client.js +0 -65
- package/lib/Socket/Client/web-socket-client.js +0 -118
- package/lib/Socket/groupStatus.js +0 -637
- package/lib/Socket/registration.js +0 -166
- package/lib/Socket/usync.js +0 -70
- package/lib/Store/make-cache-manager-store.js +0 -83
- package/lib/Utils/baileys-event-stream.js +0 -63
package/engine-requirements.js
CHANGED
|
@@ -1,10 +1,13 @@
|
|
|
1
|
-
const major = parseInt(
|
|
1
|
+
const major = parseInt(
|
|
2
|
+
process.versions.node.split('.')[0],
|
|
3
|
+
10
|
|
4
|
+
);
|
|
2
5
|
|
|
3
6
|
if (major < 20) {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
}
|
|
7
|
+
console.error(
|
|
8
|
+
`\n❌ This package requires Node.js 20+ to run reliably.\n` +
|
|
9
|
+
` You are using Node.js ${process.versions.node}.\n` +
|
|
10
|
+
` Please upgrade to Node.js 20+ to proceed.\n`
|
|
11
|
+
);
|
|
12
|
+
process.exit(1);
|
|
13
|
+
}
|
package/lib/Defaults/index.js
CHANGED
|
@@ -1,158 +1,144 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { proto } from '../../WAProto/index.js';
|
|
2
|
+
import { makeLibSignalRepository } from '../Signal/libsignal.js';
|
|
3
|
+
import { Browsers } from '../Utils/browser-utils.js';
|
|
4
|
+
import logger from '../Utils/logger.js';
|
|
5
|
+
const version = [2, 3000, 1033846690];
|
|
6
|
+
export const UNAUTHORIZED_CODES = [401, 403, 419];
|
|
7
|
+
export const BIZ_BOT_SUPPORT_PAYLOAD = '{"version":1,"is_ai_message":true,"should_show_system_message":false,"ticket_id":"7004947587700716","citation_items":[],"ticket_locale":"us"}';
|
|
8
|
+
export const DEFAULT_ORIGIN = 'https://web.whatsapp.com';
|
|
9
|
+
export const CALL_VIDEO_PREFIX = 'https://call.whatsapp.com/video/';
|
|
10
|
+
export const CALL_AUDIO_PREFIX = 'https://call.whatsapp.com/voice/';
|
|
11
|
+
export const DEF_CALLBACK_PREFIX = 'CB:';
|
|
12
|
+
export const DEF_TAG_PREFIX = 'TAG:';
|
|
13
|
+
export const DONATE_URL = 'https://saweria.co/itsliaaa'; // Lia@Note 02-02-26 --- Apologies if this feels cheeky, just a fallback
|
|
14
|
+
export const LIBRARY_NAME = 'itsliaaa/baileys';
|
|
15
|
+
export const PHONE_CONNECTION_CB = 'CB:Pong';
|
|
16
|
+
export const WA_ADV_ACCOUNT_SIG_PREFIX = Buffer.from([6, 0]);
|
|
17
|
+
export const WA_ADV_DEVICE_SIG_PREFIX = Buffer.from([6, 1]);
|
|
18
|
+
export const WA_ADV_HOSTED_ACCOUNT_SIG_PREFIX = Buffer.from([6, 5]);
|
|
19
|
+
export const WA_ADV_HOSTED_DEVICE_SIG_PREFIX = Buffer.from([6, 6]);
|
|
20
|
+
export const WA_DEFAULT_EPHEMERAL = 7 * 24 * 60 * 60;
|
|
21
|
+
/** Status messages older than 24 hours are considered expired */
|
|
22
|
+
export const STATUS_EXPIRY_SECONDS = 24 * 60 * 60;
|
|
23
|
+
/** WA Web enforces a 14-day maximum age for placeholder resend requests */
|
|
24
|
+
export const PLACEHOLDER_MAX_AGE_SECONDS = 14 * 24 * 60 * 60;
|
|
25
|
+
export const NOISE_MODE = 'Noise_XX_25519_AESGCM_SHA256\0\0\0\0';
|
|
26
|
+
export const DICT_VERSION = 3;
|
|
27
|
+
export const KEY_BUNDLE_TYPE = Buffer.from([5]);
|
|
28
|
+
export const NOISE_WA_HEADER = Buffer.from([87, 65, 6, DICT_VERSION]); // last is "DICT_VERSION"
|
|
29
|
+
export const OLD_GROUP_ID_REGEX = /^(\d{1,15})-(\d+)@g\.us$/;
|
|
30
|
+
/** from: https://stackoverflow.com/questions/3809401/what-is-a-good-regular-expression-to-match-a-url */
|
|
31
|
+
export const URL_REGEX = /https:\/\/(?![^:@\/\s]+:[^:@\/\s]+@)[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}(:\d+)?(\/[^\s]*)?/g;
|
|
32
|
+
export const WA_CERT_DETAILS = {
|
|
33
|
+
SERIAL: 0,
|
|
34
|
+
ISSUER: 'WhatsAppLongTerm1',
|
|
35
|
+
PUBLIC_KEY: Buffer.from('142375574d0a587166aae71ebe516437c4a28b73e3695c6ce1f7f9545da8ee6b', 'hex')
|
|
3
36
|
};
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
exports.MEDIA_PATH_MAP =
|
|
13
|
-
exports.DEFAULT_CONNECTION_CONFIG =
|
|
14
|
-
exports.PROCESSABLE_HISTORY_TYPES =
|
|
15
|
-
exports.WA_CERT_DETAILS =
|
|
16
|
-
exports.URL_REGEX =
|
|
17
|
-
exports.NOISE_WA_HEADER =
|
|
18
|
-
exports.KEY_BUNDLE_TYPE =
|
|
19
|
-
exports.DICT_VERSION =
|
|
20
|
-
exports.NOISE_MODE =
|
|
21
|
-
exports.WA_DEFAULT_EPHEMERAL =
|
|
22
|
-
exports.PHONE_CONNECTION_CB =
|
|
23
|
-
exports.DEF_TAG_PREFIX =
|
|
24
|
-
exports.DEF_CALLBACK_PREFIX =
|
|
25
|
-
exports.DEFAULT_ORIGIN =
|
|
26
|
-
exports.UNAUTHORIZED_CODES =
|
|
27
|
-
void 0;
|
|
28
|
-
|
|
29
|
-
const crypto_1 = require("crypto");
|
|
30
|
-
const WAProto_1 = require("../../WAProto"),
|
|
31
|
-
libsignal_1 = require("../Signal/libsignal"),
|
|
32
|
-
Utils_1 = require("../Utils"),
|
|
33
|
-
logger_1 = __importDefault(require("../Utils/logger")),
|
|
34
|
-
baileys_version_json_1 = require("./baileys-version.json"),
|
|
35
|
-
phonenumber_mcc_json_1 = __importDefault(require("./phonenumber-mcc.json"));
|
|
36
|
-
|
|
37
|
-
exports.UNAUTHORIZED_CODES = [401, 403, 419];
|
|
38
|
-
exports.version = [2, 3000, 1033846690];
|
|
39
|
-
exports.PHONENUMBER_MCC = phonenumber_mcc_json_1.default;
|
|
40
|
-
exports.DEFAULT_ORIGIN = "https://web.whatsapp.com";
|
|
41
|
-
exports.MOBILE_ENDPOINT = 'g.whatsapp.net';
|
|
42
|
-
exports.MOBILE_PORT = 443;
|
|
43
|
-
exports.DEF_CALLBACK_PREFIX = "CB:";
|
|
44
|
-
exports.DEF_TAG_PREFIX = "TAG:";
|
|
45
|
-
exports.PHONE_CONNECTION_CB = "CB:Pong";
|
|
46
|
-
exports.WA_DEFAULT_EPHEMERAL = 604800;
|
|
47
|
-
const WA_VERSION = '2.25.28.80';
|
|
48
|
-
const WA_VERSION_HASH = (0, crypto_1.createHash)('md5').update(WA_VERSION).digest('hex');
|
|
49
|
-
exports.MOBILE_TOKEN = Buffer.from('0a1mLfGUIBVrMKF1RdvLI5lkRBvof6vn0fD2QRSM' + WA_VERSION_HASH);
|
|
50
|
-
exports.MOBILE_REGISTRATION_ENDPOINT = 'https://v.whatsapp.net/v2';
|
|
51
|
-
exports.MOBILE_USERAGENT = `WhatsApp/${WA_VERSION} iOS/18.3.1 Device/Apple-iPhone_16`;
|
|
52
|
-
exports.REGISTRATION_PUBLIC_KEY = Buffer.from([
|
|
53
|
-
5, 142, 140, 15, 116, 195, 235, 197, 215, 166, 134, 92, 108, 60, 132, 56, 86, 176, 97, 33, 204, 232, 234, 119, 77,
|
|
54
|
-
34, 251, 111, 18, 37, 18, 48, 45,
|
|
55
|
-
]);
|
|
56
|
-
exports.NOISE_MODE = "Noise_XX_25519_AESGCM_SHA256\x00\x00\x00\x00";
|
|
57
|
-
exports.DICT_VERSION = 3;
|
|
58
|
-
exports.KEY_BUNDLE_TYPE = Buffer.from([5]);
|
|
59
|
-
exports.NOISE_WA_HEADER = Buffer.from([87, 65, 6, exports.DICT_VERSION]);
|
|
60
|
-
exports.PROTOCOL_VERSION = [5, 2];
|
|
61
|
-
exports.MOBILE_NOISE_HEADER = Buffer.concat([Buffer.from('WA'), Buffer.from(exports.PROTOCOL_VERSION)]);
|
|
62
|
-
|
|
63
|
-
exports.URL_REGEX = /https:\/\/(?![^:@\/\s]+:[^:@\/\s]+@)[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}(:\d+)?(\/[^\s]*)?/g;
|
|
64
|
-
exports.WA_CERT_DETAILS = { SERIAL: 0 };
|
|
65
|
-
|
|
66
|
-
exports.PROCESSABLE_HISTORY_TYPES = [
|
|
67
|
-
WAProto_1.proto.Message.HistorySyncNotification.HistorySyncType.INITIAL_BOOTSTRAP,
|
|
68
|
-
WAProto_1.proto.Message.HistorySyncNotification.HistorySyncType.PUSH_NAME,
|
|
69
|
-
WAProto_1.proto.Message.HistorySyncNotification.HistorySyncType.RECENT,
|
|
70
|
-
WAProto_1.proto.Message.HistorySyncNotification.HistorySyncType.FULL,
|
|
71
|
-
WAProto_1.proto.Message.HistorySyncNotification.HistorySyncType.ON_DEMAND
|
|
37
|
+
export const PROCESSABLE_HISTORY_TYPES = [
|
|
38
|
+
proto.HistorySync.HistorySyncType.INITIAL_BOOTSTRAP,
|
|
39
|
+
proto.HistorySync.HistorySyncType.PUSH_NAME,
|
|
40
|
+
proto.HistorySync.HistorySyncType.RECENT,
|
|
41
|
+
proto.HistorySync.HistorySyncType.FULL,
|
|
42
|
+
proto.HistorySync.HistorySyncType.ON_DEMAND,
|
|
43
|
+
proto.HistorySync.HistorySyncType.NON_BLOCKING_DATA,
|
|
44
|
+
proto.HistorySync.HistorySyncType.INITIAL_STATUS_V3
|
|
72
45
|
];
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
emitOwnEvents: !0,
|
|
83
|
-
defaultQueryTimeoutMs: 6E4,
|
|
46
|
+
export const DEFAULT_CONNECTION_CONFIG = {
|
|
47
|
+
version: version,
|
|
48
|
+
browser: Browsers.macOS('Chrome'),
|
|
49
|
+
waWebSocketUrl: 'wss://web.whatsapp.com/ws/chat',
|
|
50
|
+
connectTimeoutMs: 20000,
|
|
51
|
+
keepAliveIntervalMs: 30000,
|
|
52
|
+
logger: logger.child({ class: 'baileys' }),
|
|
53
|
+
emitOwnEvents: true,
|
|
54
|
+
defaultQueryTimeoutMs: 60000,
|
|
84
55
|
customUploadHosts: [],
|
|
85
|
-
retryRequestDelayMs:
|
|
86
|
-
maxMsgRetryCount:
|
|
87
|
-
fireInitQueries:
|
|
88
|
-
auth:
|
|
89
|
-
markOnlineOnConnect:
|
|
90
|
-
syncFullHistory:
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
56
|
+
retryRequestDelayMs: 250,
|
|
57
|
+
maxMsgRetryCount: 3,
|
|
58
|
+
fireInitQueries: true,
|
|
59
|
+
auth: undefined,
|
|
60
|
+
markOnlineOnConnect: true,
|
|
61
|
+
syncFullHistory: true,
|
|
62
|
+
patchMessageBeforeSending: msg => msg,
|
|
63
|
+
shouldSyncHistoryMessage: ({ syncType }) => {
|
|
64
|
+
return syncType !== proto.HistorySync.HistorySyncType.FULL;
|
|
65
|
+
},
|
|
66
|
+
shouldIgnoreJid: () => false,
|
|
95
67
|
linkPreviewImageThumbnailWidth: 192,
|
|
96
|
-
transactionOpts: { maxCommitRetries:
|
|
97
|
-
generateHighQualityLinkPreview:
|
|
68
|
+
transactionOpts: { maxCommitRetries: 5, delayBetweenTriesMs: 3000 },
|
|
69
|
+
generateHighQualityLinkPreview: false,
|
|
70
|
+
enableAutoSessionRecreation: true,
|
|
71
|
+
enableRecentMessageCache: true,
|
|
98
72
|
options: {},
|
|
99
|
-
appStateMacVerification: {
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
73
|
+
appStateMacVerification: {
|
|
74
|
+
patch: false,
|
|
75
|
+
snapshot: false
|
|
76
|
+
},
|
|
77
|
+
countryCode: 'US',
|
|
78
|
+
getMessage: async () => undefined,
|
|
79
|
+
cachedGroupMetadata: async () => undefined,
|
|
80
|
+
makeSignalRepository: makeLibSignalRepository
|
|
104
81
|
};
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
sticker:
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
82
|
+
export const MEDIA_PATH_MAP = {
|
|
83
|
+
image: '/mms/image',
|
|
84
|
+
video: '/mms/video',
|
|
85
|
+
document: '/mms/document',
|
|
86
|
+
audio: '/mms/audio',
|
|
87
|
+
sticker: '/mms/image',
|
|
88
|
+
'sticker-pack': '/mms/sticker-pack',
|
|
89
|
+
'thumbnail-sticker-pack': '/mms/thumbnail-sticker-pack',
|
|
90
|
+
'thumbnail-link': '/mms/thumbnail-link',
|
|
91
|
+
'product-catalog-image': '/product/image',
|
|
92
|
+
'md-app-state': '',
|
|
93
|
+
'md-msg-hist': '/mms/md-app-state',
|
|
94
|
+
'biz-cover-photo': '/pps/biz-cover-photo'
|
|
116
95
|
};
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
ptt: "Audio",
|
|
126
|
-
sticker: "Image",
|
|
127
|
-
video: "Video",
|
|
128
|
-
"thumbnail-document": "Document Thumbnail",
|
|
129
|
-
"thumbnail-image": "Image Thumbnail",
|
|
130
|
-
"thumbnail-video": "Video Thumbnail",
|
|
131
|
-
"thumbnail-link": "Link Thumbnail",
|
|
132
|
-
"md-msg-hist": "History",
|
|
133
|
-
"md-app-state": "App State",
|
|
134
|
-
"product-catalog-image": "",
|
|
135
|
-
"payment-bg-image": "Payment Background",
|
|
136
|
-
ptv: "Video"
|
|
96
|
+
// vltcs@changes 06-02-26 --- Add newsletter media path for "/m1/" instead of "/o1/" (≧▽≦)
|
|
97
|
+
export const NEWSLETTER_MEDIA_PATH_MAP = {
|
|
98
|
+
image: '/newsletter/newsletter-image',
|
|
99
|
+
video: '/newsletter/newsletter-video',
|
|
100
|
+
document: '/newsletter/newsletter-document',
|
|
101
|
+
audio: '/newsletter/newsletter-audio',
|
|
102
|
+
sticker: '/newsletter/newsletter-image',
|
|
103
|
+
'thumbnail-link': '/newsletter/newsletter-thumbnail-link'
|
|
137
104
|
};
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
105
|
+
export const MEDIA_HKDF_KEY_MAPPING = {
|
|
106
|
+
audio: 'Audio',
|
|
107
|
+
document: 'Document',
|
|
108
|
+
gif: 'Video',
|
|
109
|
+
image: 'Image',
|
|
110
|
+
ppic: '',
|
|
111
|
+
product: 'Image',
|
|
112
|
+
ptt: 'Audio',
|
|
113
|
+
'sticker-pack': 'Sticker Pack',
|
|
114
|
+
'thumbnail-sticker-pack': 'Sticker Pack Thumbnail',
|
|
115
|
+
sticker: 'Image',
|
|
116
|
+
video: 'Video',
|
|
117
|
+
'thumbnail-document': 'Document Thumbnail',
|
|
118
|
+
'thumbnail-image': 'Image Thumbnail',
|
|
119
|
+
'thumbnail-video': 'Video Thumbnail',
|
|
120
|
+
'thumbnail-link': 'Link Thumbnail',
|
|
121
|
+
'md-msg-hist': 'History',
|
|
122
|
+
'md-app-state': 'App State',
|
|
123
|
+
'product-catalog-image': '',
|
|
124
|
+
'payment-bg-image': 'Payment Background',
|
|
125
|
+
ptv: 'Video',
|
|
126
|
+
'biz-cover-photo': 'Image'
|
|
127
|
+
};
|
|
128
|
+
export const MEDIA_KEYS = Object.keys(MEDIA_PATH_MAP);
|
|
129
|
+
export const MIN_PREKEY_COUNT = 5;
|
|
130
|
+
export const INITIAL_PREKEY_COUNT = 812;
|
|
131
|
+
export const UPLOAD_TIMEOUT = 30000; // 30 seconds
|
|
132
|
+
export const MIN_UPLOAD_INTERVAL = 5000; // 5 seconds minimum between uploads
|
|
133
|
+
export const DEFAULT_CACHE_TTLS = {
|
|
134
|
+
SIGNAL_STORE: 5 * 60, // 5 minutes
|
|
135
|
+
MSG_RETRY: 60 * 60, // 1 hour
|
|
136
|
+
CALL_OFFER: 5 * 60, // 5 minutes
|
|
137
|
+
USER_DEVICES: 5 * 60 // 5 minutes
|
|
138
|
+
};
|
|
139
|
+
export const TimeMs = {
|
|
147
140
|
Minute: 60 * 1000,
|
|
148
141
|
Hour: 60 * 60 * 1000,
|
|
149
142
|
Day: 24 * 60 * 60 * 1000,
|
|
150
143
|
Week: 7 * 24 * 60 * 60 * 1000
|
|
151
|
-
};
|
|
152
|
-
|
|
153
|
-
exports.DEFAULT_CACHE_TTLS = {
|
|
154
|
-
SIGNAL_STORE: 300,
|
|
155
|
-
MSG_RETRY: 3600,
|
|
156
|
-
CALL_OFFER: 300,
|
|
157
|
-
USER_DEVICES: 300
|
|
158
|
-
};
|
|
144
|
+
};
|
|
@@ -1,7 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CiphertextMessage = void 0;
|
|
4
|
-
class CiphertextMessage {
|
|
1
|
+
export class CiphertextMessage {
|
|
5
2
|
constructor() {
|
|
6
3
|
this.UNSUPPORTED_VERSION = 1;
|
|
7
4
|
this.CURRENT_VERSION = 3;
|
|
@@ -11,5 +8,4 @@ class CiphertextMessage {
|
|
|
11
8
|
this.SENDERKEY_DISTRIBUTION_TYPE = 5;
|
|
12
9
|
this.ENCRYPTED_MESSAGE_OVERHEAD = 53;
|
|
13
10
|
}
|
|
14
|
-
}
|
|
15
|
-
exports.CiphertextMessage = CiphertextMessage;
|
|
11
|
+
}
|
|
@@ -1,42 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.GroupSessionBuilder = void 0;
|
|
37
|
-
const keyhelper = __importStar(require("./keyhelper"));
|
|
38
|
-
const sender_key_distribution_message_1 = require("./sender-key-distribution-message");
|
|
39
|
-
class GroupSessionBuilder {
|
|
1
|
+
import * as keyhelper from './keyhelper.js';
|
|
2
|
+
import { SenderKeyDistributionMessage } from './sender-key-distribution-message.js';
|
|
3
|
+
import { SenderKeyName } from './sender-key-name.js';
|
|
4
|
+
import { SenderKeyRecord } from './sender-key-record.js';
|
|
5
|
+
export class GroupSessionBuilder {
|
|
40
6
|
constructor(senderKeyStore) {
|
|
41
7
|
this.senderKeyStore = senderKeyStore;
|
|
42
8
|
}
|
|
@@ -58,7 +24,6 @@ class GroupSessionBuilder {
|
|
|
58
24
|
if (!state) {
|
|
59
25
|
throw new Error('No session state available');
|
|
60
26
|
}
|
|
61
|
-
return new
|
|
27
|
+
return new SenderKeyDistributionMessage(state.getKeyId(), state.getSenderChainKey().getIteration(), state.getSenderChainKey().getSeed(), state.getSigningKeyPublic());
|
|
62
28
|
}
|
|
63
|
-
}
|
|
64
|
-
exports.GroupSessionBuilder = GroupSessionBuilder;
|
|
29
|
+
}
|
|
@@ -1,55 +1,44 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
const crypto_1 = require("libsignal/src/crypto");
|
|
8
|
-
const queue_job_1 = __importDefault(require("./queue-job"));
|
|
9
|
-
const sender_key_message_1 = require("./sender-key-message");
|
|
10
|
-
class GroupCipher {
|
|
1
|
+
import { decrypt, encrypt } from 'libsignal/src/crypto.js';
|
|
2
|
+
import { SenderKeyMessage } from './sender-key-message.js';
|
|
3
|
+
import { SenderKeyName } from './sender-key-name.js';
|
|
4
|
+
import { SenderKeyRecord } from './sender-key-record.js';
|
|
5
|
+
import { SenderKeyState } from './sender-key-state.js';
|
|
6
|
+
export class GroupCipher {
|
|
11
7
|
constructor(senderKeyStore, senderKeyName) {
|
|
12
8
|
this.senderKeyStore = senderKeyStore;
|
|
13
9
|
this.senderKeyName = senderKeyName;
|
|
14
10
|
}
|
|
15
|
-
queueJob(awaitable) {
|
|
16
|
-
return (0, queue_job_1.default)(this.senderKeyName.toString(), awaitable);
|
|
17
|
-
}
|
|
18
11
|
async encrypt(paddedPlaintext) {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
return senderKeyMessage.serialize();
|
|
34
|
-
});
|
|
12
|
+
const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
|
|
13
|
+
if (!record) {
|
|
14
|
+
throw new Error('No SenderKeyRecord found for encryption');
|
|
15
|
+
}
|
|
16
|
+
const senderKeyState = record.getSenderKeyState();
|
|
17
|
+
if (!senderKeyState) {
|
|
18
|
+
throw new Error('No session to encrypt message');
|
|
19
|
+
}
|
|
20
|
+
const iteration = senderKeyState.getSenderChainKey().getIteration();
|
|
21
|
+
const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1);
|
|
22
|
+
const ciphertext = await this.getCipherText(senderKey.getIv(), senderKey.getCipherKey(), paddedPlaintext);
|
|
23
|
+
const senderKeyMessage = new SenderKeyMessage(senderKeyState.getKeyId(), senderKey.getIteration(), ciphertext, senderKeyState.getSigningKeyPrivate());
|
|
24
|
+
await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
|
|
25
|
+
return senderKeyMessage.serialize();
|
|
35
26
|
}
|
|
36
27
|
async decrypt(senderKeyMessageBytes) {
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
return plaintext;
|
|
52
|
-
});
|
|
28
|
+
const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
|
|
29
|
+
if (!record) {
|
|
30
|
+
throw new Error('No SenderKeyRecord found for decryption');
|
|
31
|
+
}
|
|
32
|
+
const senderKeyMessage = new SenderKeyMessage(null, null, null, null, senderKeyMessageBytes);
|
|
33
|
+
const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId());
|
|
34
|
+
if (!senderKeyState) {
|
|
35
|
+
throw new Error('No session found to decrypt message');
|
|
36
|
+
}
|
|
37
|
+
senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic());
|
|
38
|
+
const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration());
|
|
39
|
+
const plaintext = await this.getPlainText(senderKey.getIv(), senderKey.getCipherKey(), senderKeyMessage.getCipherText());
|
|
40
|
+
await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
|
|
41
|
+
return plaintext;
|
|
53
42
|
}
|
|
54
43
|
getSenderKey(senderKeyState, iteration) {
|
|
55
44
|
let senderChainKey = senderKeyState.getSenderChainKey();
|
|
@@ -75,7 +64,7 @@ class GroupCipher {
|
|
|
75
64
|
}
|
|
76
65
|
async getPlainText(iv, key, ciphertext) {
|
|
77
66
|
try {
|
|
78
|
-
return
|
|
67
|
+
return decrypt(key, ciphertext, iv);
|
|
79
68
|
}
|
|
80
69
|
catch (e) {
|
|
81
70
|
throw new Error('InvalidMessageException');
|
|
@@ -83,14 +72,10 @@ class GroupCipher {
|
|
|
83
72
|
}
|
|
84
73
|
async getCipherText(iv, key, plaintext) {
|
|
85
74
|
try {
|
|
86
|
-
|
|
87
|
-
const keyBuffer = typeof key === 'string' ? Buffer.from(key, 'base64') : key;
|
|
88
|
-
const plaintextBuffer = typeof plaintext === 'string' ? Buffer.from(plaintext) : plaintext;
|
|
89
|
-
return (0, crypto_1.encrypt)(keyBuffer, plaintextBuffer, ivBuffer);
|
|
75
|
+
return encrypt(key, plaintext, iv);
|
|
90
76
|
}
|
|
91
77
|
catch (e) {
|
|
92
78
|
throw new Error('InvalidMessageException');
|
|
93
79
|
}
|
|
94
80
|
}
|
|
95
|
-
}
|
|
96
|
-
exports.GroupCipher = GroupCipher;
|
|
81
|
+
}
|
|
@@ -1,57 +1,11 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.keyhelper = exports.CiphertextMessage = exports.SenderChainKey = exports.SenderMessageKey = exports.SenderKeyMessage = exports.SenderKeyState = exports.GroupCipher = exports.SenderKeyName = exports.SenderKeyRecord = exports.SenderKeyDistributionMessage = exports.GroupSessionBuilder = void 0;
|
|
37
|
-
var group_session_builder_1 = require("./group-session-builder");
|
|
38
|
-
Object.defineProperty(exports, "GroupSessionBuilder", { enumerable: true, get: function () { return group_session_builder_1.GroupSessionBuilder; } });
|
|
39
|
-
var sender_key_distribution_message_1 = require("./sender-key-distribution-message");
|
|
40
|
-
Object.defineProperty(exports, "SenderKeyDistributionMessage", { enumerable: true, get: function () { return sender_key_distribution_message_1.SenderKeyDistributionMessage; } });
|
|
41
|
-
var sender_key_record_1 = require("./sender-key-record");
|
|
42
|
-
Object.defineProperty(exports, "SenderKeyRecord", { enumerable: true, get: function () { return sender_key_record_1.SenderKeyRecord; } });
|
|
43
|
-
var sender_key_name_1 = require("./sender-key-name");
|
|
44
|
-
Object.defineProperty(exports, "SenderKeyName", { enumerable: true, get: function () { return sender_key_name_1.SenderKeyName; } });
|
|
45
|
-
var group_cipher_1 = require("./group_cipher");
|
|
46
|
-
Object.defineProperty(exports, "GroupCipher", { enumerable: true, get: function () { return group_cipher_1.GroupCipher; } });
|
|
47
|
-
var sender_key_state_1 = require("./sender-key-state");
|
|
48
|
-
Object.defineProperty(exports, "SenderKeyState", { enumerable: true, get: function () { return sender_key_state_1.SenderKeyState; } });
|
|
49
|
-
var sender_key_message_1 = require("./sender-key-message");
|
|
50
|
-
Object.defineProperty(exports, "SenderKeyMessage", { enumerable: true, get: function () { return sender_key_message_1.SenderKeyMessage; } });
|
|
51
|
-
var sender_message_key_1 = require("./sender-message-key");
|
|
52
|
-
Object.defineProperty(exports, "SenderMessageKey", { enumerable: true, get: function () { return sender_message_key_1.SenderMessageKey; } });
|
|
53
|
-
var sender_chain_key_1 = require("./sender-chain-key");
|
|
54
|
-
Object.defineProperty(exports, "SenderChainKey", { enumerable: true, get: function () { return sender_chain_key_1.SenderChainKey; } });
|
|
55
|
-
var ciphertext_message_1 = require("./ciphertext-message");
|
|
56
|
-
Object.defineProperty(exports, "CiphertextMessage", { enumerable: true, get: function () { return ciphertext_message_1.CiphertextMessage; } });
|
|
57
|
-
exports.keyhelper = __importStar(require("./keyhelper"));
|
|
1
|
+
export { GroupSessionBuilder } from './group-session-builder.js';
|
|
2
|
+
export { SenderKeyDistributionMessage } from './sender-key-distribution-message.js';
|
|
3
|
+
export { SenderKeyRecord } from './sender-key-record.js';
|
|
4
|
+
export { SenderKeyName } from './sender-key-name.js';
|
|
5
|
+
export { GroupCipher } from './group_cipher.js';
|
|
6
|
+
export { SenderKeyState } from './sender-key-state.js';
|
|
7
|
+
export { SenderKeyMessage } from './sender-key-message.js';
|
|
8
|
+
export { SenderMessageKey } from './sender-message-key.js';
|
|
9
|
+
export { SenderChainKey } from './sender-chain-key.js';
|
|
10
|
+
export { CiphertextMessage } from './ciphertext-message.js';
|
|
11
|
+
export * as keyhelper from './keyhelper.js';
|
|
@@ -1,55 +1,17 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.generateSenderKey = generateSenderKey;
|
|
37
|
-
exports.generateSenderKeyId = generateSenderKeyId;
|
|
38
|
-
exports.generateSenderSigningKey = generateSenderSigningKey;
|
|
39
|
-
const nodeCrypto = __importStar(require("crypto"));
|
|
40
|
-
const curve_1 = require("libsignal/src/curve");
|
|
41
|
-
function generateSenderKey() {
|
|
1
|
+
import * as nodeCrypto from 'crypto';
|
|
2
|
+
import { generateKeyPair } from 'libsignal/src/curve.js';
|
|
3
|
+
export function generateSenderKey() {
|
|
42
4
|
return nodeCrypto.randomBytes(32);
|
|
43
5
|
}
|
|
44
|
-
function generateSenderKeyId() {
|
|
6
|
+
export function generateSenderKeyId() {
|
|
45
7
|
return nodeCrypto.randomInt(2147483647);
|
|
46
8
|
}
|
|
47
|
-
function generateSenderSigningKey(key) {
|
|
9
|
+
export function generateSenderSigningKey(key) {
|
|
48
10
|
if (!key) {
|
|
49
|
-
key =
|
|
11
|
+
key = generateKeyPair();
|
|
50
12
|
}
|
|
51
13
|
return {
|
|
52
14
|
public: Buffer.from(key.pubKey),
|
|
53
15
|
private: Buffer.from(key.privKey)
|
|
54
16
|
};
|
|
55
|
-
}
|
|
17
|
+
}
|