socketon 0.31.0 → 1.51.16

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 (211) hide show
  1. package/README.md +313 -159
  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 +270 -282
  35. package/lib/Socket/socket.js +798 -635
  36. package/lib/Socket/socketon.js +402 -0
  37. package/lib/Store/index.js +6 -10
  38. package/lib/Store/make-cache-manager-store.js +73 -81
  39. package/lib/Store/make-in-memory-store.js +286 -423
  40. package/lib/Store/make-ordered-dictionary.js +77 -79
  41. package/lib/Store/object-repository.js +24 -26
  42. package/lib/Types/Auth.js +3 -2
  43. package/lib/Types/Bussines.js +3 -0
  44. package/lib/Types/Call.js +3 -2
  45. package/lib/Types/Chat.js +9 -4
  46. package/lib/Types/Contact.js +3 -2
  47. package/lib/Types/Events.js +3 -2
  48. package/lib/Types/GroupMetadata.js +3 -2
  49. package/lib/Types/Label.js +24 -26
  50. package/lib/Types/LabelAssociation.js +6 -8
  51. package/lib/Types/Message.js +12 -9
  52. package/lib/Types/Newsletter.js +33 -38
  53. package/lib/Types/Newsletter.js.bak +33 -0
  54. package/lib/Types/Product.js +3 -2
  55. package/lib/Types/Signal.js +3 -2
  56. package/lib/Types/Socket.js +4 -2
  57. package/lib/Types/State.js +11 -2
  58. package/lib/Types/USync.js +3 -2
  59. package/lib/Types/index.js +27 -41
  60. package/lib/Utils/auth-utils.js +211 -198
  61. package/lib/Utils/baileys-event-stream.js +42 -61
  62. package/lib/Utils/browser-utils.js +25 -0
  63. package/lib/Utils/business.js +213 -214
  64. package/lib/Utils/chat-utils.js +710 -687
  65. package/lib/Utils/crypto.js +112 -133
  66. package/lib/Utils/decode-wa-message.js +252 -183
  67. package/lib/Utils/decode-wa-message.js.bak +267 -0
  68. package/lib/Utils/event-buffer.js +510 -496
  69. package/lib/Utils/generics.js +319 -464
  70. package/lib/Utils/history.js +83 -92
  71. package/lib/Utils/index.js +21 -33
  72. package/lib/Utils/link-preview.js +71 -83
  73. package/lib/Utils/logger.js +5 -7
  74. package/lib/Utils/lt-hash.js +40 -46
  75. package/lib/Utils/make-mutex.js +34 -41
  76. package/lib/Utils/message-retry-manager.js +113 -0
  77. package/lib/Utils/messages-media.js +550 -768
  78. package/lib/Utils/messages.js +385 -261
  79. package/lib/Utils/noise-handler.js +138 -149
  80. package/lib/Utils/pre-key-manager.js +85 -0
  81. package/lib/Utils/process-message.js +323 -303
  82. package/lib/Utils/signal.js +149 -141
  83. package/lib/Utils/use-multi-file-auth-state.js +95 -103
  84. package/lib/Utils/validate-connection.js +183 -212
  85. package/lib/WABinary/constants.js +1298 -35
  86. package/lib/WABinary/decode.js +237 -249
  87. package/lib/WABinary/encode.js +213 -260
  88. package/lib/WABinary/generic-utils.js +56 -65
  89. package/lib/WABinary/index.js +7 -21
  90. package/lib/WABinary/jid-utils.js +89 -58
  91. package/lib/WABinary/types.js +3 -2
  92. package/lib/WAM/BinaryInfo.js +10 -12
  93. package/lib/WAM/constants.js +22851 -15348
  94. package/lib/WAM/encode.js +135 -136
  95. package/lib/WAM/index.js +5 -19
  96. package/lib/WAUSync/Protocols/USyncContactProtocol.js +28 -30
  97. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +49 -53
  98. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +27 -28
  99. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +36 -39
  100. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +50 -50
  101. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +26 -20
  102. package/lib/WAUSync/Protocols/index.js +6 -20
  103. package/lib/WAUSync/USyncQuery.js +86 -85
  104. package/lib/WAUSync/USyncUser.js +23 -25
  105. package/lib/WAUSync/index.js +5 -19
  106. package/lib/index.js +27 -36
  107. package/package.json +61 -85
  108. package/engine-requirements.js +0 -10
  109. package/lib/Defaults/baileys-version.json +0 -3
  110. package/lib/Defaults/index.d.ts +0 -53
  111. package/lib/Defaults/phonenumber-mcc.json +0 -223
  112. package/lib/Signal/Group/ciphertext-message.d.ts +0 -9
  113. package/lib/Signal/Group/group-session-builder.d.ts +0 -14
  114. package/lib/Signal/Group/group_cipher.d.ts +0 -17
  115. package/lib/Signal/Group/index.d.ts +0 -11
  116. package/lib/Signal/Group/keyhelper.d.ts +0 -10
  117. package/lib/Signal/Group/queue-job.d.ts +0 -1
  118. package/lib/Signal/Group/queue-job.js +0 -57
  119. package/lib/Signal/Group/sender-chain-key.d.ts +0 -13
  120. package/lib/Signal/Group/sender-key-distribution-message.d.ts +0 -16
  121. package/lib/Signal/Group/sender-key-message.d.ts +0 -18
  122. package/lib/Signal/Group/sender-key-name.d.ts +0 -17
  123. package/lib/Signal/Group/sender-key-record.d.ts +0 -30
  124. package/lib/Signal/Group/sender-key-state.d.ts +0 -38
  125. package/lib/Signal/Group/sender-message-key.d.ts +0 -11
  126. package/lib/Signal/libsignal.d.ts +0 -3
  127. package/lib/Socket/Client/abstract-socket-client.d.ts +0 -17
  128. package/lib/Socket/Client/abstract-socket-client.js +0 -13
  129. package/lib/Socket/Client/index.d.ts +0 -3
  130. package/lib/Socket/Client/mobile-socket-client.d.ts +0 -13
  131. package/lib/Socket/Client/mobile-socket-client.js +0 -65
  132. package/lib/Socket/Client/web-socket-client.d.ts +0 -12
  133. package/lib/Socket/Client/web-socket-client.js +0 -62
  134. package/lib/Socket/business.d.ts +0 -171
  135. package/lib/Socket/chats.d.ts +0 -267
  136. package/lib/Socket/dugong.d.ts +0 -254
  137. package/lib/Socket/dugong.js +0 -484
  138. package/lib/Socket/groups.d.ts +0 -115
  139. package/lib/Socket/index.d.ts +0 -173
  140. package/lib/Socket/messages-recv.d.ts +0 -161
  141. package/lib/Socket/messages-send.d.ts +0 -149
  142. package/lib/Socket/newsletter.d.ts +0 -134
  143. package/lib/Socket/registration.d.ts +0 -267
  144. package/lib/Socket/registration.js +0 -166
  145. package/lib/Socket/socket.d.ts +0 -43
  146. package/lib/Socket/usync.d.ts +0 -36
  147. package/lib/Socket/usync.js +0 -70
  148. package/lib/Store/index.d.ts +0 -3
  149. package/lib/Store/make-cache-manager-store.d.ts +0 -13
  150. package/lib/Store/make-in-memory-store.d.ts +0 -118
  151. package/lib/Store/make-ordered-dictionary.d.ts +0 -13
  152. package/lib/Store/object-repository.d.ts +0 -10
  153. package/lib/Types/Auth.d.ts +0 -110
  154. package/lib/Types/Call.d.ts +0 -13
  155. package/lib/Types/Chat.d.ts +0 -102
  156. package/lib/Types/Contact.d.ts +0 -19
  157. package/lib/Types/Events.d.ts +0 -157
  158. package/lib/Types/GroupMetadata.d.ts +0 -55
  159. package/lib/Types/Label.d.ts +0 -35
  160. package/lib/Types/LabelAssociation.d.ts +0 -29
  161. package/lib/Types/Message.d.ts +0 -273
  162. package/lib/Types/Newsletter.d.ts +0 -103
  163. package/lib/Types/Product.d.ts +0 -78
  164. package/lib/Types/Signal.d.ts +0 -57
  165. package/lib/Types/Socket.d.ts +0 -111
  166. package/lib/Types/State.d.ts +0 -27
  167. package/lib/Types/USync.d.ts +0 -25
  168. package/lib/Types/index.d.ts +0 -57
  169. package/lib/Utils/auth-utils.d.ts +0 -18
  170. package/lib/Utils/baileys-event-stream.d.ts +0 -16
  171. package/lib/Utils/business.d.ts +0 -22
  172. package/lib/Utils/chat-utils.d.ts +0 -71
  173. package/lib/Utils/crypto.d.ts +0 -41
  174. package/lib/Utils/decode-wa-message.d.ts +0 -19
  175. package/lib/Utils/event-buffer.d.ts +0 -35
  176. package/lib/Utils/generics.d.ts +0 -92
  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/WABinary/constants.d.ts +0 -30
  191. package/lib/WABinary/decode.d.ts +0 -7
  192. package/lib/WABinary/encode.d.ts +0 -3
  193. package/lib/WABinary/generic-utils.d.ts +0 -17
  194. package/lib/WABinary/index.d.ts +0 -5
  195. package/lib/WABinary/jid-utils.d.ts +0 -31
  196. package/lib/WABinary/types.d.ts +0 -18
  197. package/lib/WAM/BinaryInfo.d.ts +0 -17
  198. package/lib/WAM/constants.d.ts +0 -38
  199. package/lib/WAM/encode.d.ts +0 -3
  200. package/lib/WAM/index.d.ts +0 -3
  201. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +0 -9
  202. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +0 -22
  203. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +0 -12
  204. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +0 -12
  205. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +0 -25
  206. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +0 -8
  207. package/lib/WAUSync/Protocols/index.d.ts +0 -4
  208. package/lib/WAUSync/USyncQuery.d.ts +0 -28
  209. package/lib/WAUSync/USyncUser.d.ts +0 -12
  210. package/lib/WAUSync/index.d.ts +0 -3
  211. 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
+ //=======================================================//