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.
Files changed (114) hide show
  1. package/LICENSE +3 -2
  2. package/README.md +1001 -232
  3. package/WAProto/index.js +75379 -142631
  4. package/engine-requirements.js +11 -8
  5. package/lib/Defaults/index.js +132 -146
  6. package/lib/Signal/Group/ciphertext-message.js +2 -6
  7. package/lib/Signal/Group/group-session-builder.js +7 -42
  8. package/lib/Signal/Group/group_cipher.js +37 -52
  9. package/lib/Signal/Group/index.js +11 -57
  10. package/lib/Signal/Group/keyhelper.js +7 -45
  11. package/lib/Signal/Group/sender-chain-key.js +7 -16
  12. package/lib/Signal/Group/sender-key-distribution-message.js +8 -12
  13. package/lib/Signal/Group/sender-key-message.js +9 -13
  14. package/lib/Signal/Group/sender-key-name.js +2 -6
  15. package/lib/Signal/Group/sender-key-record.js +9 -22
  16. package/lib/Signal/Group/sender-key-state.js +27 -43
  17. package/lib/Signal/Group/sender-message-key.js +4 -8
  18. package/lib/Signal/libsignal.js +319 -94
  19. package/lib/Signal/lid-mapping.js +224 -139
  20. package/lib/Socket/Client/index.js +2 -19
  21. package/lib/Socket/Client/types.js +10 -0
  22. package/lib/Socket/Client/websocket.js +53 -0
  23. package/lib/Socket/business.js +162 -44
  24. package/lib/Socket/chats.js +477 -418
  25. package/lib/Socket/communities.js +430 -0
  26. package/lib/Socket/groups.js +110 -99
  27. package/lib/Socket/index.js +10 -10
  28. package/lib/Socket/messages-recv.js +884 -561
  29. package/lib/Socket/messages-send.js +859 -428
  30. package/lib/Socket/mex.js +41 -0
  31. package/lib/Socket/newsletter.js +195 -390
  32. package/lib/Socket/socket.js +465 -315
  33. package/lib/Store/index.js +3 -10
  34. package/lib/Store/make-in-memory-store.js +73 -79
  35. package/lib/Store/make-ordered-dictionary.js +4 -7
  36. package/lib/Store/object-repository.js +2 -6
  37. package/lib/Types/Auth.js +1 -2
  38. package/lib/Types/Bussines.js +1 -0
  39. package/lib/Types/Call.js +1 -2
  40. package/lib/Types/Chat.js +7 -4
  41. package/lib/Types/Contact.js +1 -2
  42. package/lib/Types/Events.js +1 -2
  43. package/lib/Types/GroupMetadata.js +1 -2
  44. package/lib/Types/Label.js +2 -5
  45. package/lib/Types/LabelAssociation.js +2 -5
  46. package/lib/Types/Message.js +17 -9
  47. package/lib/Types/Newsletter.js +33 -38
  48. package/lib/Types/Product.js +1 -2
  49. package/lib/Types/Signal.js +1 -2
  50. package/lib/Types/Socket.js +2 -2
  51. package/lib/Types/State.js +12 -2
  52. package/lib/Types/USync.js +1 -2
  53. package/lib/Types/index.js +14 -31
  54. package/lib/Utils/auth-utils.js +228 -152
  55. package/lib/Utils/browser-utils.js +28 -0
  56. package/lib/Utils/business.js +66 -70
  57. package/lib/Utils/chat-utils.js +331 -249
  58. package/lib/Utils/crypto.js +57 -91
  59. package/lib/Utils/decode-wa-message.js +168 -84
  60. package/lib/Utils/event-buffer.js +138 -80
  61. package/lib/Utils/generics.js +180 -297
  62. package/lib/Utils/history.js +83 -49
  63. package/lib/Utils/identity-change-handler.js +48 -0
  64. package/lib/Utils/index.js +19 -33
  65. package/lib/Utils/link-preview.js +14 -23
  66. package/lib/Utils/logger.js +2 -7
  67. package/lib/Utils/lt-hash.js +2 -46
  68. package/lib/Utils/make-mutex.js +24 -47
  69. package/lib/Utils/message-retry-manager.js +224 -0
  70. package/lib/Utils/messages-media.js +501 -496
  71. package/lib/Utils/messages.js +1428 -362
  72. package/lib/Utils/noise-handler.js +145 -100
  73. package/lib/Utils/pre-key-manager.js +105 -0
  74. package/lib/Utils/process-message.js +356 -150
  75. package/lib/Utils/reporting-utils.js +257 -0
  76. package/lib/Utils/signal.js +78 -73
  77. package/lib/Utils/sync-action-utils.js +47 -0
  78. package/lib/Utils/tc-token-utils.js +17 -0
  79. package/lib/Utils/use-multi-file-auth-state.js +35 -45
  80. package/lib/Utils/validate-connection.js +91 -107
  81. package/lib/WABinary/constants.js +1300 -1304
  82. package/lib/WABinary/decode.js +26 -48
  83. package/lib/WABinary/encode.js +109 -155
  84. package/lib/WABinary/generic-utils.js +161 -149
  85. package/lib/WABinary/index.js +5 -21
  86. package/lib/WABinary/jid-utils.js +73 -40
  87. package/lib/WABinary/types.js +1 -2
  88. package/lib/WAM/BinaryInfo.js +2 -6
  89. package/lib/WAM/constants.js +19070 -11568
  90. package/lib/WAM/encode.js +17 -23
  91. package/lib/WAM/index.js +3 -19
  92. package/lib/WAUSync/Protocols/USyncContactProtocol.js +8 -12
  93. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +11 -15
  94. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +9 -13
  95. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +9 -14
  96. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +20 -23
  97. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +13 -9
  98. package/lib/WAUSync/Protocols/index.js +4 -20
  99. package/lib/WAUSync/USyncQuery.js +40 -36
  100. package/lib/WAUSync/USyncUser.js +2 -6
  101. package/lib/WAUSync/index.js +3 -19
  102. package/lib/index.js +11 -44
  103. package/package.json +74 -107
  104. package/lib/Defaults/baileys-version.json +0 -3
  105. package/lib/Defaults/phonenumber-mcc.json +0 -223
  106. package/lib/Signal/Group/queue-job.js +0 -57
  107. package/lib/Socket/Client/abstract-socket-client.js +0 -13
  108. package/lib/Socket/Client/mobile-socket-client.js +0 -65
  109. package/lib/Socket/Client/web-socket-client.js +0 -118
  110. package/lib/Socket/groupStatus.js +0 -637
  111. package/lib/Socket/registration.js +0 -166
  112. package/lib/Socket/usync.js +0 -70
  113. package/lib/Store/make-cache-manager-store.js +0 -83
  114. package/lib/Utils/baileys-event-stream.js +0 -63
