socketon 1.31.2-rc → 1.51.17

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