socketon 1.31.2-rc → 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 (213) 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 +240 -324
  35. package/lib/Socket/socket.js +794 -651
  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 -392
  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 +354 -263
  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 -214
  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 -35
  107. package/package.json +85 -95
  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/generics.js.bak +0 -433
  178. package/lib/Utils/history.d.ts +0 -15
  179. package/lib/Utils/index.d.ts +0 -17
  180. package/lib/Utils/link-preview.d.ts +0 -21
  181. package/lib/Utils/logger.d.ts +0 -4
  182. package/lib/Utils/lt-hash.d.ts +0 -12
  183. package/lib/Utils/make-mutex.d.ts +0 -7
  184. package/lib/Utils/messages-media.d.ts +0 -116
  185. package/lib/Utils/messages.d.ts +0 -77
  186. package/lib/Utils/noise-handler.d.ts +0 -21
  187. package/lib/Utils/process-message.d.ts +0 -41
  188. package/lib/Utils/signal.d.ts +0 -32
  189. package/lib/Utils/use-multi-file-auth-state.d.ts +0 -13
  190. package/lib/Utils/validate-connection.d.ts +0 -11
  191. package/lib/Utils/validate-connection.js.bak +0 -237
  192. package/lib/WABinary/constants.d.ts +0 -30
  193. package/lib/WABinary/decode.d.ts +0 -7
  194. package/lib/WABinary/encode.d.ts +0 -3
  195. package/lib/WABinary/generic-utils.d.ts +0 -17
  196. package/lib/WABinary/index.d.ts +0 -5
  197. package/lib/WABinary/jid-utils.d.ts +0 -31
  198. package/lib/WABinary/types.d.ts +0 -18
  199. package/lib/WAM/BinaryInfo.d.ts +0 -17
  200. package/lib/WAM/constants.d.ts +0 -38
  201. package/lib/WAM/encode.d.ts +0 -3
  202. package/lib/WAM/index.d.ts +0 -3
  203. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +0 -9
  204. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +0 -22
  205. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +0 -12
  206. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +0 -12
  207. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +0 -25
  208. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +0 -8
  209. package/lib/WAUSync/Protocols/index.d.ts +0 -4
  210. package/lib/WAUSync/USyncQuery.d.ts +0 -28
  211. package/lib/WAUSync/USyncUser.d.ts +0 -12
  212. package/lib/WAUSync/index.d.ts +0 -3
  213. package/lib/index.d.ts +0 -12
