@dappaoffc/baileys-mod 6.0.23 → 8.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.

Potentially problematic release.


This version of @dappaoffc/baileys-mod might be problematic. Click here for more details.

Files changed (212) hide show
  1. package/LICENSE +21 -0
  2. package/WAProto/WAProto.proto +5311 -0
  3. package/WAProto/index.js +65801 -141371
  4. package/lib/Defaults/index.js +117 -141
  5. package/lib/KeyDB/BinarySearch.js +20 -0
  6. package/lib/KeyDB/KeyedDB.js +167 -0
  7. package/lib/KeyDB/index.js +4 -0
  8. package/lib/Signal/Group/ciphertext-message.js +12 -14
  9. package/lib/Signal/Group/group-session-builder.js +10 -42
  10. package/lib/Signal/Group/group_cipher.js +75 -87
  11. package/lib/Signal/Group/index.js +13 -57
  12. package/lib/Signal/Group/keyhelper.js +17 -52
  13. package/lib/Signal/Group/sender-chain-key.js +27 -33
  14. package/lib/Signal/Group/sender-key-distribution-message.js +62 -63
  15. package/lib/Signal/Group/sender-key-message.js +65 -66
  16. package/lib/Signal/Group/sender-key-name.js +45 -44
  17. package/lib/Signal/Group/sender-key-record.js +39 -49
  18. package/lib/Signal/Group/sender-key-state.js +80 -93
  19. package/lib/Signal/Group/sender-message-key.js +27 -28
  20. package/lib/Signal/libsignal.js +313 -163
  21. package/lib/Signal/lid-mapping.js +155 -0
  22. package/lib/Socket/Client/index.js +4 -19
  23. package/lib/Socket/Client/types.js +13 -0
  24. package/lib/Socket/Client/websocket.js +52 -0
  25. package/lib/Socket/Client/websocket.js.bak +53 -0
  26. package/lib/Socket/business.js +359 -242
  27. package/lib/Socket/chats.js +846 -935
  28. package/lib/Socket/communities.js +413 -0
  29. package/lib/Socket/groups.js +304 -309
  30. package/lib/Socket/index.js +15 -10
  31. package/lib/Socket/messages-recv.js +1107 -1054
  32. package/lib/Socket/messages-send.js +639 -448
  33. package/lib/Socket/mex.js +45 -0
  34. package/lib/Socket/newsletter.js +197 -310
  35. package/lib/Socket/socket.js +791 -651
  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 +33 -38
  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/decode-wa-message.js.bak +267 -0
  67. package/lib/Utils/event-buffer.js +510 -496
  68. package/lib/Utils/generics.js +319 -392
  69. package/lib/Utils/history.js +83 -92
  70. package/lib/Utils/index.js +21 -33
  71. package/lib/Utils/link-preview.js +71 -83
  72. package/lib/Utils/logger.js +5 -7
  73. package/lib/Utils/lt-hash.js +40 -46
  74. package/lib/Utils/make-mutex.js +34 -41
  75. package/lib/Utils/message-retry-manager.js +113 -0
  76. package/lib/Utils/messages-media.js +550 -768
  77. package/lib/Utils/messages.js +354 -263
  78. package/lib/Utils/noise-handler.js +138 -149
  79. package/lib/Utils/pre-key-manager.js +85 -0
  80. package/lib/Utils/process-message.js +323 -303
  81. package/lib/Utils/signal.js +149 -141
  82. package/lib/Utils/use-multi-file-auth-state.js +95 -103
  83. package/lib/Utils/validate-connection.js +183 -214
  84. package/lib/WABinary/constants.js +1298 -35
  85. package/lib/WABinary/decode.js +237 -249
  86. package/lib/WABinary/encode.js +213 -260
  87. package/lib/WABinary/generic-utils.js +56 -65
  88. package/lib/WABinary/index.js +7 -21
  89. package/lib/WABinary/jid-utils.js +89 -58
  90. package/lib/WABinary/types.js +3 -2
  91. package/lib/WAM/BinaryInfo.js +10 -12
  92. package/lib/WAM/constants.js +22851 -15348
  93. package/lib/WAM/encode.js +135 -136
  94. package/lib/WAM/index.js +5 -19
  95. package/lib/WAUSync/Protocols/USyncContactProtocol.js +28 -30
  96. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +49 -53
  97. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +27 -28
  98. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +36 -39
  99. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +50 -50
  100. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +26 -20
  101. package/lib/WAUSync/Protocols/index.js +6 -20
  102. package/lib/WAUSync/USyncQuery.js +86 -85
  103. package/lib/WAUSync/USyncUser.js +23 -25
  104. package/lib/WAUSync/index.js +5 -19
  105. package/lib/index.js +15 -38
  106. package/package.json +101 -106
  107. package/engine-requirements.js +0 -10
  108. package/lib/Defaults/baileys-version.json +0 -3
  109. package/lib/Defaults/index.d.ts +0 -53
  110. package/lib/Defaults/phonenumber-mcc.json +0 -223
  111. package/lib/Signal/Group/ciphertext-message.d.ts +0 -9
  112. package/lib/Signal/Group/group-session-builder.d.ts +0 -14
  113. package/lib/Signal/Group/group_cipher.d.ts +0 -17
  114. package/lib/Signal/Group/index.d.ts +0 -11
  115. package/lib/Signal/Group/keyhelper.d.ts +0 -10
  116. package/lib/Signal/Group/queue-job.d.ts +0 -1
  117. package/lib/Signal/Group/queue-job.js +0 -57
  118. package/lib/Signal/Group/sender-chain-key.d.ts +0 -13
  119. package/lib/Signal/Group/sender-key-distribution-message.d.ts +0 -16
  120. package/lib/Signal/Group/sender-key-message.d.ts +0 -18
  121. package/lib/Signal/Group/sender-key-name.d.ts +0 -17
  122. package/lib/Signal/Group/sender-key-record.d.ts +0 -30
  123. package/lib/Signal/Group/sender-key-state.d.ts +0 -38
  124. package/lib/Signal/Group/sender-message-key.d.ts +0 -11
  125. package/lib/Signal/libsignal.d.ts +0 -3
  126. package/lib/Socket/Client/abstract-socket-client.d.ts +0 -17
  127. package/lib/Socket/Client/abstract-socket-client.js +0 -13
  128. package/lib/Socket/Client/index.d.ts +0 -3
  129. package/lib/Socket/Client/mobile-socket-client.d.ts +0 -13
  130. package/lib/Socket/Client/mobile-socket-client.js +0 -65
  131. package/lib/Socket/Client/web-socket-client.d.ts +0 -12
  132. package/lib/Socket/Client/web-socket-client.js +0 -62
  133. package/lib/Socket/business.d.ts +0 -171
  134. package/lib/Socket/chats.d.ts +0 -267
  135. package/lib/Socket/dugong.d.ts +0 -254
  136. package/lib/Socket/dugong.js +0 -484
  137. package/lib/Socket/groups.d.ts +0 -115
  138. package/lib/Socket/index.d.ts +0 -173
  139. package/lib/Socket/messages-recv.d.ts +0 -161
  140. package/lib/Socket/messages-send.d.ts +0 -149
  141. package/lib/Socket/newsletter.d.ts +0 -134
  142. package/lib/Socket/registration.d.ts +0 -267
  143. package/lib/Socket/registration.js +0 -166
  144. package/lib/Socket/socket.d.ts +0 -43
  145. package/lib/Socket/usync.d.ts +0 -36
  146. package/lib/Socket/usync.js +0 -70
  147. package/lib/Store/index.d.ts +0 -3
  148. package/lib/Store/make-cache-manager-store.d.ts +0 -13
  149. package/lib/Store/make-in-memory-store.d.ts +0 -118
  150. package/lib/Store/make-ordered-dictionary.d.ts +0 -13
  151. package/lib/Store/object-repository.d.ts +0 -10
  152. package/lib/Types/Auth.d.ts +0 -110
  153. package/lib/Types/Call.d.ts +0 -13
  154. package/lib/Types/Chat.d.ts +0 -102
  155. package/lib/Types/Contact.d.ts +0 -19
  156. package/lib/Types/Events.d.ts +0 -157
  157. package/lib/Types/GroupMetadata.d.ts +0 -55
  158. package/lib/Types/Label.d.ts +0 -35
  159. package/lib/Types/LabelAssociation.d.ts +0 -29
  160. package/lib/Types/Message.d.ts +0 -273
  161. package/lib/Types/Newsletter.d.ts +0 -103
  162. package/lib/Types/Product.d.ts +0 -78
  163. package/lib/Types/Signal.d.ts +0 -57
  164. package/lib/Types/Socket.d.ts +0 -111
  165. package/lib/Types/State.d.ts +0 -27
  166. package/lib/Types/USync.d.ts +0 -25
  167. package/lib/Types/index.d.ts +0 -57
  168. package/lib/Utils/auth-utils.d.ts +0 -18
  169. package/lib/Utils/baileys-event-stream.d.ts +0 -16
  170. package/lib/Utils/business.d.ts +0 -22
  171. package/lib/Utils/chat-utils.d.ts +0 -71
  172. package/lib/Utils/crypto.d.ts +0 -41
  173. package/lib/Utils/decode-wa-message.d.ts +0 -19
  174. package/lib/Utils/event-buffer.d.ts +0 -35
  175. package/lib/Utils/generics.d.ts +0 -92
  176. package/lib/Utils/generics.js.bak +0 -433
  177. package/lib/Utils/history.d.ts +0 -15
  178. package/lib/Utils/index.d.ts +0 -17
  179. package/lib/Utils/link-preview.d.ts +0 -21
  180. package/lib/Utils/logger.d.ts +0 -4
  181. package/lib/Utils/lt-hash.d.ts +0 -12
  182. package/lib/Utils/make-mutex.d.ts +0 -7
  183. package/lib/Utils/messages-media.d.ts +0 -116
  184. package/lib/Utils/messages.d.ts +0 -77
  185. package/lib/Utils/noise-handler.d.ts +0 -21
  186. package/lib/Utils/process-message.d.ts +0 -41
  187. package/lib/Utils/signal.d.ts +0 -32
  188. package/lib/Utils/use-multi-file-auth-state.d.ts +0 -13
  189. package/lib/Utils/validate-connection.d.ts +0 -11
  190. package/lib/Utils/validate-connection.js.bak +0 -237
  191. package/lib/WABinary/constants.d.ts +0 -30
  192. package/lib/WABinary/decode.d.ts +0 -7
  193. package/lib/WABinary/encode.d.ts +0 -3
  194. package/lib/WABinary/generic-utils.d.ts +0 -17
  195. package/lib/WABinary/index.d.ts +0 -5
  196. package/lib/WABinary/jid-utils.d.ts +0 -31
  197. package/lib/WABinary/types.d.ts +0 -18
  198. package/lib/WAM/BinaryInfo.d.ts +0 -17
  199. package/lib/WAM/constants.d.ts +0 -38
  200. package/lib/WAM/encode.d.ts +0 -3
  201. package/lib/WAM/index.d.ts +0 -3
  202. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +0 -9
  203. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +0 -22
  204. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +0 -12
  205. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +0 -12
  206. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +0 -25
  207. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +0 -8
  208. package/lib/WAUSync/Protocols/index.d.ts +0 -4
  209. package/lib/WAUSync/USyncQuery.d.ts +0 -28
  210. package/lib/WAUSync/USyncUser.d.ts +0 -12
  211. package/lib/WAUSync/index.d.ts +0 -3
  212. package/lib/index.d.ts +0 -12
