@skyzopedia/baileys-mod 5.0.7 → 6.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (210) hide show
  1. package/WAProto/index.js +133384 -57814
  2. package/engine-requirements.js +10 -0
  3. package/lib/Defaults/baileys-version.json +3 -0
  4. package/lib/Defaults/index.d.ts +53 -0
  5. package/lib/Defaults/index.js +141 -117
  6. package/lib/Defaults/phonenumber-mcc.json +223 -0
  7. package/lib/Signal/Group/ciphertext-message.d.ts +9 -0
  8. package/lib/Signal/Group/ciphertext-message.js +14 -12
  9. package/lib/Signal/Group/group-session-builder.d.ts +14 -0
  10. package/lib/Signal/Group/group-session-builder.js +42 -10
  11. package/lib/Signal/Group/group_cipher.d.ts +17 -0
  12. package/lib/Signal/Group/group_cipher.js +87 -75
  13. package/lib/Signal/Group/index.d.ts +11 -0
  14. package/lib/Signal/Group/index.js +57 -13
  15. package/lib/Signal/Group/keyhelper.d.ts +10 -0
  16. package/lib/Signal/Group/keyhelper.js +52 -17
  17. package/lib/Signal/Group/queue-job.d.ts +1 -0
  18. package/lib/Signal/Group/queue-job.js +57 -0
  19. package/lib/Signal/Group/sender-chain-key.d.ts +13 -0
  20. package/lib/Signal/Group/sender-chain-key.js +33 -27
  21. package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
  22. package/lib/Signal/Group/sender-key-distribution-message.js +63 -62
  23. package/lib/Signal/Group/sender-key-message.d.ts +18 -0
  24. package/lib/Signal/Group/sender-key-message.js +66 -65
  25. package/lib/Signal/Group/sender-key-name.d.ts +17 -0
  26. package/lib/Signal/Group/sender-key-name.js +44 -45
  27. package/lib/Signal/Group/sender-key-record.d.ts +30 -0
  28. package/lib/Signal/Group/sender-key-record.js +49 -39
  29. package/lib/Signal/Group/sender-key-state.d.ts +38 -0
  30. package/lib/Signal/Group/sender-key-state.js +93 -80
  31. package/lib/Signal/Group/sender-message-key.d.ts +11 -0
  32. package/lib/Signal/Group/sender-message-key.js +28 -27
  33. package/lib/Signal/libsignal.d.ts +3 -0
  34. package/lib/Signal/libsignal.js +163 -313
  35. package/lib/Socket/Client/abstract-socket-client.d.ts +17 -0
  36. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  37. package/lib/Socket/Client/index.d.ts +3 -0
  38. package/lib/Socket/Client/index.js +19 -4
  39. package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
  40. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  41. package/lib/Socket/Client/web-socket-client.d.ts +12 -0
  42. package/lib/Socket/Client/web-socket-client.js +62 -0
  43. package/lib/Socket/business.d.ts +171 -0
  44. package/lib/Socket/business.js +242 -359
  45. package/lib/Socket/chats.d.ts +267 -0
  46. package/lib/Socket/chats.js +935 -846
  47. package/lib/Socket/dugong.d.ts +254 -0
  48. package/lib/Socket/dugong.js +484 -0
  49. package/lib/Socket/groups.d.ts +115 -0
  50. package/lib/Socket/groups.js +309 -304
  51. package/lib/Socket/index.d.ts +173 -0
  52. package/lib/Socket/index.js +10 -15
  53. package/lib/Socket/messages-recv.d.ts +161 -0
  54. package/lib/Socket/messages-recv.js +1054 -1107
  55. package/lib/Socket/messages-send.d.ts +149 -0
  56. package/lib/Socket/messages-send.js +447 -706
  57. package/lib/Socket/newsletter.d.ts +134 -0
  58. package/lib/Socket/newsletter.js +314 -199
  59. package/lib/Socket/registration.d.ts +267 -0
  60. package/lib/Socket/registration.js +166 -0
  61. package/lib/Socket/socket.d.ts +43 -0
  62. package/lib/Socket/socket.js +650 -777
  63. package/lib/Socket/usync.d.ts +36 -0
  64. package/lib/Socket/usync.js +70 -0
  65. package/lib/Store/index.d.ts +3 -0
  66. package/lib/Store/index.js +10 -6
  67. package/lib/Store/make-cache-manager-store.d.ts +13 -0
  68. package/lib/Store/make-cache-manager-store.js +81 -73
  69. package/lib/Store/make-in-memory-store.d.ts +118 -0
  70. package/lib/Store/make-in-memory-store.js +423 -286
  71. package/lib/Store/make-ordered-dictionary.d.ts +13 -0
  72. package/lib/Store/make-ordered-dictionary.js +79 -77
  73. package/lib/Store/object-repository.d.ts +10 -0
  74. package/lib/Store/object-repository.js +26 -24
  75. package/lib/Types/Auth.d.ts +110 -0
  76. package/lib/Types/Auth.js +2 -3
  77. package/lib/Types/Call.d.ts +13 -0
  78. package/lib/Types/Call.js +2 -3
  79. package/lib/Types/Chat.d.ts +102 -0
  80. package/lib/Types/Chat.js +4 -9
  81. package/lib/Types/Contact.d.ts +19 -0
  82. package/lib/Types/Contact.js +2 -3
  83. package/lib/Types/Events.d.ts +157 -0
  84. package/lib/Types/Events.js +2 -3
  85. package/lib/Types/GroupMetadata.d.ts +55 -0
  86. package/lib/Types/GroupMetadata.js +2 -3
  87. package/lib/Types/Label.d.ts +35 -0
  88. package/lib/Types/Label.js +26 -24
  89. package/lib/Types/LabelAssociation.d.ts +29 -0
  90. package/lib/Types/LabelAssociation.js +8 -6
  91. package/lib/Types/Message.d.ts +273 -0
  92. package/lib/Types/Message.js +9 -12
  93. package/lib/Types/Newsletter.d.ts +103 -0
  94. package/lib/Types/Newsletter.js +38 -33
  95. package/lib/Types/Product.d.ts +78 -0
  96. package/lib/Types/Product.js +2 -3
  97. package/lib/Types/Signal.d.ts +57 -0
  98. package/lib/Types/Signal.js +2 -3
  99. package/lib/Types/Socket.d.ts +111 -0
  100. package/lib/Types/Socket.js +2 -4
  101. package/lib/Types/State.d.ts +27 -0
  102. package/lib/Types/State.js +2 -11
  103. package/lib/Types/USync.d.ts +25 -0
  104. package/lib/Types/USync.js +2 -3
  105. package/lib/Types/index.d.ts +57 -0
  106. package/lib/Types/index.js +41 -27
  107. package/lib/Utils/auth-utils.d.ts +18 -0
  108. package/lib/Utils/auth-utils.js +198 -211
  109. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  110. package/lib/Utils/baileys-event-stream.js +61 -42
  111. package/lib/Utils/business.d.ts +22 -0
  112. package/lib/Utils/business.js +214 -213
  113. package/lib/Utils/chat-utils.d.ts +71 -0
  114. package/lib/Utils/chat-utils.js +687 -710
  115. package/lib/Utils/crypto.d.ts +41 -0
  116. package/lib/Utils/crypto.js +133 -112
  117. package/lib/Utils/decode-wa-message.d.ts +19 -0
  118. package/lib/Utils/decode-wa-message.js +183 -252
  119. package/lib/Utils/event-buffer.d.ts +35 -0
  120. package/lib/Utils/event-buffer.js +496 -510
  121. package/lib/Utils/generics.d.ts +92 -0
  122. package/lib/Utils/generics.js +387 -319
  123. package/lib/Utils/history.d.ts +15 -0
  124. package/lib/Utils/history.js +92 -83
  125. package/lib/Utils/index.d.ts +17 -0
  126. package/lib/Utils/index.js +33 -21
  127. package/lib/Utils/link-preview.d.ts +21 -0
  128. package/lib/Utils/link-preview.js +83 -71
  129. package/lib/Utils/logger.d.ts +4 -0
  130. package/lib/Utils/logger.js +7 -5
  131. package/lib/Utils/lt-hash.d.ts +12 -0
  132. package/lib/Utils/lt-hash.js +46 -40
  133. package/lib/Utils/make-mutex.d.ts +7 -0
  134. package/lib/Utils/make-mutex.js +41 -34
  135. package/lib/Utils/messages-media.d.ts +116 -0
  136. package/lib/Utils/messages-media.js +768 -550
  137. package/lib/Utils/messages.d.ts +77 -0
  138. package/lib/Utils/messages.js +263 -362
  139. package/lib/Utils/noise-handler.d.ts +21 -0
  140. package/lib/Utils/noise-handler.js +149 -138
  141. package/lib/Utils/process-message.d.ts +41 -0
  142. package/lib/Utils/process-message.js +303 -323
  143. package/lib/Utils/signal.d.ts +32 -0
  144. package/lib/Utils/signal.js +141 -149
  145. package/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
  146. package/lib/Utils/use-multi-file-auth-state.js +103 -95
  147. package/lib/Utils/validate-connection.d.ts +11 -0
  148. package/lib/Utils/validate-connection.js +220 -183
  149. package/lib/WABinary/constants.d.ts +30 -0
  150. package/lib/WABinary/constants.js +35 -1298
  151. package/lib/WABinary/decode.d.ts +7 -0
  152. package/lib/WABinary/decode.js +249 -237
  153. package/lib/WABinary/encode.d.ts +3 -0
  154. package/lib/WABinary/encode.js +260 -213
  155. package/lib/WABinary/generic-utils.d.ts +17 -0
  156. package/lib/WABinary/generic-utils.js +65 -56
  157. package/lib/WABinary/index.d.ts +5 -0
  158. package/lib/WABinary/index.js +21 -7
  159. package/lib/WABinary/jid-utils.d.ts +31 -0
  160. package/lib/WABinary/jid-utils.js +58 -89
  161. package/lib/WABinary/types.d.ts +18 -0
  162. package/lib/WABinary/types.js +2 -3
  163. package/lib/WAM/BinaryInfo.d.ts +17 -0
  164. package/lib/WAM/BinaryInfo.js +12 -10
  165. package/lib/WAM/constants.d.ts +38 -0
  166. package/lib/WAM/constants.js +15348 -22851
  167. package/lib/WAM/encode.d.ts +3 -0
  168. package/lib/WAM/encode.js +136 -135
  169. package/lib/WAM/index.d.ts +3 -0
  170. package/lib/WAM/index.js +19 -5
  171. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
  172. package/lib/WAUSync/Protocols/USyncContactProtocol.js +30 -28
  173. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
  174. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +53 -49
  175. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
  176. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +28 -27
  177. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
  178. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +39 -36
  179. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +25 -0
  180. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +50 -50
  181. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +8 -0
  182. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +20 -26
  183. package/lib/WAUSync/Protocols/index.d.ts +4 -0
  184. package/lib/WAUSync/Protocols/index.js +20 -6
  185. package/lib/WAUSync/USyncQuery.d.ts +28 -0
  186. package/lib/WAUSync/USyncQuery.js +85 -86
  187. package/lib/WAUSync/USyncUser.d.ts +12 -0
  188. package/lib/WAUSync/USyncUser.js +25 -23
  189. package/lib/WAUSync/index.d.ts +3 -0
  190. package/lib/WAUSync/index.js +19 -5
  191. package/lib/index.d.ts +12 -0
  192. package/lib/index.js +36 -24
  193. package/package.json +106 -98
  194. package/LICENSE +0 -21
  195. package/WAProto/WAProto.proto +0 -5311
  196. package/lib/KeyDB/BinarySearch.js +0 -20
  197. package/lib/KeyDB/KeyedDB.js +0 -167
  198. package/lib/KeyDB/index.js +0 -4
  199. package/lib/Signal/lid-mapping.js +0 -155
  200. package/lib/Socket/Client/types.js +0 -13
  201. package/lib/Socket/Client/websocket.js +0 -52
  202. package/lib/Socket/Client/websocket.js.bak +0 -53
  203. package/lib/Socket/communities.js +0 -413
  204. package/lib/Socket/mex.js +0 -45
  205. package/lib/Types/Bussines.js +0 -3
  206. package/lib/Types/Newsletter.js.bak +0 -33
  207. package/lib/Utils/browser-utils.js +0 -25
  208. package/lib/Utils/message-retry-manager.js +0 -113
  209. package/lib/Utils/messages.js.bak +0 -907
  210. package/lib/Utils/pre-key-manager.js +0 -85