@@ -1,96 +1,84 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.GroupCipher = void 0;
7
- const crypto_1 = require("libsignal/src/crypto");
8
- const queue_job_1 = __importDefault(require("./queue-job"));
9
- const sender_key_message_1 = require("./sender-key-message");
10
- class GroupCipher {
11
- constructor(senderKeyStore, senderKeyName) {
12
- this.senderKeyStore = senderKeyStore;
13
- this.senderKeyName = senderKeyName;
1
+ //=======================================================//
2
+ import { decrypt, encrypt } from "libsignal-xeuka/src/crypto.js";
3
+ import { SenderKeyMessage } from "./sender-key-message.js";
4
+ import { SenderKeyRecord } from "./sender-key-record.js";
5
+ import { SenderKeyState } from "./sender-key-state.js";
6
+ import { SenderKeyName } from "./sender-key-name.js";
7
+ //=======================================================//
8
+ export class GroupCipher {
9
+ constructor(senderKeyStore, senderKeyName) {
10
+ this.senderKeyStore = senderKeyStore;
11
+ this.senderKeyName = senderKeyName;
12
+ }
13
+ async encrypt(paddedPlaintext) {
14
+ const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
15
+ if (!record) {
16
+ throw new Error("No SenderKeyRecord found for encryption");
14
17
  }
15
- queueJob(awaitable) {
16
- return (0, queue_job_1.default)(this.senderKeyName.toString(), awaitable);
18
+ const senderKeyState = record.getSenderKeyState();
19
+ if (!senderKeyState) {
20
+ throw new Error("No session to encrypt message");
17
21
  }
18
- async encrypt(paddedPlaintext) {
19
- return await this.queueJob(async () => {
20
- const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
21
- if (!record) {
22
- throw new Error('No SenderKeyRecord found for encryption');
23
- }
24
- const senderKeyState = record.getSenderKeyState();
25
- if (!senderKeyState) {
26
- throw new Error('No session to encrypt message');
27
- }
28
- const iteration = senderKeyState.getSenderChainKey().getIteration();
29
- const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1);
30
- const ciphertext = await this.getCipherText(senderKey.getIv(), senderKey.getCipherKey(), paddedPlaintext);
31
- const senderKeyMessage = new sender_key_message_1.SenderKeyMessage(senderKeyState.getKeyId(), senderKey.getIteration(), ciphertext, senderKeyState.getSigningKeyPrivate());
32
- await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
33
- return senderKeyMessage.serialize();
34
- });
22
+ const iteration = senderKeyState.getSenderChainKey().getIteration();
23
+ const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1);
24
+ const ciphertext = await this.getCipherText(senderKey.getIv(), senderKey.getCipherKey(), paddedPlaintext);
25
+ const senderKeyMessage = new SenderKeyMessage(senderKeyState.getKeyId(), senderKey.getIteration(), ciphertext, senderKeyState.getSigningKeyPrivate());
26
+ await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
27
+ return senderKeyMessage.serialize();
28
+ }
29
+ async decrypt(senderKeyMessageBytes) {
30
+ const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
31
+ if (!record) {
32
+ throw new Error("No SenderKeyRecord found for decryption");
35
33
  }
36
- async decrypt(senderKeyMessageBytes) {
37
- return await this.queueJob(async () => {
38
- const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
39
- if (!record) {
40
- throw new Error('No SenderKeyRecord found for decryption');
41
- }
42
- const senderKeyMessage = new sender_key_message_1.SenderKeyMessage(null, null, null, null, senderKeyMessageBytes);
43
- const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId());
44
- if (!senderKeyState) {
45
- throw new Error('No session found to decrypt message');
46
- }
47
- senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic());
48
- const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration());
49
- const plaintext = await this.getPlainText(senderKey.getIv(), senderKey.getCipherKey(), senderKeyMessage.getCipherText());
50
- await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
51
- return plaintext;
52
- });
34
+ const senderKeyMessage = new SenderKeyMessage(null, null, null, null, senderKeyMessageBytes);
35
+ const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId());
36
+ if (!senderKeyState) {
37
+ throw new Error("No session found to decrypt message");
53
38
  }
54
- getSenderKey(senderKeyState, iteration) {
55
- let senderChainKey = senderKeyState.getSenderChainKey();
56
- if (senderChainKey.getIteration() > iteration) {
57
- if (senderKeyState.hasSenderMessageKey(iteration)) {
58
- const messageKey = senderKeyState.removeSenderMessageKey(iteration);
59
- if (!messageKey) {
60
- throw new Error('No sender message key found for iteration');
61
- }
62
- return messageKey;
63
- }
64
- throw new Error(`Received message with old counter: ${senderChainKey.getIteration()}, ${iteration}`);
39
+ senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic());
40
+ const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration());
41
+ const plaintext = await this.getPlainText(senderKey.getIv(), senderKey.getCipherKey(), senderKeyMessage.getCipherText());
42
+ await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
43
+ return plaintext;
44
+ }
45
+ getSenderKey(senderKeyState, iteration) {
46
+ let senderChainKey = senderKeyState.getSenderChainKey();
47
+ if (senderChainKey.getIteration() > iteration) {
48
+ if (senderKeyState.hasSenderMessageKey(iteration)) {
49
+ const messageKey = senderKeyState.removeSenderMessageKey(iteration);
50
+ if (!messageKey) {
51
+ throw new Error("No sender message key found for iteration");
65
52
  }
66
- if (iteration - senderChainKey.getIteration() > 2000) {
67
- throw new Error('Over 2000 messages into the future!');
68
- }
69
- while (senderChainKey.getIteration() < iteration) {
70
- senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey());
71
- senderChainKey = senderChainKey.getNext();
72
- }
73
- senderKeyState.setSenderChainKey(senderChainKey.getNext());
74
- return senderChainKey.getSenderMessageKey();
53
+ return messageKey;
54
+ }
55
+ throw new Error(`Received message with old counter: ${senderChainKey.getIteration()}, ${iteration}`);
75
56
  }