@@ -1,69 +1,68 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SenderKeyMessage = void 0;
4
- const curve_1 = require("libsignal/src/curve");
5
- const WAProto_1 = require("../../../WAProto");
6
- const ciphertext_message_1 = require("./ciphertext-message");
7
- class SenderKeyMessage extends ciphertext_message_1.CiphertextMessage {
8
- constructor(keyId, iteration, ciphertext, signatureKey, serialized) {
9
- super();
10
- this.SIGNATURE_LENGTH = 64;
11
- if (serialized) {
12
- const version = serialized[0];
13
- const message = serialized.slice(1, serialized.length - this.SIGNATURE_LENGTH);
14
- const signature = serialized.slice(-1 * this.SIGNATURE_LENGTH);
15
- const senderKeyMessage = WAProto_1.proto.SenderKeyMessage.decode(message).toJSON();
16
- this.serialized = serialized;
17
- this.messageVersion = (version & 0xff) >> 4;
18
- this.keyId = senderKeyMessage.id;
19
- this.iteration = senderKeyMessage.iteration;
20
- this.ciphertext =
21
- typeof senderKeyMessage.ciphertext === 'string'
22
- ? Buffer.from(senderKeyMessage.ciphertext, 'base64')
23
- : senderKeyMessage.ciphertext;
24
- this.signature = signature;
25
- }
26
- else {
27
- const version = (((this.CURRENT_VERSION << 4) | this.CURRENT_VERSION) & 0xff) % 256;
28
- const ciphertextBuffer = Buffer.from(ciphertext);
29
- const message = WAProto_1.proto.SenderKeyMessage.encode(WAProto_1.proto.SenderKeyMessage.create({
30
- id: keyId,
31
- iteration: iteration,
32
- ciphertext: ciphertextBuffer
33
- })).finish();
34
- const signature = this.getSignature(signatureKey, Buffer.concat([Buffer.from([version]), message]));
35
- this.serialized = Buffer.concat([Buffer.from([version]), message, Buffer.from(signature)]);
36
- this.messageVersion = this.CURRENT_VERSION;
37
- this.keyId = keyId;
38
- this.iteration = iteration;
39
- this.ciphertext = ciphertextBuffer;
40
- this.signature = signature;
41
- }
1
+ //=======================================================//
2
+ import { calculateSignature, verifySignature } from "libsignal-xeuka/src/curve.js";
3
+ import { CiphertextMessage } from "./ciphertext-message.js";
4
+ import { proto } from "../../../WAProto/index.js";
5
+ //=======================================================//
6
+ export class SenderKeyMessage extends CiphertextMessage {
7
+ constructor(keyId, iteration, ciphertext, signatureKey, serialized) {
8
+ super();
9
+ this.SIGNATURE_LENGTH = 64;
10
+ if (serialized) {
11
+ const version = serialized[0];
12
+ const message = serialized.slice(1, serialized.length - this.SIGNATURE_LENGTH);
13
+ const signature = serialized.slice(-1 * this.SIGNATURE_LENGTH);
14
+ const senderKeyMessage = proto.SenderKeyMessage.decode(message).toJSON();
15
+ this.serialized = serialized;
16
+ this.messageVersion = (version & 0xff) >> 4;
17
+ this.keyId = senderKeyMessage.id;
18
+ this.iteration = senderKeyMessage.iteration;
19
+ this.ciphertext =
20
+ typeof senderKeyMessage.ciphertext === "string"
21
+ ? Buffer.from(senderKeyMessage.ciphertext, "base64")
22
+ : senderKeyMessage.ciphertext;
23
+ this.signature = signature;
42
24
  }
43
- getKeyId() {
44
- return this.keyId;
45
- }
46
- getIteration() {
47
- return this.iteration;
48
- }
49
- getCipherText() {
50
- return this.ciphertext;
51
- }
52
- verifySignature(signatureKey) {
53
- const part1 = this.serialized.slice(0, this.serialized.length - this.SIGNATURE_LENGTH);
54
- const part2 = this.serialized.slice(-1 * this.SIGNATURE_LENGTH);
55
- const res = (0, curve_1.verifySignature)(signatureKey, part1, part2);
56
- if (!res)
57
- throw new Error('Invalid signature!');
58
- }
59
- getSignature(signatureKey, serialized) {
60
- return Buffer.from((0, curve_1.calculateSignature)(signatureKey, serialized));
61
- }
62
- serialize() {
63
- return this.serialized;
64
- }
65
- getType() {
66
- return 4;
25
+ else {
26
+ const version = (((this.CURRENT_VERSION << 4) | this.CURRENT_VERSION) & 0xff) % 256;
27
+ const ciphertextBuffer = Buffer.from(ciphertext);
28
+ const message = proto.SenderKeyMessage.encode(proto.SenderKeyMessage.create({
29
+ id: keyId,
30
+ iteration: iteration,
31
+ ciphertext: ciphertextBuffer
32
+ })).finish();
33
+ const signature = this.getSignature(signatureKey, Buffer.concat([Buffer.from([version]), message]));
34
+ this.serialized = Buffer.concat([Buffer.from([version]), message, Buffer.from(signature)]);
35
+ this.messageVersion = this.CURRENT_VERSION;
36
+ this.keyId = keyId;
37
+ this.iteration = iteration;
38
+ this.ciphertext = ciphertextBuffer;
39
+ this.signature = signature;
67
40
  }
41
+ }
42
+ getKeyId() {
43
+ return this.keyId;
44
+ }
45
+ getIteration() {
46
+ return this.iteration;
47
+ }
48
+ getCipherText() {
49
+ return this.ciphertext;
50
+ }
51
+ verifySignature(signatureKey) {
52
+ const part1 = this.serialized.slice(0, this.serialized.length - this.SIGNATURE_LENGTH);
53
+ const part2 = this.serialized.slice(-1 * this.SIGNATURE_LENGTH);
54
+ const res = verifySignature(signatureKey, part1, part2);
55
+ if (!res)
56
+ throw new Error("Invalid signature!");
57
+ }
58
+ getSignature(signatureKey, serialized) {
59
+ return Buffer.from(calculateSignature(signatureKey, serialized));
60
+ }
61
+ serialize() {
62
+ return this.serialized;
63
+ }
64
+ getType() {
65
+ return 4;
66
+ }
68
67
  }
69
- exports.SenderKeyMessage = SenderKeyMessage;
68
+ //=======================================================//
@@ -1,51 +1,52 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SenderKeyName = void 0;
1
+ //=======================================================//
4
2
  function isNull(str) {
5
- return str === null || str === '';
3
+ return str === null || str === "";
6
4
  }
5
+ //=======================================================//
7
6
  function intValue(num) {
8
- const MAX_VALUE = 0x7fffffff;
9
- const MIN_VALUE = -0x80000000;
10
- if (num > MAX_VALUE || num < MIN_VALUE) {
11
- return num & 0xffffffff;
12
- }
13
- return num;
7
+ const MAX_VALUE = 0x7fffffff;
8
+ const MIN_VALUE = -0x80000000;
9
+ if (num > MAX_VALUE || num < MIN_VALUE) {
10
+ return num & 0xffffffff;
11
+ }
12
+ return num;
14
13
  }
14
+ //=======================================================//
15
15
  function hashCode(strKey) {
16
- let hash = 0;
17
- if (!isNull(strKey)) {
18
- for (let i = 0; i < strKey.length; i++) {
19
- hash = hash * 31 + strKey.charCodeAt(i);
20
- hash = intValue(hash);
21
- }
22
- }
23
- return hash;
16
+ let hash = 0;
17
+ if (!isNull(strKey)) {
18
+ for (let i = 0; i < strKey.length; i++) {
19
+ hash = hash * 31 + strKey.charCodeAt(i);
20
+ hash = intValue(hash);
21
+ }
22
+ }
23
+ return hash;
24
24
  }
25
- class SenderKeyName {
26
- constructor(groupId, sender) {
27
- this.groupId = groupId;
28
- this.sender = sender;
29
- }
30
- getGroupId() {
31
- return this.groupId;
32
- }
33
- getSender() {
34
- return this.sender;
35
- }
36
- serialize() {
37
- return `${this.groupId}::${this.sender.id}::${this.sender.deviceId}`;
38
- }
39
- toString() {
40
- return this.serialize();
41
- }
42
- equals(other) {
43
- if (other === null)
44
- return false;
45
- return this.groupId === other.groupId && this.sender.toString() === other.sender.toString();
46
- }
47
- hashCode() {
48
- return hashCode(this.groupId) ^ hashCode(this.sender.toString());
49
- }
25
+ //=======================================================//
26
+ export class SenderKeyName {
27
+ constructor(groupId, sender) {
28
+ this.groupId = groupId;
29
+ this.sender = sender;
30
+ }
31
+ getGroupId() {
32
+ return this.groupId;
33
+ }
34
+ getSender() {
35
+ return this.sender;
36
+ }
37
+ serialize() {
38
+ return `${this.groupId}::${this.sender.id}::${this.sender.deviceId}`;
39
+ }
40
+ toString() {
41
+ return this.serialize();
42
+ }
43
+ equals(other) {
44
+ if (other === null)
45
+ return false;
46
+ return this.groupId === other.groupId && this.sender.toString() === other.sender.toString();
47
+ }
48
+ hashCode() {
49
+ return hashCode(this.groupId) ^ hashCode(this.sender.toString());
50
+ }
50
51
  }
51
- exports.SenderKeyName = SenderKeyName;
52
+ //=======================================================//
@@ -1,53 +1,43 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SenderKeyRecord = void 0;
4
- const generics_1 = require("../../Utils/generics");
5
- const sender_key_state_1 = require("./sender-key-state");
6
- class SenderKeyRecord {
7
- constructor(serialized) {
8
- this.MAX_STATES = 5;
9
- this.senderKeyStates = [];
10
- if (serialized) {
11
- for (const structure of serialized) {
12
- this.senderKeyStates.push(new sender_key_state_1.SenderKeyState(null, null, null, null, null, null, structure));
13
- }
14
- }
1
+ //=======================================================//
2
+ import { SenderKeyState } from "./sender-key-state.js";
3
+ import { BufferJSON } from "../../Utils/generics.js";
4
+ //=======================================================//
5
+ export class SenderKeyRecord {
6
+ constructor(serialized) {
7
+ this.MAX_STATES = 5;
8
+ this.senderKeyStates = [];
9
+ if (serialized) {
10
+ for (const structure of serialized) {
11
+ this.senderKeyStates.push(new SenderKeyState(null, null, null, null, null, null, structure));
12
+ }
15
13
  }
16
- isEmpty() {
17
- return this.senderKeyStates.length === 0;
14
+ }
15
+ isEmpty() {
16
+ return this.senderKeyStates.length === 0;
17
+ }
18
+ getSenderKeyState(keyId) {
19
+ if (keyId === undefined && this.senderKeyStates.length) {
20
+ return this.senderKeyStates[this.senderKeyStates.length - 1];
18
21
  }
19
- getSenderKeyState(keyId) {
20
- if (keyId === undefined && this.senderKeyStates.length) {
21
- return this.senderKeyStates[this.senderKeyStates.length - 1];
22
- }
23
- return this.senderKeyStates.find(state => state.getKeyId() === keyId);
24
- }
25
- addSenderKeyState(id, iteration, chainKey, signatureKey) {
26
- this.senderKeyStates.push(new sender_key_state_1.SenderKeyState(id, iteration, chainKey, null, signatureKey));
27
- if (this.senderKeyStates.length > this.MAX_STATES) {
28
- this.senderKeyStates.shift();
29
- }
30
- }
31
- setSenderKeyState(id, iteration, chainKey, keyPair) {
32
- this.senderKeyStates.length = 0;
33
- this.senderKeyStates.push(new sender_key_state_1.SenderKeyState(id, iteration, chainKey, keyPair));
34
- }
35
- serialize() {
36
- return this.senderKeyStates.map(state => state.getStructure());
37
- }
38
- static deserialize(data) {
39
- let parsed;
40
- if (typeof data === 'string') {
41
- parsed = JSON.parse(data, generics_1.BufferJSON.reviver);
42
- }
43
- else if (data instanceof Uint8Array) {
44
- const str = Buffer.from(data).toString('utf-8');
45
- parsed = JSON.parse(str, generics_1.BufferJSON.reviver);
46
- }
47
- else {
48
- parsed = data;
49
- }
50
- return new SenderKeyRecord(parsed);
22
+ return this.senderKeyStates.find(state => state.getKeyId() === keyId);
23
+ }
24
+ addSenderKeyState(id, iteration, chainKey, signatureKey) {
25
+ this.senderKeyStates.push(new SenderKeyState(id, iteration, chainKey, null, signatureKey));
26
+ if (this.senderKeyStates.length > this.MAX_STATES) {
27
+ this.senderKeyStates.shift();
51
28
  }
29
+ }
30
+ setSenderKeyState(id, iteration, chainKey, keyPair) {
31
+ this.senderKeyStates.length = 0;
32
+ this.senderKeyStates.push(new SenderKeyState(id, iteration, chainKey, keyPair));
33
+ }
34
+ serialize() {
35
+ return this.senderKeyStates.map(state => state.getStructure());
36
+ }
37
+ static deserialize(data) {
38
+ const str = Buffer.from(data).toString("utf-8");
39
+ const parsed = JSON.parse(str, BufferJSON.reviver);
40
+ return new SenderKeyRecord(parsed);
41
+ }
52
42
  }
53
- exports.SenderKeyRecord = SenderKeyRecord;
43
+ //=======================================================//
@@ -1,99 +1,86 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SenderKeyState = void 0;
4
- const sender_chain_key_1 = require("./sender-chain-key");
5
- const sender_message_key_1 = require("./sender-message-key");
6
- class SenderKeyState {
7
- constructor(id, iteration, chainKey, signatureKeyPair, signatureKeyPublic, signatureKeyPrivate, senderKeyStateStructure) {
8
- this.MAX_MESSAGE_KEYS = 2000;
9
- if (senderKeyStateStructure) {
10
- this.senderKeyStateStructure = senderKeyStateStructure;
11
- }
12
- else {
13
- if (signatureKeyPair) {
14
- signatureKeyPublic = signatureKeyPair.public;
15
- signatureKeyPrivate = signatureKeyPair.private;
16
- }
17
- chainKey = typeof chainKey === 'string' ? Buffer.from(chainKey, 'base64') : chainKey;
18
- const senderChainKeyStructure = {
19
- iteration: iteration || 0,
20
- seed: chainKey || Buffer.alloc(0)
21
- };
22
- const signingKeyStructure = {
23
- public: typeof signatureKeyPublic === 'string'
24
- ? Buffer.from(signatureKeyPublic, 'base64')
25
- : signatureKeyPublic || Buffer.alloc(0)
26
- };
27
- if (signatureKeyPrivate) {
28
- signingKeyStructure.private =
29
- typeof signatureKeyPrivate === 'string' ? Buffer.from(signatureKeyPrivate, 'base64') : signatureKeyPrivate;
30
- }
31
- this.senderKeyStateStructure = {
32
- senderKeyId: id || 0,
33
- senderChainKey: senderChainKeyStructure,
34
- senderSigningKey: signingKeyStructure,
35
- senderMessageKeys: []
36
- };
37
- }
1
+ //=======================================================//
2
+ import { SenderMessageKey } from "./sender-message-key.js";
3
+ import { SenderChainKey } from "./sender-chain-key.js";
4
+ //=======================================================//
5
+ export class SenderKeyState {
6
+ constructor(id, iteration, chainKey, signatureKeyPair, signatureKeyPublic, signatureKeyPrivate, senderKeyStateStructure) {
7
+ this.MAX_MESSAGE_KEYS = 2000;
8
+ if (senderKeyStateStructure) {
9
+ this.senderKeyStateStructure = {
10
+ ...senderKeyStateStructure,
11
+ senderMessageKeys: Array.isArray(senderKeyStateStructure.senderMessageKeys)
12
+ ? senderKeyStateStructure.senderMessageKeys
13
+ : []
14
+ };
38
15
  }
39
- getKeyId() {
40
- return this.senderKeyStateStructure.senderKeyId;
16
+ else {
17
+ if (signatureKeyPair) {
18
+ signatureKeyPublic = signatureKeyPair.public;
19
+ signatureKeyPrivate = signatureKeyPair.private;
20
+ }
21
+ this.senderKeyStateStructure = {
22
+ senderKeyId: id || 0,
23
+ senderChainKey: {
24
+ iteration: iteration || 0,
25
+ seed: Buffer.from(chainKey || [])
26
+ },
27
+ senderSigningKey: {
28
+ public: Buffer.from(signatureKeyPublic || []),
29
+ private: Buffer.from(signatureKeyPrivate || [])
30
+ },
31
+ senderMessageKeys: []
32
+ };
41
33
  }
42
- getSenderChainKey() {
43
- return new sender_chain_key_1.SenderChainKey(this.senderKeyStateStructure.senderChainKey.iteration, this.senderKeyStateStructure.senderChainKey.seed);
34
+ }
35
+ getKeyId() {
36
+ return this.senderKeyStateStructure.senderKeyId;
37
+ }
38
+ getSenderChainKey() {
39
+ return new SenderChainKey(this.senderKeyStateStructure.senderChainKey.iteration, this.senderKeyStateStructure.senderChainKey.seed);
40
+ }
41
+ setSenderChainKey(chainKey) {
42
+ this.senderKeyStateStructure.senderChainKey = {
43
+ iteration: chainKey.getIteration(),
44
+ seed: chainKey.getSeed()
45
+ };
46
+ }
47
+ getSigningKeyPublic() {
48
+ const publicKey = Buffer.from(this.senderKeyStateStructure.senderSigningKey.public);
49
+ if (publicKey.length === 32) {
50
+ const fixed = Buffer.alloc(33);
51
+ fixed[0] = 0x05;
52
+ publicKey.copy(fixed, 1);
53
+ return fixed;
44
54
  }
45
- setSenderChainKey(chainKey) {
46
- this.senderKeyStateStructure.senderChainKey = {
47
- iteration: chainKey.getIteration(),
48
- seed: chainKey.getSeed()
49
- };
55
+ return publicKey;
56
+ }
57
+ getSigningKeyPrivate() {
58
+ const privateKey = this.senderKeyStateStructure.senderSigningKey.private;
59
+ return Buffer.from(privateKey || []);
60
+ }
61
+ hasSenderMessageKey(iteration) {
62
+ return this.senderKeyStateStructure.senderMessageKeys.some(key => key.iteration === iteration);
63
+ }
64
+ addSenderMessageKey(senderMessageKey) {
65
+ this.senderKeyStateStructure.senderMessageKeys.push({
66
+ iteration: senderMessageKey.getIteration(),
67
+ seed: senderMessageKey.getSeed()
68
+ });
69
+ if (this.senderKeyStateStructure.senderMessageKeys.length > this.MAX_MESSAGE_KEYS) {
70
+ this.senderKeyStateStructure.senderMessageKeys.shift();
50
71
  }
51
- getSigningKeyPublic() {
52
- const publicKey = this.senderKeyStateStructure.senderSigningKey.public;
53
- if (publicKey instanceof Buffer) {
54
- return publicKey;
55
- }
56
- else if (typeof publicKey === 'string') {
57
- return Buffer.from(publicKey, 'base64');
58
- }
59
- return Buffer.from(publicKey || []);
60
- }
61
- getSigningKeyPrivate() {
62
- const privateKey = this.senderKeyStateStructure.senderSigningKey.private;
63
- if (!privateKey) {
64
- return undefined;
65
- }
66
- if (privateKey instanceof Buffer) {
67
- return privateKey;
68
- }
69
- else if (typeof privateKey === 'string') {
70
- return Buffer.from(privateKey, 'base64');
71
- }
72
- return Buffer.from(privateKey || []);
73
- }
74
- hasSenderMessageKey(iteration) {
75
- return this.senderKeyStateStructure.senderMessageKeys.some(key => key.iteration === iteration);
76
- }
77
- addSenderMessageKey(senderMessageKey) {
78
- this.senderKeyStateStructure.senderMessageKeys.push({
79
- iteration: senderMessageKey.getIteration(),
80
- seed: senderMessageKey.getSeed()
81
- });
82
- if (this.senderKeyStateStructure.senderMessageKeys.length > this.MAX_MESSAGE_KEYS) {
83
- this.senderKeyStateStructure.senderMessageKeys.shift();
84
- }
85
- }
86
- removeSenderMessageKey(iteration) {
87
- const index = this.senderKeyStateStructure.senderMessageKeys.findIndex(key => key.iteration === iteration);
88
- if (index !== -1) {
89
- const messageKey = this.senderKeyStateStructure.senderMessageKeys[index];
90
- this.senderKeyStateStructure.senderMessageKeys.splice(index, 1);
91
- return new sender_message_key_1.SenderMessageKey(messageKey.iteration, messageKey.seed);
92
- }
93
- return null;
94
- }
95
- getStructure() {
96
- return this.senderKeyStateStructure;
72
+ }
73
+ removeSenderMessageKey(iteration) {
74
+ const index = this.senderKeyStateStructure.senderMessageKeys.findIndex(key => key.iteration === iteration);
75
+ if (index !== -1) {
76
+ const messageKey = this.senderKeyStateStructure.senderMessageKeys[index];
77
+ this.senderKeyStateStructure.senderMessageKeys.splice(index, 1);
78
+ return new SenderMessageKey(messageKey.iteration, messageKey.seed);
97
79
  }
80
+ return null;
81
+ }
82
+ getStructure() {
83
+ return this.senderKeyStateStructure;
84
+ }
98
85
  }
99
- exports.SenderKeyState = SenderKeyState;
86
+ //=======================================================//
@@ -1,29 +1,28 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SenderMessageKey = void 0;
4
- const crypto_1 = require("libsignal/src/crypto");
5
- class SenderMessageKey {
6
- constructor(iteration, seed) {
7
- const derivative = (0, crypto_1.deriveSecrets)(seed, Buffer.alloc(32), Buffer.from('WhisperGroup'));
8
- const keys = new Uint8Array(32);
9
- keys.set(new Uint8Array(derivative[0].slice(16)));
10
- keys.set(new Uint8Array(derivative[1].slice(0, 16)), 16);
11
- this.iv = Buffer.from(derivative[0].slice(0, 16));
12
- this.cipherKey = Buffer.from(keys.buffer);
13
- this.iteration = iteration;
14
- this.seed = seed;
15
- }
16
- getIteration() {
17
- return this.iteration;
18
- }
19
- getIv() {
20
- return this.iv;
21
- }
22
- getCipherKey() {
23
- return this.cipherKey;
24
- }
25
- getSeed() {
26
- return this.seed;
27
- }
1
+ //=======================================================//
2
+ import { deriveSecrets } from "libsignal-xeuka/src/crypto.js";
3
+ //=======================================================//
4
+ export class SenderMessageKey {
5
+ constructor(iteration, seed) {
6
+ const derivative = deriveSecrets(seed, Buffer.alloc(32), Buffer.from("WhisperGroup"));
7
+ const keys = new Uint8Array(32);
8
+ keys.set(new Uint8Array(derivative[0].slice(16)));
9
+ keys.set(new Uint8Array(derivative[1].slice(0, 16)), 16);
10
+ this.iv = Buffer.from(derivative[0].slice(0, 16));
11
+ this.cipherKey = Buffer.from(keys.buffer);
12
+ this.iteration = iteration;
13
+ this.seed = seed;
14
+ }
15
+ getIteration() {
16
+ return this.iteration;
17
+ }
18
+ getIv() {
19
+ return this.iv;
20
+ }
21
+ getCipherKey() {
22
+ return this.cipherKey;
23
+ }
24
+ getSeed() {
25
+ return this.seed;
26
+ }
28
27
  }
29
- exports.SenderMessageKey = SenderMessageKey;
28
+ //=======================================================//