@fazzcode/baileys 0.1.7 → 2.4.4

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 (209) hide show
  1. package/LICENSE +21 -0
  2. package/README.MD +1420 -103
  3. package/WAProto/WAProto.proto +5311 -0
  4. package/WAProto/index.js +83385 -119575
  5. package/lib/Defaults/index.js +117 -124
  6. package/lib/KeyDB/BinarySearch.js +20 -0
  7. package/lib/KeyDB/KeyedDB.js +167 -0
  8. package/lib/KeyDB/index.js +4 -0
  9. package/lib/Signal/Group/ciphertext-message.js +12 -14
  10. package/lib/Signal/Group/group-session-builder.js +10 -42
  11. package/lib/Signal/Group/group_cipher.js +75 -87
  12. package/lib/Signal/Group/index.js +13 -57
  13. package/lib/Signal/Group/keyhelper.js +17 -52
  14. package/lib/Signal/Group/sender-chain-key.js +27 -33
  15. package/lib/Signal/Group/sender-key-distribution-message.js +62 -63
  16. package/lib/Signal/Group/sender-key-message.js +65 -66
  17. package/lib/Signal/Group/sender-key-name.js +45 -44
  18. package/lib/Signal/Group/sender-key-record.js +39 -49
  19. package/lib/Signal/Group/sender-key-state.js +80 -93
  20. package/lib/Signal/Group/sender-message-key.js +27 -28
  21. package/lib/Signal/libsignal.js +313 -163
  22. package/lib/Signal/lid-mapping.js +155 -0
  23. package/lib/Socket/Client/index.js +4 -19
  24. package/lib/Socket/Client/types.js +13 -0
  25. package/lib/Socket/Client/websocket.js +52 -0
  26. package/lib/Socket/business.js +359 -242
  27. package/lib/Socket/chats.js +851 -830
  28. package/lib/Socket/communities.js +413 -0
  29. package/lib/Socket/groups.js +304 -309
  30. package/lib/Socket/index.js +15 -9
  31. package/lib/Socket/messages-recv.js +1107 -1054
  32. package/lib/Socket/messages-send.js +709 -414
  33. package/lib/Socket/mex.js +45 -0
  34. package/lib/Socket/newsletter.js +232 -318
  35. package/lib/Socket/socket.js +789 -599
  36. package/lib/Store/index.js +6 -10
  37. package/lib/Store/make-cache-manager-store.js +73 -81
  38. package/lib/Store/make-in-memory-store.js +286 -423
  39. package/lib/Store/make-ordered-dictionary.js +77 -79
  40. package/lib/Store/object-repository.js +24 -26
  41. package/lib/Types/Auth.js +3 -2
  42. package/lib/Types/Bussines.js +3 -0
  43. package/lib/Types/Call.js +3 -2
  44. package/lib/Types/Chat.js +9 -4
  45. package/lib/Types/Contact.js +3 -2
  46. package/lib/Types/Events.js +3 -2
  47. package/lib/Types/GroupMetadata.js +3 -2
  48. package/lib/Types/Label.js +24 -26
  49. package/lib/Types/LabelAssociation.js +6 -8
  50. package/lib/Types/Message.js +12 -9
  51. package/lib/Types/Newsletter.js +31 -30
  52. package/lib/Types/Newsletter.js.bak +33 -0
  53. package/lib/Types/Product.js +3 -2
  54. package/lib/Types/Signal.js +3 -2
  55. package/lib/Types/Socket.js +4 -2
  56. package/lib/Types/State.js +11 -2
  57. package/lib/Types/USync.js +3 -2
  58. package/lib/Types/index.js +27 -41
  59. package/lib/Utils/auth-utils.js +211 -198
  60. package/lib/Utils/baileys-event-stream.js +42 -61
  61. package/lib/Utils/browser-utils.js +25 -0
  62. package/lib/Utils/business.js +213 -214
  63. package/lib/Utils/chat-utils.js +710 -687
  64. package/lib/Utils/crypto.js +112 -133
  65. package/lib/Utils/decode-wa-message.js +252 -183
  66. package/lib/Utils/event-buffer.js +510 -496
  67. package/lib/Utils/generics.js +328 -356
  68. package/lib/Utils/history.js +83 -92
  69. package/lib/Utils/index.js +21 -33
  70. package/lib/Utils/link-preview.js +71 -83
  71. package/lib/Utils/logger.js +5 -7
  72. package/lib/Utils/lt-hash.js +40 -46
  73. package/lib/Utils/make-mutex.js +34 -41
  74. package/lib/Utils/message-retry-manager.js +113 -0
  75. package/lib/Utils/messages-media.js +548 -678
  76. package/lib/Utils/messages.js +352 -249
  77. package/lib/Utils/noise-handler.js +138 -149
  78. package/lib/Utils/pre-key-manager.js +85 -0
  79. package/lib/Utils/process-message.js +323 -303
  80. package/lib/Utils/signal.js +148 -138
  81. package/lib/Utils/use-multi-file-auth-state.js +98 -67
  82. package/lib/Utils/validate-connection.js +183 -188
  83. package/lib/WABinary/constants.js +1298 -35
  84. package/lib/WABinary/decode.js +237 -249
  85. package/lib/WABinary/encode.js +208 -218
  86. package/lib/WABinary/generic-utils.js +53 -57
  87. package/lib/WABinary/index.js +7 -21
  88. package/lib/WABinary/jid-utils.js +89 -58
  89. package/lib/WABinary/types.js +3 -2
  90. package/lib/WAM/BinaryInfo.js +10 -12
  91. package/lib/WAM/constants.js +22851 -15348
  92. package/lib/WAM/encode.js +135 -136
  93. package/lib/WAM/index.js +5 -19
  94. package/lib/WAUSync/Protocols/USyncContactProtocol.js +28 -30
  95. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +49 -53
  96. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +27 -28
  97. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +36 -39
  98. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +50 -50
  99. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +26 -20
  100. package/lib/WAUSync/Protocols/index.js +6 -20
  101. package/lib/WAUSync/USyncQuery.js +86 -85
  102. package/lib/WAUSync/USyncUser.js +23 -25
  103. package/lib/WAUSync/index.js +5 -19
  104. package/lib/index.js +32 -34
  105. package/package.json +99 -105
  106. package/engine-requirements.js +0 -10
  107. package/lib/Defaults/baileys-version.json +0 -3
  108. package/lib/Defaults/index.d.ts +0 -53
  109. package/lib/Defaults/phonenumber-mcc.json +0 -223
  110. package/lib/Signal/Group/ciphertext-message.d.ts +0 -9
  111. package/lib/Signal/Group/group-session-builder.d.ts +0 -14
  112. package/lib/Signal/Group/group_cipher.d.ts +0 -17
  113. package/lib/Signal/Group/index.d.ts +0 -11
  114. package/lib/Signal/Group/keyhelper.d.ts +0 -10
  115. package/lib/Signal/Group/queue-job.d.ts +0 -1
  116. package/lib/Signal/Group/queue-job.js +0 -57
  117. package/lib/Signal/Group/sender-chain-key.d.ts +0 -13
  118. package/lib/Signal/Group/sender-key-distribution-message.d.ts +0 -16
  119. package/lib/Signal/Group/sender-key-message.d.ts +0 -18
  120. package/lib/Signal/Group/sender-key-name.d.ts +0 -17
  121. package/lib/Signal/Group/sender-key-record.d.ts +0 -30
  122. package/lib/Signal/Group/sender-key-state.d.ts +0 -38
  123. package/lib/Signal/Group/sender-message-key.d.ts +0 -11
  124. package/lib/Signal/libsignal.d.ts +0 -3
  125. package/lib/Socket/Client/abstract-socket-client.d.ts +0 -17
  126. package/lib/Socket/Client/abstract-socket-client.js +0 -13
  127. package/lib/Socket/Client/index.d.ts +0 -3
  128. package/lib/Socket/Client/mobile-socket-client.d.ts +0 -13
  129. package/lib/Socket/Client/mobile-socket-client.js +0 -65
  130. package/lib/Socket/Client/web-socket-client.d.ts +0 -12
  131. package/lib/Socket/Client/web-socket-client.js +0 -62
  132. package/lib/Socket/business.d.ts +0 -171
  133. package/lib/Socket/chats.d.ts +0 -80
  134. package/lib/Socket/dugong.d.ts +0 -219
  135. package/lib/Socket/dugong.js +0 -441
  136. package/lib/Socket/groups.d.ts +0 -115
  137. package/lib/Socket/index.d.ts +0 -173
  138. package/lib/Socket/messages-recv.d.ts +0 -161
  139. package/lib/Socket/messages-send.d.ts +0 -149
  140. package/lib/Socket/newsletter.d.ts +0 -134
  141. package/lib/Socket/registration.d.ts +0 -267
  142. package/lib/Socket/registration.js +0 -166
  143. package/lib/Socket/socket.d.ts +0 -43
  144. package/lib/Socket/usync.d.ts +0 -36
  145. package/lib/Socket/usync.js +0 -70
  146. package/lib/Store/index.d.ts +0 -3
  147. package/lib/Store/make-cache-manager-store.d.ts +0 -13
  148. package/lib/Store/make-in-memory-store.d.ts +0 -118
  149. package/lib/Store/make-ordered-dictionary.d.ts +0 -13
  150. package/lib/Store/object-repository.d.ts +0 -10
  151. package/lib/Types/Auth.d.ts +0 -110
  152. package/lib/Types/Call.d.ts +0 -13
  153. package/lib/Types/Chat.d.ts +0 -102
  154. package/lib/Types/Contact.d.ts +0 -19
  155. package/lib/Types/Events.d.ts +0 -157
  156. package/lib/Types/GroupMetadata.d.ts +0 -55
  157. package/lib/Types/Label.d.ts +0 -35
  158. package/lib/Types/LabelAssociation.d.ts +0 -29
  159. package/lib/Types/Message.d.ts +0 -273
  160. package/lib/Types/Newsletter.d.ts +0 -92
  161. package/lib/Types/Product.d.ts +0 -78
  162. package/lib/Types/Signal.d.ts +0 -57
  163. package/lib/Types/Socket.d.ts +0 -111
  164. package/lib/Types/State.d.ts +0 -27
  165. package/lib/Types/USync.d.ts +0 -25
  166. package/lib/Types/index.d.ts +0 -57
  167. package/lib/Utils/auth-utils.d.ts +0 -18
  168. package/lib/Utils/baileys-event-stream.d.ts +0 -16
  169. package/lib/Utils/business.d.ts +0 -22
  170. package/lib/Utils/chat-utils.d.ts +0 -71
  171. package/lib/Utils/crypto.d.ts +0 -41
  172. package/lib/Utils/decode-wa-message.d.ts +0 -19
  173. package/lib/Utils/event-buffer.d.ts +0 -35
  174. package/lib/Utils/generics.d.ts +0 -92
  175. package/lib/Utils/history.d.ts +0 -15
  176. package/lib/Utils/index.d.ts +0 -17
  177. package/lib/Utils/link-preview.d.ts +0 -21
  178. package/lib/Utils/logger.d.ts +0 -4
  179. package/lib/Utils/lt-hash.d.ts +0 -12
  180. package/lib/Utils/make-mutex.d.ts +0 -7
  181. package/lib/Utils/messages-media.d.ts +0 -116
  182. package/lib/Utils/messages.d.ts +0 -77
  183. package/lib/Utils/noise-handler.d.ts +0 -21
  184. package/lib/Utils/process-message.d.ts +0 -41
  185. package/lib/Utils/signal.d.ts +0 -32
  186. package/lib/Utils/use-multi-file-auth-state.d.ts +0 -13
  187. package/lib/Utils/validate-connection.d.ts +0 -11
  188. package/lib/WABinary/constants.d.ts +0 -27
  189. package/lib/WABinary/decode.d.ts +0 -7
  190. package/lib/WABinary/encode.d.ts +0 -3
  191. package/lib/WABinary/generic-utils.d.ts +0 -16
  192. package/lib/WABinary/index.d.ts +0 -5
  193. package/lib/WABinary/jid-utils.d.ts +0 -31
  194. package/lib/WABinary/types.d.ts +0 -18
  195. package/lib/WAM/BinaryInfo.d.ts +0 -17
  196. package/lib/WAM/constants.d.ts +0 -38
  197. package/lib/WAM/encode.d.ts +0 -3
  198. package/lib/WAM/index.d.ts +0 -3
  199. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +0 -9
  200. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +0 -22
  201. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +0 -12
  202. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +0 -12
  203. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +0 -25
  204. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +0 -8
  205. package/lib/WAUSync/Protocols/index.d.ts +0 -4
  206. package/lib/WAUSync/USyncQuery.d.ts +0 -28
  207. package/lib/WAUSync/USyncUser.d.ts +0 -12
  208. package/lib/WAUSync/index.d.ts +0 -3
  209. package/lib/index.d.ts +0 -12