@@ -1,10 +1,13 @@
1
- const major = parseInt(process.versions.node.split('.')[0], 10);
1
+ const major = parseInt(
2
+ process.versions.node.split('.')[0],
3
+ 10
4
+ );
2
5
 
3
6
  if (major < 20) {
4
- console.error(
5
- `\n❌ This package requires Node.js 20+ to run reliably.\n` +
6
- ` You are using Node.js ${process.versions.node}.\n` +
7
- ` Please upgrade to Node.js 20+ to proceed.\n`
8
- );
9
- process.exit(1);
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
+ }
@@ -1,158 +1,144 @@
1
- var __importDefault = this && this.__importDefault || function (a) {
2
- return a && a.__esModule ? a : { "default": a }
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
- Object.defineProperty(exports, "__esModule", { value: !0 });
6
-
7
- exports.DEFAULT_CACHE_TTLS =
8
- exports.INITIAL_PREKEY_COUNT =
9
- exports.MIN_PREKEY_COUNT =
10
- exports.MEDIA_KEYS =
11
- exports.MEDIA_HKDF_KEY_MAPPING =
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
- exports.DEFAULT_CONNECTION_CONFIG = {
75
- version: baileys_version_json_1.version,
76
- browser: Utils_1.Browsers.macOS("Chrome"),
77
- waWebSocketUrl: "wss://web.whatsapp.com/ws/chat",
78
- connectTimeoutMs: 6E4,
79
- keepAliveIntervalMs: 15E3,
80
- logger: logger_1.default.child({ class: "baileys" }),
81
- printQRInTerminal: !1,
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: 500, // was 0 - add minimum backoff between decrypt-fail retries to reduce burst
86
- maxMsgRetryCount: 5, // was 15 - fewer retries = less traffic when running many bots
87
- fireInitQueries: !0,
88
- auth: void 0,
89
- markOnlineOnConnect: !1, // was true - prevents all bots spamming presence on simultaneous restart
90
- syncFullHistory: !1,
91
- connectJitterMs: 0, // set e.g. 10000 to spread multi-bot connects over a random 0-10s window
92
- patchMessageBeforeSending: a => a,
93
- shouldSyncHistoryMessage: () => !0,
94
- shouldIgnoreJid: () => !1,
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: 10, delayBetweenTriesMs: 3E3 },
97
- generateHighQualityLinkPreview: !1,
68
+ transactionOpts: { maxCommitRetries: 5, delayBetweenTriesMs: 3000 },
69
+ generateHighQualityLinkPreview: false,
70
+ enableAutoSessionRecreation: true,
71
+ enableRecentMessageCache: true,
98
72
  options: {},
99
- appStateMacVerification: { patch: !1, snapshot: !1 },
100
- countryCode: "US",
101
- getMessage: async () => { },
102
- cachedGroupMetadata: async () => { },
103
- makeSignalRepository: libsignal_1.makeLibSignalRepository
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
- exports.MEDIA_PATH_MAP = {
107
- image: "/mms/image",
108
- video: "/mms/video",
109
- document: "/mms/document",
110
- audio: "/mms/audio",
111
- sticker: "/mms/image",
112
- "thumbnail-link": "/mms/image",
113
- "product-catalog-image": "/product/image",
114
- "md-app-state": "",
115
- "md-msg-hist": "/mms/md-app-state"
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
- exports.MEDIA_HKDF_KEY_MAPPING = {
119
- audio: "Audio",
120
- document: "Document",
121
- gif: "Video",
122
- image: "Image",
123
- ppic: "",
124
- product: "Image",
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
- exports.MEDIA_KEYS = Object.keys(exports.MEDIA_PATH_MAP);
140
- exports.MIN_PREKEY_COUNT = 5;
141
- exports.INITIAL_PREKEY_COUNT = 30;
142
- exports.UPLOAD_TIMEOUT = 30000;
143
- exports.MIN_UPLOAD_INTERVAL = 30000; // was 5000 - prevent prekey upload storms when many bots connect at once
144
- exports.PREKEY_UPLOAD_JITTER_MS = 5000; // random jitter added to prekey upload timing
145
-
146
- exports.TimeMs = {
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
- "use strict";
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
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
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.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 sender_key_distribution_message_1.SenderKeyDistributionMessage(state.getKeyId(), state.getSenderChainKey().getIteration(), state.getSenderChainKey().getSeed(), state.getSigningKeyPublic());
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
- "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.GroupCipher = void 0;
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
- return await this.queueJob(async () => {
20
- const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
21
- if (!record) {
22
- throw new Error('No SenderKeyRecord found for encryption');
23
- }
24
- const senderKeyState = record.getSenderKeyState();
25
- if (!senderKeyState) {
26
- throw new Error('No session to encrypt message');
27
- }
28
- const iteration = senderKeyState.getSenderChainKey().getIteration();
29
- const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1);
30
- const ciphertext = await this.getCipherText(senderKey.getIv(), senderKey.getCipherKey(), paddedPlaintext);
31
- const senderKeyMessage = new sender_key_message_1.SenderKeyMessage(senderKeyState.getKeyId(), senderKey.getIteration(), ciphertext, senderKeyState.getSigningKeyPrivate());
32
- await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
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
- return await this.queueJob(async () => {
38
- const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
39
- if (!record) {
40
- throw new Error('No SenderKeyRecord found for decryption');
41
- }
42
- const senderKeyMessage = new sender_key_message_1.SenderKeyMessage(null, null, null, null, senderKeyMessageBytes);
43
- const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId());
44
- if (!senderKeyState) {
45
- throw new Error('No session found to decrypt message');
46
- }
47
- senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic());
48
- const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration());
49
- const plaintext = await this.getPlainText(senderKey.getIv(), senderKey.getCipherKey(), senderKeyMessage.getCipherText());
50
- await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
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 (0, crypto_1.decrypt)(key, ciphertext, iv);
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
- const ivBuffer = typeof iv === 'string' ? Buffer.from(iv, 'base64') : iv;
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
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
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.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
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
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 = (0, curve_1.generateKeyPair)();
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
+ }