@@ -1,10 +1,42 @@
1
- //=======================================================//
2
- import { SenderKeyDistributionMessage } from "./sender-key-distribution-message.js";
3
- import { SenderKeyRecord } from "./sender-key-record.js";
4
- import { SenderKeyName } from "./sender-key-name.js";
5
- import * as keyhelper from "./keyhelper.js";
6
- //=======================================================//
7
- export class GroupSessionBuilder {
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 {
8
40
  constructor(senderKeyStore) {
9
41
  this.senderKeyStore = senderKeyStore;
10
42
  }
@@ -24,9 +56,9 @@ export class GroupSessionBuilder {
24
56
  }
25
57
  const state = senderKeyRecord.getSenderKeyState();
26
58
  if (!state) {
27
- throw new Error("No session state available");
59
+ throw new Error('No session state available');
28
60
  }
29
- return new SenderKeyDistributionMessage(state.getKeyId(), state.getSenderChainKey().getIteration(), state.getSenderChainKey().getSeed(), state.getSigningKeyPublic());
61
+ return new sender_key_distribution_message_1.SenderKeyDistributionMessage(state.getKeyId(), state.getSenderChainKey().getIteration(), state.getSenderChainKey().getSeed(), state.getSigningKeyPublic());
30
62
  }
31
63
  }
