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