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,151 +1,130 @@
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]; } };
1
+ //=======================================================//
2
+ import { createCipheriv, createDecipheriv, createHash, createHmac, randomBytes } from "crypto";
3
+ import { KEY_BUNDLE_TYPE } from "../Defaults/index.js";
4
+ import * as curve from "libsignal-xeuka/src/curve.js";
5
+ //=======================================================//
6
+ const { subtle } = globalThis.crypto;
7
+ export const generateSignalPubKey = (pubKey) => pubKey.length === 33 ? pubKey : Buffer.concat([KEY_BUNDLE_TYPE, pubKey]);
8
+ export const Curve = {
9
+ generateKeyPair: () => {
10
+ const { pubKey, privKey } = curve.generateKeyPair();
11
+ return {
12
+ private: Buffer.from(privKey),
13
+ public: Buffer.from(pubKey.slice(1))
14
+ };
15
+ },
16
+ sharedKey: (privateKey, publicKey) => {
17
+ const shared = curve.calculateAgreement(generateSignalPubKey(publicKey), privateKey);
18
+ return Buffer.from(shared);
19
+ },
20
+ sign: (privateKey, buf) => curve.calculateSignature(privateKey, buf),
21
+ verify: (pubKey, message, signature) => {
22
+ try {
23
+ curve.verifySignature(generateSignalPubKey(pubKey), message, signature);
24
+ return true;
7
25
  }
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 (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- var __importDefault = (this && this.__importDefault) || function (mod) {
26
- return (mod && mod.__esModule) ? mod : { "default": mod };
27
- };
28
- Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.derivePairingCodeKey = exports.hkdf = exports.md5 = exports.sha256 = exports.hmacSign = exports.aesEncrypWithIV = exports.aesEncrypt = exports.aesDecryptWithIV = exports.aesDecrypt = exports.aesDecryptCTR = exports.aesEncryptCTR = exports.aesDecryptGCM = exports.aesEncryptGCM = exports.signedKeyPair = exports.Curve = exports.generateSignalPubKey = void 0;
30
- const crypto_1 = require("crypto");
31
- const futoin_hkdf_1 = __importDefault(require("futoin-hkdf"));
32
- const libsignal = __importStar(require("libsignal"));
33
- const Defaults_1 = require("../Defaults");
34
- /** prefix version byte to the pub keys, required for some curve crypto functions */
35
- const generateSignalPubKey = (pubKey) => (pubKey.length === 33
36
- ? pubKey
37
- : Buffer.concat([Defaults_1.KEY_BUNDLE_TYPE, pubKey]));
38
- exports.generateSignalPubKey = generateSignalPubKey;
39
- exports.Curve = {
40
- generateKeyPair: () => {
41
- const { pubKey, privKey } = libsignal.curve.generateKeyPair();
42
- return {
43
- private: Buffer.from(privKey),
44
- // remove version byte
45
- public: Buffer.from(pubKey.slice(1))
46
- };
47
- },
48
- sharedKey: (privateKey, publicKey) => {
49
- const shared = libsignal.curve.calculateAgreement((0, exports.generateSignalPubKey)(publicKey), privateKey);
50
- return Buffer.from(shared);
51
- },
52
- sign: (privateKey, buf) => (libsignal.curve.calculateSignature(privateKey, buf)),
53
- verify: (pubKey, message, signature) => {
54
- try {
55
- libsignal.curve.verifySignature((0, exports.generateSignalPubKey)(pubKey), message, signature);
56
- return true;
57
- }
58
- catch (error) {
59
- return false;
60
- }
26
+ catch (error) {
27
+ return false;
61
28
  }
29
+ }
62
30
  };
63
- const signedKeyPair = (identityKeyPair, keyId) => {
64
- const preKey = exports.Curve.generateKeyPair();
65
- const pubKey = (0, exports.generateSignalPubKey)(preKey.public);
66
- const signature = exports.Curve.sign(identityKeyPair.private, pubKey);
67
- return { keyPair: preKey, signature, keyId };
31
+ //=======================================================//
32
+ export const signedKeyPair = (identityKeyPair, keyId) => {
33
+ const preKey = Curve.generateKeyPair();
34
+ const pubKey = generateSignalPubKey(preKey.public);
35
+ const signature = Curve.sign(identityKeyPair.private, pubKey);
36
+ return { keyPair: preKey, signature, keyId };
68
37
  };
69
- exports.signedKeyPair = signedKeyPair;
38
+ //=======================================================//
70
39
  const GCM_TAG_LENGTH = 128 >> 3;
71
- /**
72
- * encrypt AES 256 GCM;
73
- * where the tag tag is suffixed to the ciphertext
74
- * */
75
- function aesEncryptGCM(plaintext, key, iv, additionalData) {
76
- const cipher = (0, crypto_1.createCipheriv)('aes-256-gcm', key, iv);
77
- cipher.setAAD(additionalData);
78
- return Buffer.concat([cipher.update(plaintext), cipher.final(), cipher.getAuthTag()]);
40
+ export function aesEncryptGCM(plaintext, key, iv, additionalData) {
41
+ const cipher = createCipheriv("aes-256-gcm", key, iv);
42
+ cipher.setAAD(additionalData);
43
+ return Buffer.concat([cipher.update(plaintext), cipher.final(), cipher.getAuthTag()]);
79
44
  }
80
- exports.aesEncryptGCM = aesEncryptGCM;
81
- /**
82
- * decrypt AES 256 GCM;
83
- * where the auth tag is suffixed to the ciphertext
84
- * */
85
- function aesDecryptGCM(ciphertext, key, iv, additionalData) {
86
- const decipher = (0, crypto_1.createDecipheriv)('aes-256-gcm', key, iv);
87
- // decrypt additional adata
88
- const enc = ciphertext.slice(0, ciphertext.length - GCM_TAG_LENGTH);
89
- const tag = ciphertext.slice(ciphertext.length - GCM_TAG_LENGTH);
90
- // set additional data
91
- decipher.setAAD(additionalData);
92
- decipher.setAuthTag(tag);
93
- return Buffer.concat([decipher.update(enc), decipher.final()]);
45
+ //=======================================================//
46
+ export function aesDecryptGCM(ciphertext, key, iv, additionalData) {
47
+ const decipher = createDecipheriv("aes-256-gcm", key, iv);
48
+ const enc = ciphertext.slice(0, ciphertext.length - GCM_TAG_LENGTH);
49
+ const tag = ciphertext.slice(ciphertext.length - GCM_TAG_LENGTH);
50
+ decipher.setAAD(additionalData);
51
+ decipher.setAuthTag(tag);
52
+ return Buffer.concat([decipher.update(enc), decipher.final()]);
94
53
  }
95
- exports.aesDecryptGCM = aesDecryptGCM;
96
- function aesEncryptCTR(plaintext, key, iv) {
97
- const cipher = (0, crypto_1.createCipheriv)('aes-256-ctr', key, iv);
98
- return Buffer.concat([cipher.update(plaintext), cipher.final()]);
54
+ //=======================================================//
55
+ export function aesEncryptCTR(plaintext, key, iv) {
56
+ const cipher = createCipheriv("aes-256-ctr", key, iv);
57
+ return Buffer.concat([cipher.update(plaintext), cipher.final()]);
99
58
  }
100
- exports.aesEncryptCTR = aesEncryptCTR;
101
- function aesDecryptCTR(ciphertext, key, iv) {
102
- const decipher = (0, crypto_1.createDecipheriv)('aes-256-ctr', key, iv);
103
- return Buffer.concat([decipher.update(ciphertext), decipher.final()]);
59
+ //=======================================================//
60
+ export function aesDecryptCTR(ciphertext, key, iv) {
61
+ const decipher = createDecipheriv("aes-256-ctr", key, iv);
62
+ return Buffer.concat([decipher.update(ciphertext), decipher.final()]);
104
63
  }
105
- exports.aesDecryptCTR = aesDecryptCTR;
106
- /** decrypt AES 256 CBC; where the IV is prefixed to the buffer */
107
- function aesDecrypt(buffer, key) {
108
- return aesDecryptWithIV(buffer.slice(16, buffer.length), key, buffer.slice(0, 16));
64
+ //=======================================================//
65
+ export function aesDecrypt(buffer, key) {
66
+ return aesDecryptWithIV(buffer.slice(16, buffer.length), key, buffer.slice(0, 16));
109
67
  }
110
- exports.aesDecrypt = aesDecrypt;
111
- /** decrypt AES 256 CBC */
112
- function aesDecryptWithIV(buffer, key, IV) {
113
- const aes = (0, crypto_1.createDecipheriv)('aes-256-cbc', key, IV);
114
- return Buffer.concat([aes.update(buffer), aes.final()]);
68
+ //=======================================================//
69
+ export function aesDecryptWithIV(buffer, key, IV) {
70
+ const aes = createDecipheriv("aes-256-cbc", key, IV);
71
+ return Buffer.concat([aes.update(buffer), aes.final()]);
115
72
  }
116
- exports.aesDecryptWithIV = aesDecryptWithIV;
117
- // encrypt AES 256 CBC; where a random IV is prefixed to the buffer
118
- function aesEncrypt(buffer, key) {
119
- const IV = (0, crypto_1.randomBytes)(16);
120
- const aes = (0, crypto_1.createCipheriv)('aes-256-cbc', key, IV);
121
- return Buffer.concat([IV, aes.update(buffer), aes.final()]); // prefix IV to the buffer
73
+ //=======================================================//
74
+ export function aesEncrypt(buffer, key) {
75
+ const IV = randomBytes(16);
76
+ const aes = createCipheriv("aes-256-cbc", key, IV);
77
+ return Buffer.concat([IV, aes.update(buffer), aes.final()]);
122
78
  }
123
- exports.aesEncrypt = aesEncrypt;
124
- // encrypt AES 256 CBC with a given IV
125
- function aesEncrypWithIV(buffer, key, IV) {
126
- const aes = (0, crypto_1.createCipheriv)('aes-256-cbc', key, IV);
127
- return Buffer.concat([aes.update(buffer), aes.final()]); // prefix IV to the buffer
79
+ //=======================================================//
80
+ export function aesEncrypWithIV(buffer, key, IV) {
81
+ const aes = createCipheriv("aes-256-cbc", key, IV);
82
+ return Buffer.concat([aes.update(buffer), aes.final()]);
128
83
  }
129
- exports.aesEncrypWithIV = aesEncrypWithIV;
130
- // sign HMAC using SHA 256
131
- function hmacSign(buffer, key, variant = 'sha256') {
132
- return (0, crypto_1.createHmac)(variant, key).update(buffer).digest();
84
+ //=======================================================//
85
+ export function hmacSign(buffer, key, variant = "sha256") {
86
+ return createHmac(variant, key).update(buffer).digest();
133
87
  }
134
- exports.hmacSign = hmacSign;
135
- function sha256(buffer) {
136
- return (0, crypto_1.createHash)('sha256').update(buffer).digest();
88
+ //=======================================================//
89
+ export function sha256(buffer) {
90
+ return createHash("sha256").update(buffer).digest();
137
91
  }
138
- exports.sha256 = sha256;
139
- function md5(buffer) {
140
- return (0, crypto_1.createHash)('md5').update(buffer).digest();
92
+ //=======================================================//
93
+ export function md5(buffer) {
94
+ return createHash("md5").update(buffer).digest();
141
95
  }
142
- exports.md5 = md5;
143
- // HKDF key expansion
144
- function hkdf(buffer, expandedLength, info) {
145
- return (0, futoin_hkdf_1.default)(!Buffer.isBuffer(buffer) ? Buffer.from(buffer) : buffer, expandedLength, info);
96
+ //=======================================================//
97
+ export async function hkdf(buffer, expandedLength, info) {
98
+ const inputKeyMaterial = new Uint8Array(buffer instanceof Uint8Array ? buffer : new Uint8Array(buffer));
99
+ const salt = info.salt ? new Uint8Array(info.salt) : new Uint8Array(0);
100
+ const infoBytes = info.info ? new TextEncoder().encode(info.info) : new Uint8Array(0);
101
+ const importedKey = await subtle.importKey("raw", inputKeyMaterial, { name: "HKDF" }, false, [
102
+ "deriveBits"
103
+ ]);
104
+ const derivedBits = await subtle.deriveBits({
105
+ name: "HKDF",
106
+ hash: "SHA-256",
107
+ salt: salt,
108
+ info: infoBytes
109
+ }, importedKey, expandedLength * 8
110
+ );
111
+ return Buffer.from(derivedBits);
146
112
  }
147
- exports.hkdf = hkdf;
148
- function derivePairingCodeKey(pairingCode, salt) {
149
- return (0, crypto_1.pbkdf2Sync)(pairingCode, salt, 2 << 16, 32, 'sha256');
113
+ //=======================================================//
114
+ export async function derivePairingCodeKey(pairingCode, salt) {
115
+ const encoder = new TextEncoder();
116
+ const pairingCodeBuffer = encoder.encode(pairingCode);
117
+ const saltBuffer = new Uint8Array(salt instanceof Uint8Array ? salt : new Uint8Array(salt));
118
+ const keyMaterial = await subtle.importKey("raw", pairingCodeBuffer, { name: "PBKDF2" }, false, [
119
+ "deriveBits"
120
+ ]);
121
+ const derivedBits = await subtle.deriveBits({
122
+ name: "PBKDF2",
123
+ salt: saltBuffer,
124
+ iterations: 2 << 16,
125
+ hash: "SHA-256"
126
+ }, keyMaterial, 32 * 8
127
+ );
128
+ return Buffer.from(derivedBits);
150
129
  }
151
- exports.derivePairingCodeKey = derivePairingCodeKey;
130
+ //=======================================================//