@@ -1,96 +1,84 @@
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 {
11
- constructor(senderKeyStore, senderKeyName) {
12
- this.senderKeyStore = senderKeyStore;
13
- this.senderKeyName = senderKeyName;
1
+ //=======================================================//
2
+ import { decrypt, encrypt } from "libsignal-xeuka/src/crypto.js";
3
+ import { SenderKeyMessage } from "./sender-key-message.js";
4
+ import { SenderKeyRecord } from "./sender-key-record.js";
5
+ import { SenderKeyState } from "./sender-key-state.js";
6
+ import { SenderKeyName } from "./sender-key-name.js";
7
+ //=======================================================//
8
+ export class GroupCipher {
9
+ constructor(senderKeyStore, senderKeyName) {
10
+ this.senderKeyStore = senderKeyStore;
11
+ this.senderKeyName = senderKeyName;
12
+ }
13
+ async encrypt(paddedPlaintext) {
14
+ const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
15
+ if (!record) {
16
+ throw new Error("No SenderKeyRecord found for encryption");
14
17
  }
15
- queueJob(awaitable) {
16
- return (0, queue_job_1.default)(this.senderKeyName.toString(), awaitable);
18
+ const senderKeyState = record.getSenderKeyState();
19
+ if (!senderKeyState) {
20
+ throw new Error("No session to encrypt message");
17
21
  }
18
- 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
- });
22
+ const iteration = senderKeyState.getSenderChainKey().getIteration();
23
+ const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1);
24
+ const ciphertext = await this.getCipherText(senderKey.getIv(), senderKey.getCipherKey(), paddedPlaintext);
25
+ const senderKeyMessage = new SenderKeyMessage(senderKeyState.getKeyId(), senderKey.getIteration(), ciphertext, senderKeyState.getSigningKeyPrivate());
26
+ await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
27
+ return senderKeyMessage.serialize();
28
+ }
29
+ async decrypt(senderKeyMessageBytes) {
30
+ const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
31
+ if (!record) {
32
+ throw new Error("No SenderKeyRecord found for decryption");
35
33
  }
36
- 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
- });
34
+ const senderKeyMessage = new SenderKeyMessage(null, null, null, null, senderKeyMessageBytes);
35
+ const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId());
36
+ if (!senderKeyState) {
37
+ throw new Error("No session found to decrypt message");
53
38
  }