76
- async getPlainText(iv, key, ciphertext) {
77
- try {
78
- return (0, crypto_1.decrypt)(key, ciphertext, iv);
79
- }
80
- catch (e) {
81
- throw new Error('InvalidMessageException');
82
- }
57
+ if (iteration - senderChainKey.getIteration() > 2000) {
58
+ throw new Error("Over 2000 messages into the future!");
83
59
  }
84
- async getCipherText(iv, key, plaintext) {
85
- try {
86
- const ivBuffer = typeof iv === 'string' ? Buffer.from(iv, 'base64') : iv;
87
- const keyBuffer = typeof key === 'string' ? Buffer.from(key, 'base64') : key;
88
- const plaintextBuffer = typeof plaintext === 'string' ? Buffer.from(plaintext) : plaintext;
89
- return (0, crypto_1.encrypt)(keyBuffer, plaintextBuffer, ivBuffer);
90
- }
91
- catch (e) {
92
- throw new Error('InvalidMessageException');
93
- }
60
+ while (senderChainKey.getIteration() < iteration) {
61
+ senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey());
62
+ senderChainKey = senderChainKey.getNext();
63
+ }
64
+ senderKeyState.setSenderChainKey(senderChainKey.getNext());
65
+ return senderChainKey.getSenderMessageKey();
66
+ }
67
+ async getPlainText(iv, key, ciphertext) {
68
+ try {
69
+ return decrypt(key, ciphertext, iv);
70
+ }
71
+ catch (e) {
72
+ throw new Error("InvalidMessageException");
73
+ }
74
+ }
75
+ async getCipherText(iv, key, plaintext) {
76
+ try {
77
+ return encrypt(key, plaintext, iv);
78
+ }
79
+ catch (e) {
80
+ throw new Error("InvalidMessageException");
94
81
  }
82
+ }
95
83
  }
