@baileys-md/baileys 11.2.4 → 12.0.1

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 (126) hide show
  1. package/LICENSE +1 -1
  2. package/WAProto/WAProto.proto +5311 -0
  3. package/WAProto/index.js +70084 -131686
  4. package/lib/Defaults/index.js +118 -117
  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 +13 -0
  9. package/lib/Signal/Group/group-session-builder.js +32 -0
  10. package/lib/Signal/Group/group_cipher.js +84 -0
  11. package/lib/Signal/Group/index.js +13 -0
  12. package/lib/Signal/Group/keyhelper.js +20 -0
  13. package/lib/Signal/Group/sender-chain-key.js +28 -0
  14. package/lib/Signal/Group/sender-key-distribution-message.js +65 -0
  15. package/lib/Signal/Group/sender-key-message.js +68 -0
  16. package/{WASignalGroup/sender_key_name.js → lib/Signal/Group/sender-key-name.js} +10 -28
  17. package/lib/Signal/Group/sender-key-record.js +43 -0
  18. package/lib/Signal/Group/sender-key-state.js +86 -0
  19. package/lib/Signal/Group/sender-message-key.js +28 -0
  20. package/lib/Signal/libsignal.js +314 -151
  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 +847 -844
  27. package/lib/Socket/communities.js +413 -0
  28. package/lib/Socket/groups.js +304 -319
  29. package/lib/Socket/index.js +15 -9
  30. package/lib/Socket/messages-recv.js +1109 -989
  31. package/lib/Socket/messages-send.js +611 -347
  32. package/lib/Socket/mex.js +45 -0
  33. package/lib/Socket/newsletter.js +230 -231
  34. package/lib/Socket/socket.js +795 -616
  35. package/lib/Store/index.js +6 -8
  36. package/lib/Store/make-cache-manager-store.js +73 -81
  37. package/lib/Store/make-in-memory-store.js +286 -427
  38. package/lib/Store/make-ordered-dictionary.js +77 -79
  39. package/lib/Store/object-repository.js +24 -26
  40. package/lib/Types/Auth.js +3 -2
  41. package/lib/Types/Bussines.js +3 -0
  42. package/lib/Types/Call.js +3 -2
  43. package/lib/Types/Chat.js +9 -4
  44. package/lib/Types/Contact.js +3 -2
  45. package/lib/Types/Events.js +3 -2
  46. package/lib/Types/GroupMetadata.js +3 -2
  47. package/lib/Types/Label.js +24 -26
  48. package/lib/Types/LabelAssociation.js +6 -8
  49. package/lib/Types/Message.js +12 -7
  50. package/lib/Types/Newsletter.js +32 -17
  51. package/lib/Types/Product.js +3 -2
  52. package/lib/Types/Signal.js +3 -2
  53. package/lib/Types/Socket.js +4 -2
  54. package/lib/Types/State.js +11 -2
  55. package/lib/Types/USync.js +3 -2
  56. package/lib/Types/index.js +27 -41
  57. package/lib/Utils/auth-utils.js +211 -198
  58. package/lib/Utils/baileys-event-stream.js +42 -61
  59. package/lib/Utils/browser-utils.js +25 -0
  60. package/lib/Utils/business.js +213 -214
  61. package/lib/Utils/chat-utils.js +711 -689
  62. package/lib/Utils/crypto.js +112 -133
  63. package/lib/Utils/decode-wa-message.js +254 -186
  64. package/lib/Utils/event-buffer.js +510 -502
  65. package/lib/Utils/generics.js +318 -408
  66. package/lib/Utils/history.js +83 -90
  67. package/lib/Utils/index.js +21 -33
  68. package/lib/Utils/link-preview.js +71 -116
  69. package/lib/Utils/logger.js +5 -7
  70. package/lib/Utils/lt-hash.js +40 -46
  71. package/lib/Utils/make-mutex.js +34 -41
  72. package/lib/Utils/message-retry-manager.js +113 -0
  73. package/lib/Utils/messages-media.js +575 -671
  74. package/lib/Utils/messages.js +354 -462
  75. package/lib/Utils/noise-handler.js +138 -149
  76. package/lib/Utils/pre-key-manager.js +85 -0
  77. package/lib/Utils/process-message.js +323 -354
  78. package/lib/Utils/signal.js +148 -130
  79. package/lib/Utils/use-multi-file-auth-state.js +109 -91
  80. package/lib/Utils/validate-connection.js +183 -190
  81. package/lib/WABinary/constants.js +1298 -35
  82. package/lib/WABinary/decode.js +231 -256
  83. package/lib/WABinary/encode.js +207 -239
  84. package/lib/WABinary/generic-utils.js +119 -40
  85. package/lib/WABinary/index.js +7 -21
  86. package/lib/WABinary/jid-utils.js +88 -64
  87. package/lib/WABinary/types.js +3 -2
  88. package/lib/WAM/BinaryInfo.js +10 -12
  89. package/lib/WAM/constants.js +22851 -15348
  90. package/lib/WAM/encode.js +135 -136
  91. package/lib/WAM/index.js +5 -19
  92. package/lib/WAUSync/Protocols/USyncContactProtocol.js +28 -30
  93. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +49 -53
  94. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +27 -28
  95. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +36 -39
  96. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +50 -50
  97. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +26 -20
  98. package/lib/WAUSync/Protocols/index.js +6 -20
  99. package/lib/WAUSync/USyncQuery.js +86 -85
  100. package/lib/WAUSync/USyncUser.js +23 -25
  101. package/lib/WAUSync/index.js +5 -19
  102. package/lib/index.js +18 -33
  103. package/package.json +52 -57
  104. package/README.md +0 -2
  105. package/WASignalGroup/GroupProtocol.js +0 -1697
  106. package/WASignalGroup/ciphertext_message.js +0 -16
  107. package/WASignalGroup/group_cipher.js +0 -120
  108. package/WASignalGroup/group_session_builder.js +0 -46
  109. package/WASignalGroup/index.js +0 -5
  110. package/WASignalGroup/keyhelper.js +0 -21
  111. package/WASignalGroup/protobufs.js +0 -3
  112. package/WASignalGroup/queue_job.js +0 -69
  113. package/WASignalGroup/sender_chain_key.js +0 -50
  114. package/WASignalGroup/sender_key_distribution_message.js +0 -78
  115. package/WASignalGroup/sender_key_message.js +0 -92
  116. package/WASignalGroup/sender_key_record.js +0 -56
  117. package/WASignalGroup/sender_key_state.js +0 -129
  118. package/WASignalGroup/sender_message_key.js +0 -39
  119. package/lib/Defaults/baileys-version.json +0 -3
  120. package/lib/Defaults/phonenumber-mcc.json +0 -223
  121. package/lib/Socket/Client/abstract-socket-client.js +0 -13
  122. package/lib/Socket/Client/mobile-socket-client.js +0 -65
  123. package/lib/Socket/Client/web-socket-client.js +0 -62
  124. package/lib/Socket/registration.js +0 -166
  125. package/lib/Socket/usync.js +0 -70
  126. package/lib/Store/make-mongo-store.js +0 -567