54
- getSenderKey(senderKeyState, iteration) {
55
- let senderChainKey = senderKeyState.getSenderChainKey();
56
- if (senderChainKey.getIteration() > iteration) {
57
- if (senderKeyState.hasSenderMessageKey(iteration)) {
58
- const messageKey = senderKeyState.removeSenderMessageKey(iteration);
59
- if (!messageKey) {
60
- throw new Error('No sender message key found for iteration');
61
- }
62
- return messageKey;
63
- }
64
- throw new Error(`Received message with old counter: ${senderChainKey.getIteration()}, ${iteration}`);
39
+ senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic());
40
+ const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration());
41
+ const plaintext = await this.getPlainText(senderKey.getIv(), senderKey.getCipherKey(), senderKeyMessage.getCipherText());
42
+ await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
43
+ return plaintext;
44
+ }
45
+ getSenderKey(senderKeyState, iteration) {
46
+ let senderChainKey = senderKeyState.getSenderChainKey();
47
+ if (senderChainKey.getIteration() > iteration) {
48
+ if (senderKeyState.hasSenderMessageKey(iteration)) {
49
+ const messageKey = senderKeyState.removeSenderMessageKey(iteration);
50
+ if (!messageKey) {
51
+ throw new Error("No sender message key found for iteration");
65
52
  }
66
- if (iteration - senderChainKey.getIteration() > 2000) {
67
- throw new Error('Over 2000 messages into the future!');
68
- }
69
- while (senderChainKey.getIteration() < iteration) {
70
- senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey());
71
- senderChainKey = senderChainKey.getNext();
72
- }
73
- senderKeyState.setSenderChainKey(senderChainKey.getNext());
74
- return senderChainKey.getSenderMessageKey();
53
+ return messageKey;
54
+ }
55
+ throw new Error(`Received message with old counter: ${senderChainKey.getIteration()}, ${iteration}`);
75
56
  }