96
- exports.GroupCipher = GroupCipher;
84
+ //=======================================================//
@@ -1,57 +1,13 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.keyhelper = exports.CiphertextMessage = exports.SenderChainKey = exports.SenderMessageKey = exports.SenderKeyMessage = exports.SenderKeyState = exports.GroupCipher = exports.SenderKeyName = exports.SenderKeyRecord = exports.SenderKeyDistributionMessage = exports.GroupSessionBuilder = void 0;
37
- var group_session_builder_1 = require("./group-session-builder");
38
- Object.defineProperty(exports, "GroupSessionBuilder", { enumerable: true, get: function () { return group_session_builder_1.GroupSessionBuilder; } });
39
- var sender_key_distribution_message_1 = require("./sender-key-distribution-message");
40
- Object.defineProperty(exports, "SenderKeyDistributionMessage", { enumerable: true, get: function () { return sender_key_distribution_message_1.SenderKeyDistributionMessage; } });
41
- var sender_key_record_1 = require("./sender-key-record");
42
- Object.defineProperty(exports, "SenderKeyRecord", { enumerable: true, get: function () { return sender_key_record_1.SenderKeyRecord; } });
43
- var sender_key_name_1 = require("./sender-key-name");
44
- Object.defineProperty(exports, "SenderKeyName", { enumerable: true, get: function () { return sender_key_name_1.SenderKeyName; } });
45
- var group_cipher_1 = require("./group_cipher");
46
- Object.defineProperty(exports, "GroupCipher", { enumerable: true, get: function () { return group_cipher_1.GroupCipher; } });
47
- var sender_key_state_1 = require("./sender-key-state");
48
- Object.defineProperty(exports, "SenderKeyState", { enumerable: true, get: function () { return sender_key_state_1.SenderKeyState; } });
49
- var sender_key_message_1 = require("./sender-key-message");
50
- Object.defineProperty(exports, "SenderKeyMessage", { enumerable: true, get: function () { return sender_key_message_1.SenderKeyMessage; } });
51
- var sender_message_key_1 = require("./sender-message-key");
52
- Object.defineProperty(exports, "SenderMessageKey", { enumerable: true, get: function () { return sender_message_key_1.SenderMessageKey; } });
53
- var sender_chain_key_1 = require("./sender-chain-key");
54
- Object.defineProperty(exports, "SenderChainKey", { enumerable: true, get: function () { return sender_chain_key_1.SenderChainKey; } });
55
- var ciphertext_message_1 = require("./ciphertext-message");
56
- Object.defineProperty(exports, "CiphertextMessage", { enumerable: true, get: function () { return ciphertext_message_1.CiphertextMessage; } });
57
- exports.keyhelper = __importStar(require("./keyhelper"));
1
+ //=======================================================//
2
+ export { SenderKeyDistributionMessage } from "./sender-key-distribution-message.js";
3
+ export { GroupSessionBuilder } from "./group-session-builder.js";
4
+ export { CiphertextMessage } from "./ciphertext-message.js";
5
+ export { SenderKeyMessage } from "./sender-key-message.js";
6
+ export { SenderMessageKey } from "./sender-message-key.js";
7
+ export { SenderKeyRecord } from "./sender-key-record.js";
8
+ export { SenderKeyState } from "./sender-key-state.js";
9
+ export { SenderChainKey } from "./sender-chain-key.js";
10
+ export { SenderKeyName } from "./sender-key-name.js";
11
+ export { GroupCipher } from "./group_cipher.js";
12
+ export * as keyhelper from "./keyhelper.js";
13
+ //=======================================================//
@@ -1,55 +1,20 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.generateSenderKey = generateSenderKey;
37
- exports.generateSenderKeyId = generateSenderKeyId;
38
- exports.generateSenderSigningKey = generateSenderSigningKey;
39
- const nodeCrypto = __importStar(require("crypto"));
40
- const curve_1 = require("libsignal/src/curve");
41
- function generateSenderKey() {
42
- return nodeCrypto.randomBytes(32);
1
+ //=======================================================//
2
+ import { generateKeyPair } from "libsignal-xeuka/src/curve.js";
3
+ import * as nodeCrypto from "crypto";
4
+ //=======================================================//
5
+ export function generateSenderKey() {
6
+ return nodeCrypto.randomBytes(32);
43
7
  }
44
- function generateSenderKeyId() {
45
- return nodeCrypto.randomInt(2147483647);
8
+ export function generateSenderKeyId() {
9
+ return nodeCrypto.randomInt(2147483647);
46
10
  }
47
- function generateSenderSigningKey(key) {
48
- if (!key) {
49
- key = (0, curve_1.generateKeyPair)();
50
- }
51
- return {
52
- public: Buffer.from(key.pubKey),
53
- private: Buffer.from(key.privKey)
54
- };
11
+ export function generateSenderSigningKey(key) {
12
+ if (!key) {
13
+ key = generateKeyPair();
14
+ }
15
+ return {
16
+ public: Buffer.from(key.pubKey),
17
+ private: Buffer.from(key.privKey)
18
+ };
55
19
  }
20
+ //=======================================================//
@@ -1,34 +1,28 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SenderChainKey = void 0;
4
- const crypto_1 = require("libsignal/src/crypto");
5
- const sender_message_key_1 = require("./sender-message-key");
6
- class SenderChainKey {
7
- constructor(iteration, chainKey) {
8
- this.MESSAGE_KEY_SEED = Buffer.from([0x01]);
9
- this.CHAIN_KEY_SEED = Buffer.from([0x02]);
10
- this.iteration = iteration;
11
- if (chainKey instanceof Buffer) {
12
- this.chainKey = chainKey;
13
- }
14
- else {
15
- this.chainKey = Buffer.from(chainKey || []);
16
- }
17
- }
18
- getIteration() {
19
- return this.iteration;
20
- }
21
- getSenderMessageKey() {
22
- return new sender_message_key_1.SenderMessageKey(this.iteration, this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey));
23
- }
24
- getNext() {
25
- return new SenderChainKey(this.iteration + 1, this.getDerivative(this.CHAIN_KEY_SEED, this.chainKey));
26
- }
27
- getSeed() {
28
- return this.chainKey;
29
- }
30
- getDerivative(seed, key) {
31
- return (0, crypto_1.calculateMAC)(key, seed);
32
- }
1
+ //=======================================================//
2
+ import { calculateMAC } from "libsignal-xeuka/src/crypto.js";
3
+ import { SenderMessageKey } from "./sender-message-key.js";
4
+ //=======================================================//
5
+ export class SenderChainKey {
6
+ constructor(iteration, chainKey) {
7
+ this.MESSAGE_KEY_SEED = Buffer.from([0x01]);
8
+ this.CHAIN_KEY_SEED = Buffer.from([0x02]);
9
+ this.iteration = iteration;
10
+ this.chainKey = Buffer.from(chainKey);
11
+ }
12
+ getIteration() {
13
+ return this.iteration;
14
+ }
15
+ getSenderMessageKey() {
16
+ return new SenderMessageKey(this.iteration, this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey));
17
+ }
18
+ getNext() {
19
+ return new SenderChainKey(this.iteration + 1, this.getDerivative(this.CHAIN_KEY_SEED, this.chainKey));
20
+ }
21
+ getSeed() {
22
+ return this.chainKey;
23
+ }
24
+ getDerivative(seed, key) {
25
+ return calculateMAC(key, seed);
26
+ }
33
27
  }
34
- exports.SenderChainKey = SenderChainKey;
28
+ //=======================================================//
@@ -1,66 +1,65 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SenderKeyDistributionMessage = void 0;
4
- const WAProto_1 = require("../../../WAProto");
5
- const ciphertext_message_1 = require("./ciphertext-message");
6
- class SenderKeyDistributionMessage extends ciphertext_message_1.CiphertextMessage {
7
- constructor(id, iteration, chainKey, signatureKey, serialized) {
8
- super();
9
- if (serialized) {
10
- try {
11
- const message = serialized.slice(1);
12
- const distributionMessage = WAProto_1.proto.SenderKeyDistributionMessage.decode(message).toJSON();
13
- this.serialized = serialized;
14
- this.id = distributionMessage.id;
15
- this.iteration = distributionMessage.iteration;
16
- this.chainKey =
17
- typeof distributionMessage.chainKey === 'string'
18
- ? Buffer.from(distributionMessage.chainKey, 'base64')
19
- : distributionMessage.chainKey;
20
- this.signatureKey =
21
- typeof distributionMessage.signingKey === 'string'
22
- ? Buffer.from(distributionMessage.signingKey, 'base64')
23
- : distributionMessage.signingKey;
24
- }
25
- catch (e) {
26
- throw new Error(String(e));
27
- }
28
- }
29
- else {
30
- const version = this.intsToByteHighAndLow(this.CURRENT_VERSION, this.CURRENT_VERSION);
31
- this.id = id;
32
- this.iteration = iteration;
33
- this.chainKey = chainKey;
34
- this.signatureKey = signatureKey;
35
- const message = WAProto_1.proto.SenderKeyDistributionMessage.encode(WAProto_1.proto.SenderKeyDistributionMessage.create({
36
- id,
37
- iteration,
38
- chainKey,
39
- signingKey: this.signatureKey
40
- })).finish();
41
- this.serialized = Buffer.concat([Buffer.from([version]), message]);
42
- }
1
+ //=======================================================//
2
+ import { CiphertextMessage } from "./ciphertext-message.js";
3
+ import { proto } from "../../../WAProto/index.js";
4
+ //=======================================================//
5
+ export class SenderKeyDistributionMessage extends CiphertextMessage {
6
+ constructor(id, iteration, chainKey, signatureKey, serialized) {
7
+ super();
8
+ if (serialized) {
9
+ try {
10
+ const message = serialized.slice(1);
11
+ const distributionMessage = proto.SenderKeyDistributionMessage.decode(message).toJSON();
12
+ this.serialized = serialized;
13
+ this.id = distributionMessage.id;
14
+ this.iteration = distributionMessage.iteration;
15
+ this.chainKey =
16
+ typeof distributionMessage.chainKey === "string"
17
+ ? Buffer.from(distributionMessage.chainKey, "base64")
18
+ : distributionMessage.chainKey;
19
+ this.signatureKey =
20
+ typeof distributionMessage.signingKey === "string"
21
+ ? Buffer.from(distributionMessage.signingKey, "base64")
22
+ : distributionMessage.signingKey;
23
+ }
24
+ catch (e) {
25
+ throw new Error(String(e));
26
+ }
43
27
  }
44
- intsToByteHighAndLow(highValue, lowValue) {
45
- return (((highValue << 4) | lowValue) & 0xff) % 256;
46
- }
47
- serialize() {
48
- return this.serialized;
49
- }
50
- getType() {
51
- return this.SENDERKEY_DISTRIBUTION_TYPE;
52
- }
53
- getIteration() {
54
- return this.iteration;
55
- }
56
- getChainKey() {
57
- return typeof this.chainKey === 'string' ? Buffer.from(this.chainKey, 'base64') : this.chainKey;
58
- }
59
- getSignatureKey() {
60
- return typeof this.signatureKey === 'string' ? Buffer.from(this.signatureKey, 'base64') : this.signatureKey;
61
- }
62
- getId() {
63
- return this.id;
28
+ else {
29
+ const version = this.intsToByteHighAndLow(this.CURRENT_VERSION, this.CURRENT_VERSION);
30
+ this.id = id;
31
+ this.iteration = iteration;
32
+ this.chainKey = chainKey;
33
+ this.signatureKey = signatureKey;
34
+ const message = proto.SenderKeyDistributionMessage.encode(proto.SenderKeyDistributionMessage.create({
35
+ id,
36
+ iteration,
37
+ chainKey,
38
+ signingKey: this.signatureKey
39
+ })).finish();
40
+ this.serialized = Buffer.concat([Buffer.from([version]), message]);
64
41
  }
42
+ }
43
+ intsToByteHighAndLow(highValue, lowValue) {
44
+ return (((highValue << 4) | lowValue) & 0xff) % 256;
45
+ }
46
+ serialize() {
47
+ return this.serialized;
48
+ }
49
+ getType() {
50
+ return this.SENDERKEY_DISTRIBUTION_TYPE;
51
+ }
52
+ getIteration() {
53
+ return this.iteration;
54
+ }
55
+ getChainKey() {
56
+ return this.chainKey;
57
+ }
58
+ getSignatureKey() {
59
+ return this.signatureKey;
60
+ }
61
+ getId() {
62
+ return this.id;
63
+ }
65
64
  }
66
- exports.SenderKeyDistributionMessage = SenderKeyDistributionMessage;
65
+ //=======================================================//