32
- //# sourceMappingURL=group-session-builder.js.map
64
+ exports.GroupSessionBuilder = GroupSessionBuilder;
@@ -0,0 +1,17 @@
1
+ import { SenderKeyName } from './sender-key-name';
2
+ import { SenderKeyRecord } from './sender-key-record';
3
+ export interface SenderKeyStore {
4
+ loadSenderKey(senderKeyName: SenderKeyName): Promise<SenderKeyRecord>;
5
+ storeSenderKey(senderKeyName: SenderKeyName, record: SenderKeyRecord): Promise<void>;
6
+ }
7
+ export declare class GroupCipher {
8
+ private readonly senderKeyStore;
9
+ private readonly senderKeyName;
10
+ constructor(senderKeyStore: SenderKeyStore, senderKeyName: SenderKeyName);
11
+ private queueJob;
12
+ encrypt(paddedPlaintext: Uint8Array | string): Promise<Uint8Array>;
13
+ decrypt(senderKeyMessageBytes: Uint8Array): Promise<Uint8Array>;
14
+ private getSenderKey;
15
+ private getPlainText;
16
+ private getCipherText;
17
+ }
@@ -1,84 +1,96 @@
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");
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;
17
14
  }
18
- const senderKeyState = record.getSenderKeyState();
19
- if (!senderKeyState) {
20
- throw new Error("No session to encrypt message");
15
+ queueJob(awaitable) {
16
+ return (0, queue_job_1.default)(this.senderKeyName.toString(), awaitable);
21
17
  }
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");
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
+ });
33
35
  }
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");
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
+ });
38
53
  }
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");
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}`);
52
65
  }
53
- return messageKey;
54
- }
55
- throw new Error(`Received message with old counter: ${senderChainKey.getIteration()}, ${iteration}`);
56
- }
57
- if (iteration - senderChainKey.getIteration() > 2000) {
58
- throw new Error("Over 2000 messages into the future!");
59
- }
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");
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();
73
75
  }
74
- }
75
- async getCipherText(iv, key, plaintext) {
76
- try {
77
- return encrypt(key, plaintext, iv);
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
+ }
78
83
  }
79
- catch (e) {
80
- throw new Error("InvalidMessageException");
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
+ }
81
94
  }
82
- }
83
95
  }
84
- //=======================================================//
96
+ exports.GroupCipher = GroupCipher;
@@ -0,0 +1,11 @@
1
+ export { GroupSessionBuilder } from './group-session-builder';
2
+ export { SenderKeyDistributionMessage } from './sender-key-distribution-message';
3
+ export { SenderKeyRecord } from './sender-key-record';
4
+ export { SenderKeyName } from './sender-key-name';
5
+ export { GroupCipher } from './group_cipher';
6
+ export { SenderKeyState } from './sender-key-state';
7
+ export { SenderKeyMessage } from './sender-key-message';
8
+ export { SenderMessageKey } from './sender-message-key';
9
+ export { SenderChainKey } from './sender-chain-key';
10
+ export { CiphertextMessage } from './ciphertext-message';
11
+ export * as keyhelper from './keyhelper';
@@ -1,13 +1,57 @@
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
+ "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"));
@@ -0,0 +1,10 @@
1
+ import { generateKeyPair } from 'libsignal/src/curve';
2
+ type KeyPairType = ReturnType<typeof generateKeyPair>;
3
+ export declare function generateSenderKey(): Buffer;
4
+ export declare function generateSenderKeyId(): number;
5
+ export interface SigningKeyPair {
6
+ public: Buffer;
7
+ private: Buffer;
8
+ }
9
+ export declare function generateSenderSigningKey(key?: KeyPairType): SigningKeyPair;
10
+ export {};
@@ -1,20 +1,55 @@
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);
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);
7
43
  }
8
- export function generateSenderKeyId() {
9
- return nodeCrypto.randomInt(2147483647);
44
+ function generateSenderKeyId() {
45
+ return nodeCrypto.randomInt(2147483647);
10
46
  }
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
- };
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
+ };
19
55
  }
20
- //=======================================================//
@@ -0,0 +1 @@
1
+ export default function queueJob<T>(bucket: string | number, awaitable: () => Promise<T>): Promise<T>;
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.default = queueJob;
4
+ const _queueAsyncBuckets = new Map();
5
+ const _gcLimit = 10000;
6
+ async function _asyncQueueExecutor(queue, cleanup) {
7
+ let offt = 0;
8
+ // eslint-disable-next-line no-constant-condition
9
+ while (true) {
10
+ const limit = Math.min(queue.length, _gcLimit);
11
+ for (let i = offt; i < limit; i++) {
12
+ const job = queue[i];
13
+ try {
14
+ job.resolve(await job.awaitable());
15
+ }
16
+ catch (e) {
17
+ job.reject(e);
18
+ }
19
+ }
20
+ if (limit < queue.length) {
21
+ if (limit >= _gcLimit) {
22
+ queue.splice(0, limit);
23
+ offt = 0;
24
+ }
25
+ else {
26
+ offt = limit;
27
+ }
28
+ }
29
+ else {
30
+ break;
31
+ }
32
+ }
33
+ cleanup();
34
+ }
35
+ function queueJob(bucket, awaitable) {
36
+ // Skip name assignment since it's readonly in strict mode
37
+ if (typeof bucket !== 'string') {
38
+ console.warn('Unhandled bucket type (for naming):', typeof bucket, bucket);
39
+ }
40
+ let inactive = false;
41
+ if (!_queueAsyncBuckets.has(bucket)) {
42
+ _queueAsyncBuckets.set(bucket, []);
43
+ inactive = true;
44
+ }
45
+ const queue = _queueAsyncBuckets.get(bucket);
46
+ const job = new Promise((resolve, reject) => {
47
+ queue.push({
48
+ awaitable,
49
+ resolve: resolve,
50
+ reject
51
+ });
52
+ });
53
+ if (inactive) {
54
+ _asyncQueueExecutor(queue, () => _queueAsyncBuckets.delete(bucket));
55
+ }
56
+ return job;
57
+ }
@@ -0,0 +1,13 @@
1
+ import { SenderMessageKey } from './sender-message-key';
2
+ export declare class SenderChainKey {
3
+ private readonly MESSAGE_KEY_SEED;
4
+ private readonly CHAIN_KEY_SEED;
5
+ private readonly iteration;
6
+ private readonly chainKey;
7
+ constructor(iteration: number, chainKey: any);
8
+ getIteration(): number;
9
+ getSenderMessageKey(): SenderMessageKey;
10
+ getNext(): SenderChainKey;
11
+ getSeed(): Uint8Array;
12
+ private getDerivative;
13
+ }
@@ -1,28 +1,34 @@
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
- }
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
+ }
27
33
  }
28
- //=======================================================//
34
+ exports.SenderChainKey = SenderChainKey;
@@ -0,0 +1,16 @@
1
+ import { CiphertextMessage } from './ciphertext-message';
2
+ export declare class SenderKeyDistributionMessage extends CiphertextMessage {
3
+ private readonly id;
4
+ private readonly iteration;
5
+ private readonly chainKey;
6
+ private readonly signatureKey;
7
+ private readonly serialized;
8
+ constructor(id?: number | null, iteration?: number | null, chainKey?: Uint8Array | null, signatureKey?: Uint8Array | null, serialized?: Uint8Array | null);
9
+ private intsToByteHighAndLow;
10
+ serialize(): Uint8Array;
11
+ getType(): number;
12
+ getIteration(): number;
13
+ getChainKey(): Uint8Array;
14
+ getSignatureKey(): Uint8Array;
15
+ getId(): number;
16
+ }