76
- async getPlainText(iv, key, ciphertext) {
77
- try {
78
- return (0, crypto_1.decrypt)(key, ciphertext, iv);
79
- }
80
- catch (e) {
81
- throw new Error('InvalidMessageException');
82
- }
57
+ if (iteration - senderChainKey.getIteration() > 2000) {
58
+ throw new Error("Over 2000 messages into the future!");
83
59
  }
84
- async getCipherText(iv, key, plaintext) {
85
- 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);
90
- }
91
- catch (e) {
92
- throw new Error('InvalidMessageException');
93
- }
60
+ while (senderChainKey.getIteration() < iteration) {
61
+ senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey());
62
+ senderChainKey = senderChainKey.getNext();
63
+ }
64
+ senderKeyState.setSenderChainKey(senderChainKey.getNext());
65
+ return senderChainKey.getSenderMessageKey();
66
+ }
67
+ async getPlainText(iv, key, ciphertext) {
68
+ try {
69
+ return decrypt(key, ciphertext, iv);
70
+ }
71
+ catch (e) {
72
+ throw new Error("InvalidMessageException");
73
+ }
74
+ }
75
+ async getCipherText(iv, key, plaintext) {
76
+ try {
77
+ return encrypt(key, plaintext, iv);
78
+ }
79
+ catch (e) {
80
+ throw new Error("InvalidMessageException");
94
81
  }
82
+ }
95
83
  }
