@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,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
+ //=======================================================//