@@ -1,16 +0,0 @@
1
- class CiphertextMessage {
2
- UNSUPPORTED_VERSION = 1;
3
-
4
- CURRENT_VERSION = 3;
5
-
6
- WHISPER_TYPE = 2;
7
-
8
- PREKEY_TYPE = 3;
9
-
10
- SENDERKEY_TYPE = 4;
11
-
12
- SENDERKEY_DISTRIBUTION_TYPE = 5;
13
-
14
- ENCRYPTED_MESSAGE_OVERHEAD = 53;
15
- }
16
- module.exports = CiphertextMessage;
@@ -1,120 +0,0 @@
1
- const queue_job = require('./queue_job');
2
- const SenderKeyMessage = require('./sender_key_message');
3
- const crypto = require('libsignal/src/crypto');
4
-
5
- class GroupCipher {
6
- constructor(senderKeyStore, senderKeyName) {
7
- this.senderKeyStore = senderKeyStore;
8
- this.senderKeyName = senderKeyName;
9
- }
10
-
11
- queueJob(awaitable) {
12
- return queue_job(this.senderKeyName.toString(), awaitable)
13
- }
14
-
15
- async encrypt(paddedPlaintext) {
16
- return await this.queueJob(async () => {
17
- const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
18
- if (!record) {
19
- throw new Error("No SenderKeyRecord found for encryption")
20
- }
21
- const senderKeyState = record.getSenderKeyState();
22
- if (!senderKeyState) {
23
- throw new Error("No session to encrypt message");
24
- }
25
- const iteration = senderKeyState.getSenderChainKey().getIteration()
26
- const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1)
27
-
28
- const ciphertext = await this.getCipherText(
29
- senderKey.getIv(),
30
- senderKey.getCipherKey(),
31
- paddedPlaintext
32
- );
33
-
34
- const senderKeyMessage = new SenderKeyMessage(
35
- senderKeyState.getKeyId(),
36
- senderKey.getIteration(),
37
- ciphertext,
38
- senderKeyState.getSigningKeyPrivate()
39
- );
40
- await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
41
- return senderKeyMessage.serialize()
42
- })
43
- }
44
-
45
- async decrypt(senderKeyMessageBytes) {
46
- return await this.queueJob(async () => {
47
- const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
48
- if (!record) {
49
- throw new Error("No SenderKeyRecord found for decryption")
50
- }
51
- const senderKeyMessage = new SenderKeyMessage(null, null, null, null, senderKeyMessageBytes);
52
- const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId());
53
- if (!senderKeyState) {
54
- throw new Error("No session found to decrypt message")
55
- }
56
-
57
- senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic());
58
- const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration());
59
- // senderKeyState.senderKeyStateStructure.senderSigningKey.private =
60
-
61
- const plaintext = await this.getPlainText(
62
- senderKey.getIv(),
63
- senderKey.getCipherKey(),
64
- senderKeyMessage.getCipherText()
65
- );
66
-
67
- await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
68
-
69
- return plaintext;
70
- })
71
- }
72
-
73
- getSenderKey(senderKeyState, iteration) {
74
- let senderChainKey = senderKeyState.getSenderChainKey();
75
- if (senderChainKey.getIteration() > iteration) {
76
- if (senderKeyState.hasSenderMessageKey(iteration)) {
77
- return senderKeyState.removeSenderMessageKey(iteration);
78
- }
79
- throw new Error(
80
- `Received message with old counter: ${senderChainKey.getIteration()}, ${iteration}`
81
- );
82
- }
83
-
84
- if (iteration - senderChainKey.getIteration() > 2000) {
85
- throw new Error('Over 2000 messages into the future!');
86
- }
87
-
88
- while (senderChainKey.getIteration() < iteration) {
89
- senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey());
90
- senderChainKey = senderChainKey.getNext();
91
- }
92
-
93
- senderKeyState.setSenderChainKey(senderChainKey.getNext());
94
- return senderChainKey.getSenderMessageKey();
95
- }
96
-
97
- getPlainText(iv, key, ciphertext) {
98
- try {
99
- const plaintext = crypto.decrypt(key, ciphertext, iv);
100
- return plaintext;
101
- } catch (e) {
102
- //console.log(e.stack);
103
- throw new Error('InvalidMessageException');
104
- }
105
- }
106
-
107
- getCipherText(iv, key, plaintext) {
108
- try {
109
- iv = typeof iv === 'string' ? Buffer.from(iv, 'base64') : iv;
110
- key = typeof key === 'string' ? Buffer.from(key, 'base64') : key;
111
- const crypted = crypto.encrypt(key, Buffer.from(plaintext), iv);
112
- return crypted;
113
- } catch (e) {
114
- //console.log(e.stack);
115
- throw new Error('InvalidMessageException');
116
- }
117
- }
118
- }
119
-
120
- module.exports = GroupCipher;
@@ -1,46 +0,0 @@
1
- //const utils = require('../../common/utils');
2
- const SenderKeyDistributionMessage = require('./sender_key_distribution_message');
3
-
4
- const keyhelper = require("./keyhelper");
5
- class GroupSessionBuilder {
6
- constructor(senderKeyStore) {
7
- this.senderKeyStore = senderKeyStore;
8
- }
9
-
10
- async process(senderKeyName, senderKeyDistributionMessage) {
11
- //console.log('GroupSessionBuilder process', senderKeyName, senderKeyDistributionMessage);
12
- const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName);
13
- senderKeyRecord.addSenderKeyState(
14
- senderKeyDistributionMessage.getId(),
15
- senderKeyDistributionMessage.getIteration(),
16
- senderKeyDistributionMessage.getChainKey(),
17
- senderKeyDistributionMessage.getSignatureKey()
18
- );
19
- await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord);
20
- }
21
-
22
- // [{"senderKeyId":1742199468,"senderChainKey":{"iteration":0,"seed":"yxMY9VFQcXEP34olRAcGCtsgx1XoKsHfDIh+1ea4HAQ="},"senderSigningKey":{"public":""}}]
23
- async create(senderKeyName) {
24
- const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName);
25
- //console.log('GroupSessionBuilder create session', senderKeyName, senderKeyRecord);
26
-
27
- if (senderKeyRecord.isEmpty()) {
28
- const keyId = keyhelper.generateSenderKeyId();
29
- const senderKey = keyhelper.generateSenderKey();
30
- const signingKey = keyhelper.generateSenderSigningKey();
31
-
32
- senderKeyRecord.setSenderKeyState(keyId, 0, senderKey, signingKey);
33
- await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord);
34
- }
35
-
36
- const state = senderKeyRecord.getSenderKeyState();
37
-
38
- return new SenderKeyDistributionMessage(
39
- state.getKeyId(),
40
- state.getSenderChainKey().getIteration(),
41
- state.getSenderChainKey().getSeed(),
42
- state.getSigningKeyPublic()
43
- );
44
- }
45
- }
46
- module.exports = GroupSessionBuilder;
@@ -1,5 +0,0 @@
1
- module.exports.GroupSessionBuilder = require('./group_session_builder')
2
- module.exports.SenderKeyDistributionMessage = require('./sender_key_distribution_message')
3
- module.exports.SenderKeyRecord = require('./sender_key_record')
4
- module.exports.SenderKeyName = require('./sender_key_name')
5
- module.exports.GroupCipher = require('./group_cipher')
@@ -1,21 +0,0 @@
1
- const curve = require('libsignal/src/curve');
2
- const nodeCrypto = require('crypto');
3
-
4
- exports.generateSenderKey = function() {
5
- return nodeCrypto.randomBytes(32);
6
- }
7
-
8
- exports.generateSenderKeyId = function() {
9
- return nodeCrypto.randomInt(2147483647);
10
- }
11
-
12
- exports.generateSenderSigningKey = function(key) {
13
- if (!key) {
14
- key = curve.generateKeyPair();
15
- }
16
-
17
- return {
18
- public: key.pubKey,
19
- private: key.privKey,
20
- };
21
- }
@@ -1,3 +0,0 @@
1
- const { groupproto } = require('./GroupProtocol')
2
-
3
- module.exports = groupproto
@@ -1,69 +0,0 @@
1
- // vim: ts=4:sw=4:expandtab
2
-
3
- /*
4
- * jobQueue manages multiple queues indexed by device to serialize
5
- * session io ops on the database.
6
- */
7
- 'use strict';
8
-
9
-
10
- const _queueAsyncBuckets = new Map();
11
- const _gcLimit = 10000;
12
-
13
- async function _asyncQueueExecutor(queue, cleanup) {
14
- let offt = 0;
15
- while (true) {
16
- let limit = Math.min(queue.length, _gcLimit); // Break up thundering hurds for GC duty.
17
- for (let i = offt; i < limit; i++) {
18
- const job = queue[i];
19
- try {
20
- job.resolve(await job.awaitable());
21
- } catch (e) {
22
- job.reject(e);
23
- }
24
- }
25
- if (limit < queue.length) {
26
- /* Perform lazy GC of queue for faster iteration. */
27
- if (limit >= _gcLimit) {
28
- queue.splice(0, limit);
29
- offt = 0;
30
- } else {
31
- offt = limit;
32
- }
33
- } else {
34
- break;
35
- }
36
- }
37
- cleanup();
38
- }
39
-
40
- module.exports = function (bucket, awaitable) {
41
- /* Run the async awaitable only when all other async calls registered
42
- * here have completed (or thrown). The bucket argument is a hashable
43
- * key representing the task queue to use. */
44
- if (!awaitable.name) {
45
- // Make debuging easier by adding a name to this function.
46
- Object.defineProperty(awaitable, 'name', { writable: true });
47
- if (typeof bucket === 'string') {
48
- awaitable.name = bucket;
49
- } else {
50
- console.warn("Unhandled bucket type (for naming):", typeof bucket, bucket);
51
- }
52
- }
53
- let inactive;
54
- if (!_queueAsyncBuckets.has(bucket)) {
55
- _queueAsyncBuckets.set(bucket, []);
56
- inactive = true;
57
- }
58
- const queue = _queueAsyncBuckets.get(bucket);
59
- const job = new Promise((resolve, reject) => queue.push({
60
- awaitable,
61
- resolve,
62
- reject
63
- }));
64
- if (inactive) {
65
- /* An executor is not currently active; Start one now. */
66
- _asyncQueueExecutor(queue, () => _queueAsyncBuckets.delete(bucket));
67
- }
68
- return job;
69
- };
@@ -1,50 +0,0 @@
1
- const SenderMessageKey = require('./sender_message_key');
2
- //const HKDF = require('./hkdf');
3
- const crypto = require('libsignal/src/crypto');
4
-
5
- class SenderChainKey {
6
- MESSAGE_KEY_SEED = Buffer.from([0x01]);
7
-
8
- CHAIN_KEY_SEED = Buffer.from([0x02]);
9
-
10
- iteration = 0;
11
-
12
- chainKey = Buffer.alloc(0);
13
-
14
- constructor(iteration, chainKey) {
15
- this.iteration = iteration;
16
- this.chainKey = chainKey;
17
- }
18
-
19
- getIteration() {
20
- return this.iteration;
21
- }
22
-
23
- getSenderMessageKey() {
24
- return new SenderMessageKey(
25
- this.iteration,
26
- this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey)
27
- );
28
- }
29
-
30
- getNext() {
31
- return new SenderChainKey(
32
- this.iteration + 1,
33
- this.getDerivative(this.CHAIN_KEY_SEED, this.chainKey)
34
- );
35
- }
36
-
37
- getSeed() {
38
- return typeof this.chainKey === 'string' ? Buffer.from(this.chainKey, 'base64') : this.chainKey;
39
- }
40
-
41
- getDerivative(seed, key) {
42
- key = typeof key === 'string' ? Buffer.from(key, 'base64') : key;
43
- const hash = crypto.calculateMAC(key, seed);
44
- //const hash = new Hash().hmac_hash(key, seed, 'sha256', '');
45
-
46
- return hash;
47
- }
48
- }
49
-
50
- module.exports = SenderChainKey;
@@ -1,78 +0,0 @@
1
- const CiphertextMessage = require('./ciphertext_message');
2
- const protobufs = require('./protobufs');
3
-
4
- class SenderKeyDistributionMessage extends CiphertextMessage {
5
- constructor(
6
- id = null,
7
- iteration = null,
8
- chainKey = null,
9
- signatureKey = null,
10
- serialized = null
11
- ) {
12
- super();
13
- if (serialized) {
14
- try {
15
- const version = serialized[0];
16
- const message = serialized.slice(1);
17
-
18
- const distributionMessage = protobufs.SenderKeyDistributionMessage.decode(
19
- message
20
- ).toJSON();
21
- this.serialized = serialized;
22
- this.id = distributionMessage.id;
23
- this.iteration = distributionMessage.iteration;
24
- this.chainKey = distributionMessage.chainKey;
25
- this.signatureKey = distributionMessage.signingKey;
26
- } catch (e) {
27
- throw new Error(e);
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 = protobufs.SenderKeyDistributionMessage.encode(
36
- protobufs.SenderKeyDistributionMessage.create({
37
- id,
38
- iteration,
39
- chainKey,
40
- signingKey: this.signatureKey,
41
- })
42
- ).finish();
43
- this.serialized = Buffer.concat([Buffer.from([version]), message]);
44
- }
45
- }
46
-
47
- intsToByteHighAndLow(highValue, lowValue) {
48
- return (((highValue << 4) | lowValue) & 0xff) % 256;
49
- }
50
-
51
- serialize() {
52
- return this.serialized;
53
- }
54
-
55
- getType() {
56
- return this.SENDERKEY_DISTRIBUTION_TYPE;
57
- }
58
-
59
- getIteration() {
60
- return this.iteration;
61
- }
62
-
63
- getChainKey() {
64
- return typeof this.chainKey === 'string' ? Buffer.from(this.chainKey, 'base64') : this.chainKey;
65
- }
66
-
67
- getSignatureKey() {
68
- return typeof this.signatureKey === 'string'
69
- ? Buffer.from(this.signatureKey, 'base64')
70
- : this.signatureKey;
71
- }
72
-
73
- getId() {
74
- return this.id;
75
- }
76
- }
77
-
78
- module.exports = SenderKeyDistributionMessage;
@@ -1,92 +0,0 @@
1
- const CiphertextMessage = require('./ciphertext_message');
2
- const curve = require('libsignal/src/curve');
3
- const protobufs = require('./protobufs');
4
-
5
- class SenderKeyMessage extends CiphertextMessage {
6
- SIGNATURE_LENGTH = 64;
7
-
8
- constructor(
9
- keyId = null,
10
- iteration = null,
11
- ciphertext = null,
12
- signatureKey = null,
13
- serialized = null
14
- ) {
15
- super();
16
- if (serialized) {
17
- const version = serialized[0];
18
- const message = serialized.slice(1, serialized.length - this.SIGNATURE_LENGTH);
19
- const signature = serialized.slice(-1 * this.SIGNATURE_LENGTH);
20
- const senderKeyMessage = protobufs.SenderKeyMessage.decode(message).toJSON();
21
- senderKeyMessage.ciphertext = Buffer.from(senderKeyMessage.ciphertext, 'base64');
22
-
23
- this.serialized = serialized;
24
- this.messageVersion = (version & 0xff) >> 4;
25
-
26
- this.keyId = senderKeyMessage.id;
27
- this.iteration = senderKeyMessage.iteration;
28
- this.ciphertext = senderKeyMessage.ciphertext;
29
- this.signature = signature;
30
- } else {
31
- const version = (((this.CURRENT_VERSION << 4) | this.CURRENT_VERSION) & 0xff) % 256;
32
- ciphertext = Buffer.from(ciphertext); // .toString('base64');
33
- const message = protobufs.SenderKeyMessage.encode(
34
- protobufs.SenderKeyMessage.create({
35
- id: keyId,
36
- iteration,
37
- ciphertext,
38
- })
39
- ).finish();
40
-
41
- const signature = this.getSignature(
42
- signatureKey,
43
- Buffer.concat([Buffer.from([version]), message])
44
- );
45
- this.serialized = Buffer.concat([Buffer.from([version]), message, Buffer.from(signature)]);
46
- this.messageVersion = this.CURRENT_VERSION;
47
- this.keyId = keyId;
48
- this.iteration = iteration;
49
- this.ciphertext = ciphertext;
50
- this.signature = signature;
51
- }
52
- }
53
-
54
- getKeyId() {
55
- return this.keyId;
56
- }
57
-
58
- getIteration() {
59
- return this.iteration;
60
- }
61
-
62
- getCipherText() {
63
- return this.ciphertext;
64
- }
65
-
66
- verifySignature(signatureKey) {
67
- const part1 = this.serialized.slice(0, this.serialized.length - this.SIGNATURE_LENGTH);
68
- const part2 = this.serialized.slice(-1 * this.SIGNATURE_LENGTH);
69
- const res = curve.verifySignature(signatureKey, part1, part2);
70
- if (!res) throw new Error('Invalid signature!');
71
- }
72
-
73
- getSignature(signatureKey, serialized) {
74
- const signature = Buffer.from(
75
- curve.calculateSignature(
76
- signatureKey,
77
- serialized
78
- )
79
- );
80
- return signature;
81
- }
82
-
83
- serialize() {
84
- return this.serialized;
85
- }
86
-
87
- getType() {
88
- return 4;
89
- }
90
- }
91
-
92
- module.exports = SenderKeyMessage;
@@ -1,56 +0,0 @@
1
- const SenderKeyState = require('./sender_key_state');
2
-
3
- class SenderKeyRecord {
4
- MAX_STATES = 5;
5
-
6
- constructor(serialized) {
7
- this.senderKeyStates = [];
8
-
9
- if (serialized) {
10
- const list = serialized;
11
- for (let i = 0; i < list.length; i++) {
12
- const structure = list[i];
13
- this.senderKeyStates.push(
14
- new SenderKeyState(null, null, null, null, null, null, structure)
15
- );
16
- }
17
- }
18
- }
19
-
20
- isEmpty() {
21
- return this.senderKeyStates.length === 0;
22
- }
23
-
24
- getSenderKeyState(keyId) {
25
- if (!keyId && this.senderKeyStates.length) return this.senderKeyStates[this.senderKeyStates.length - 1];
26
- for (let i = 0; i < this.senderKeyStates.length; i++) {
27
- const state = this.senderKeyStates[i];
28
- if (state.getKeyId() === keyId) {
29
- return state;
30
- }
31
- }
32
- }
33
-
34
- addSenderKeyState(id, iteration, chainKey, signatureKey) {
35
- this.senderKeyStates.push(new SenderKeyState(id, iteration, chainKey, null, signatureKey));
36
- if (this.senderKeyStates.length > 5) {
37
- this.senderKeyStates.shift()
38
- }
39
- }
40
-
41
- setSenderKeyState(id, iteration, chainKey, keyPair) {
42
- this.senderKeyStates.length = 0;
43
- this.senderKeyStates.push(new SenderKeyState(id, iteration, chainKey, keyPair));
44
- }
45
-
46
- serialize() {
47
- const recordStructure = [];
48
- for (let i = 0; i < this.senderKeyStates.length; i++) {
49
- const senderKeyState = this.senderKeyStates[i];
50
- recordStructure.push(senderKeyState.getStructure());
51
- }
52
- return recordStructure;
53
- }
54
- }
55
-
56
- module.exports = SenderKeyRecord;
@@ -1,129 +0,0 @@
1
- const SenderChainKey = require('./sender_chain_key');
2
- const SenderMessageKey = require('./sender_message_key');
3
-
4
- const protobufs = require('./protobufs');
5
-
6
- class SenderKeyState {
7
- MAX_MESSAGE_KEYS = 2000;
8
-
9
- constructor(
10
- id = null,
11
- iteration = null,
12
- chainKey = null,
13
- signatureKeyPair = null,
14
- signatureKeyPublic = null,
15
- signatureKeyPrivate = null,
16
- senderKeyStateStructure = null
17
- ) {
18
- if (senderKeyStateStructure) {
19
- this.senderKeyStateStructure = senderKeyStateStructure;
20
- } else {
21
- if (signatureKeyPair) {
22
- signatureKeyPublic = signatureKeyPair.public;
23
- signatureKeyPrivate = signatureKeyPair.private;
24
- }
25
-
26
- chainKey = typeof chainKey === 'string' ? Buffer.from(chainKey, 'base64') : chainKey;
27
- this.senderKeyStateStructure = protobufs.SenderKeyStateStructure.create();
28
- const senderChainKeyStructure = protobufs.SenderChainKey.create();
29
- senderChainKeyStructure.iteration = iteration;
30
- senderChainKeyStructure.seed = chainKey;
31
- this.senderKeyStateStructure.senderChainKey = senderChainKeyStructure;
32
-
33
- const signingKeyStructure = protobufs.SenderSigningKey.create();
34
- signingKeyStructure.public =
35
- typeof signatureKeyPublic === 'string' ?
36
- Buffer.from(signatureKeyPublic, 'base64') :
37
- signatureKeyPublic;
38
- if (signatureKeyPrivate) {
39
- signingKeyStructure.private =
40
- typeof signatureKeyPrivate === 'string' ?
41
- Buffer.from(signatureKeyPrivate, 'base64') :
42
- signatureKeyPrivate;
43
- }
44
- this.senderKeyStateStructure.senderKeyId = id;
45
- this.senderChainKey = senderChainKeyStructure;
46
- this.senderKeyStateStructure.senderSigningKey = signingKeyStructure;
47
- }
48
- this.senderKeyStateStructure.senderMessageKeys =
49
- this.senderKeyStateStructure.senderMessageKeys || [];
50
- }
51
-
52
- SenderKeyState(senderKeyStateStructure) {
53
- this.senderKeyStateStructure = senderKeyStateStructure;
54
- }
55
-
56
- getKeyId() {
57
- return this.senderKeyStateStructure.senderKeyId;
58
- }
59
-
60
- getSenderChainKey() {
61
- return new SenderChainKey(
62
- this.senderKeyStateStructure.senderChainKey.iteration,
63
- this.senderKeyStateStructure.senderChainKey.seed
64
- );
65
- }
66
-
67
- setSenderChainKey(chainKey) {
68
- const senderChainKeyStructure = protobufs.SenderChainKey.create({
69
- iteration: chainKey.getIteration(),
70
- seed: chainKey.getSeed(),
71
- });
72
- this.senderKeyStateStructure.senderChainKey = senderChainKeyStructure;
73
- }
74
-
75
- getSigningKeyPublic() {
76
- return typeof this.senderKeyStateStructure.senderSigningKey.public === 'string' ?
77
- Buffer.from(this.senderKeyStateStructure.senderSigningKey.public, 'base64') :
78
- this.senderKeyStateStructure.senderSigningKey.public;
79
- }
80
-
81
- getSigningKeyPrivate() {
82
- return typeof this.senderKeyStateStructure.senderSigningKey.private === 'string' ?
83
- Buffer.from(this.senderKeyStateStructure.senderSigningKey.private, 'base64') :
84
- this.senderKeyStateStructure.senderSigningKey.private;
85
- }
86
-
87
- hasSenderMessageKey(iteration) {
88
- const list = this.senderKeyStateStructure.senderMessageKeys;
89
- for (let o = 0; o < list.length; o++) {
90
- const senderMessageKey = list[o];
91
- if (senderMessageKey.iteration === iteration) return true;
92
- }
93
- return false;
94
- }
95
-
96
- addSenderMessageKey(senderMessageKey) {
97
- const senderMessageKeyStructure = protobufs.SenderKeyStateStructure.create({
98
- iteration: senderMessageKey.getIteration(),
99
- seed: senderMessageKey.getSeed(),
100
- });
101
- this.senderKeyStateStructure.senderMessageKeys.push(senderMessageKeyStructure);
102
-
103
- if (this.senderKeyStateStructure.senderMessageKeys.length > this.MAX_MESSAGE_KEYS) {
104
- this.senderKeyStateStructure.senderMessageKeys.shift();
105
- }
106
- }
107
-
108
- removeSenderMessageKey(iteration) {
109
- let result = null;
110
-
111
- this.senderKeyStateStructure.senderMessageKeys = this.senderKeyStateStructure.senderMessageKeys.filter(
112
- senderMessageKey => {
113
- if (senderMessageKey.iteration === iteration) result = senderMessageKey;
114
- return senderMessageKey.iteration !== iteration;
115
- }
116
- );
117
-
118
- if (result != null) {
119
- return new SenderMessageKey(result.iteration, result.seed);
120
- }
121
- return null;
122
- }
123
-
124
- getStructure() {
125
- return this.senderKeyStateStructure;
126
- }
127
- }
128
-
129
- module.exports = SenderKeyState;