96
- exports.GroupCipher = GroupCipher;
84
+ //=======================================================//
@@ -1,57 +1,13 @@
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
+ //=======================================================//
2
+ export { SenderKeyDistributionMessage } from "./sender-key-distribution-message.js";
3
+ export { GroupSessionBuilder } from "./group-session-builder.js";
4
+ export { CiphertextMessage } from "./ciphertext-message.js";
5
+ export { SenderKeyMessage } from "./sender-key-message.js";
6
+ export { SenderMessageKey } from "./sender-message-key.js";
7
+ export { SenderKeyRecord } from "./sender-key-record.js";
8
+ export { SenderKeyState } from "./sender-key-state.js";
9
+ export { SenderChainKey } from "./sender-chain-key.js";
10
+ export { SenderKeyName } from "./sender-key-name.js";
11
+ export { GroupCipher } from "./group_cipher.js";
12
+ export * as keyhelper from "./keyhelper.js";
13
+ //=======================================================//
@@ -1,55 +1,20 @@
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() {
42
- return nodeCrypto.randomBytes(32);
1
+ //=======================================================//
2
+ import { generateKeyPair } from "libsignal-xeuka/src/curve.js";
3
+ import * as nodeCrypto from "crypto";
4
+ //=======================================================//
5
+ export function generateSenderKey() {
6
+ return nodeCrypto.randomBytes(32);
43
7
  }
44
- function generateSenderKeyId() {
45
- return nodeCrypto.randomInt(2147483647);
8
+ export function generateSenderKeyId() {
9
+ return nodeCrypto.randomInt(2147483647);
46
10
  }
47
- function generateSenderSigningKey(key) {
48
- if (!key) {
49
- key = (0, curve_1.generateKeyPair)();
50
- }
51
- return {
52
- public: Buffer.from(key.pubKey),
53
- private: Buffer.from(key.privKey)
54
- };
11
+ export function generateSenderSigningKey(key) {
12
+ if (!key) {
13
+ key = generateKeyPair();
14
+ }
15
+ return {
16
+ public: Buffer.from(key.pubKey),
17
+ private: Buffer.from(key.privKey)
18
+ };
55
19
  }
20
+ //=======================================================//
@@ -1,34 +1,28 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SenderChainKey = void 0;
4
- const crypto_1 = require("libsignal/src/crypto");
5
- const sender_message_key_1 = require("./sender-message-key");
6
- class SenderChainKey {
7
- constructor(iteration, chainKey) {
8
- this.MESSAGE_KEY_SEED = Buffer.from([0x01]);
9
- this.CHAIN_KEY_SEED = Buffer.from([0x02]);
10
- this.iteration = iteration;
11
- if (chainKey instanceof Buffer) {
12
- this.chainKey = chainKey;
13
- }
14
- else {
15
- this.chainKey = Buffer.from(chainKey || []);
16
- }
17
- }
18
- getIteration() {
19
- return this.iteration;
20
- }
21
- getSenderMessageKey() {
22
- return new sender_message_key_1.SenderMessageKey(this.iteration, this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey));
23
- }
24
- getNext() {
25
- return new SenderChainKey(this.iteration + 1, this.getDerivative(this.CHAIN_KEY_SEED, this.chainKey));
26
- }
27
- getSeed() {
28
- return this.chainKey;
29
- }
30
- getDerivative(seed, key) {
31
- return (0, crypto_1.calculateMAC)(key, seed);
32
- }
1
+ //=======================================================//
2
+ import { calculateMAC } from "libsignal-xeuka/src/crypto.js";
3
+ import { SenderMessageKey } from "./sender-message-key.js";
4
+ //=======================================================//
5
+ export class SenderChainKey {
6
+ constructor(iteration, chainKey) {
7
+ this.MESSAGE_KEY_SEED = Buffer.from([0x01]);
8
+ this.CHAIN_KEY_SEED = Buffer.from([0x02]);
9
+ this.iteration = iteration;
10
+ this.chainKey = Buffer.from(chainKey);
11
+ }
12
+ getIteration() {
13
+ return this.iteration;
14
+ }
15
+ getSenderMessageKey() {
16
+ return new SenderMessageKey(this.iteration, this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey));
17
+ }
18
+ getNext() {
19
+ return new SenderChainKey(this.iteration + 1, this.getDerivative(this.CHAIN_KEY_SEED, this.chainKey));
20
+ }
21
+ getSeed() {
22
+ return this.chainKey;
23
+ }
24
+ getDerivative(seed, key) {
25
+ return calculateMAC(key, seed);
26
+ }
33
27
  }
34
- exports.SenderChainKey = SenderChainKey;
28
+ //=======================================================//
@@ -1,66 +1,65 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SenderKeyDistributionMessage = void 0;
4
- const WAProto_1 = require("../../../WAProto");
5
- const ciphertext_message_1 = require("./ciphertext-message");
6
- class SenderKeyDistributionMessage extends ciphertext_message_1.CiphertextMessage {
7
- constructor(id, iteration, chainKey, signatureKey, serialized) {
8
- super();
9
- if (serialized) {
10
- try {
11
- const message = serialized.slice(1);
12
- const distributionMessage = WAProto_1.proto.SenderKeyDistributionMessage.decode(message).toJSON();
13
- this.serialized = serialized;
14
- this.id = distributionMessage.id;
15
- this.iteration = distributionMessage.iteration;
16
- this.chainKey =
17
- typeof distributionMessage.chainKey === 'string'
18
- ? Buffer.from(distributionMessage.chainKey, 'base64')
19
- : distributionMessage.chainKey;
20
- this.signatureKey =
21
- typeof distributionMessage.signingKey === 'string'
22
- ? Buffer.from(distributionMessage.signingKey, 'base64')
23
- : distributionMessage.signingKey;
24
- }
25
- catch (e) {
26
- throw new Error(String(e));
27
- }
28
- }
29
- else {
30
- const version = this.intsToByteHighAndLow(this.CURRENT_VERSION, this.CURRENT_VERSION);
31
- this.id = id;
32
- this.iteration = iteration;
33
- this.chainKey = chainKey;
34
- this.signatureKey = signatureKey;
35
- const message = WAProto_1.proto.SenderKeyDistributionMessage.encode(WAProto_1.proto.SenderKeyDistributionMessage.create({
36
- id,
37
- iteration,
38
- chainKey,
39
- signingKey: this.signatureKey
40
- })).finish();
41
- this.serialized = Buffer.concat([Buffer.from([version]), message]);
42
- }
1
+ //=======================================================//
2
+ import { CiphertextMessage } from "./ciphertext-message.js";
3
+ import { proto } from "../../../WAProto/index.js";
4
+ //=======================================================//
5
+ export class SenderKeyDistributionMessage extends CiphertextMessage {
6
+ constructor(id, iteration, chainKey, signatureKey, serialized) {
7
+ super();
8
+ if (serialized) {
9
+ try {
10
+ const message = serialized.slice(1);
11
+ const distributionMessage = proto.SenderKeyDistributionMessage.decode(message).toJSON();
12
+ this.serialized = serialized;
13
+ this.id = distributionMessage.id;
14
+ this.iteration = distributionMessage.iteration;
15
+ this.chainKey =
16
+ typeof distributionMessage.chainKey === "string"
17
+ ? Buffer.from(distributionMessage.chainKey, "base64")
18
+ : distributionMessage.chainKey;
19
+ this.signatureKey =
20
+ typeof distributionMessage.signingKey === "string"
21
+ ? Buffer.from(distributionMessage.signingKey, "base64")
22
+ : distributionMessage.signingKey;
23
+ }
24
+ catch (e) {
25
+ throw new Error(String(e));
26
+ }
43
27
  }
44
- intsToByteHighAndLow(highValue, lowValue) {
45
- return (((highValue << 4) | lowValue) & 0xff) % 256;
46
- }
47
- serialize() {
48
- return this.serialized;
49
- }
50
- getType() {
51
- return this.SENDERKEY_DISTRIBUTION_TYPE;
52
- }
53
- getIteration() {
54
- return this.iteration;
55
- }
56
- getChainKey() {
57
- return typeof this.chainKey === 'string' ? Buffer.from(this.chainKey, 'base64') : this.chainKey;
58
- }
59
- getSignatureKey() {
60
- return typeof this.signatureKey === 'string' ? Buffer.from(this.signatureKey, 'base64') : this.signatureKey;
61
- }
62
- getId() {
63
- return this.id;
28
+ else {
29
+ const version = this.intsToByteHighAndLow(this.CURRENT_VERSION, this.CURRENT_VERSION);
30
+ this.id = id;
31
+ this.iteration = iteration;
32
+ this.chainKey = chainKey;
33
+ this.signatureKey = signatureKey;
34
+ const message = proto.SenderKeyDistributionMessage.encode(proto.SenderKeyDistributionMessage.create({
35
+ id,
36
+ iteration,
37
+ chainKey,
38
+ signingKey: this.signatureKey
39
+ })).finish();
40
+ this.serialized = Buffer.concat([Buffer.from([version]), message]);
64
41
  }
42
+ }
43
+ intsToByteHighAndLow(highValue, lowValue) {
44
+ return (((highValue << 4) | lowValue) & 0xff) % 256;
45
+ }
46
+ serialize() {
47
+ return this.serialized;
48
+ }
49
+ getType() {
50
+ return this.SENDERKEY_DISTRIBUTION_TYPE;
51
+ }
52
+ getIteration() {
53
+ return this.iteration;
54
+ }
55
+ getChainKey() {
56
+ return this.chainKey;
57
+ }
58
+ getSignatureKey() {
59
+ return this.signatureKey;
60
+ }
61
+ getId() {
62
+ return this.id;
63
+ }
65
64
  }
66
- exports.SenderKeyDistributionMessage = SenderKeyDistributionMessage;
65
+ //=======================================================//