@neelegirl/baileys 1.5.2 → 1.5.3

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 (193) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +195 -187
  3. package/WAProto/WAProto.proto +537 -236
  4. package/WAProto/index.d.ts +5971 -2388
  5. package/WAProto/index.js +17298 -6513
  6. package/lib/Defaults/baileys-version.json +3 -3
  7. package/lib/Defaults/index.d.ts +77 -67
  8. package/lib/Defaults/index.js +148 -136
  9. package/lib/Defaults/phonenumber-mcc.json +223 -223
  10. package/lib/Signal/WASignalGroup/GroupProtocol.js +1908 -1908
  11. package/lib/Signal/WASignalGroup/ciphertext-message.d.ts +9 -0
  12. package/lib/Signal/WASignalGroup/ciphertext-message.js +19 -0
  13. package/lib/Signal/WASignalGroup/ciphertext_message.js +15 -15
  14. package/lib/Signal/WASignalGroup/group-session-builder.d.ts +17 -0
  15. package/lib/Signal/WASignalGroup/group-session-builder.js +72 -0
  16. package/lib/Signal/WASignalGroup/group.proto +41 -41
  17. package/lib/Signal/WASignalGroup/group_cipher.d.ts +19 -0
  18. package/lib/Signal/WASignalGroup/group_cipher.js +101 -110
  19. package/lib/Signal/WASignalGroup/group_session_builder.js +45 -45
  20. package/lib/Signal/WASignalGroup/index.d.ts +11 -0
  21. package/lib/Signal/WASignalGroup/index.js +61 -6
  22. package/lib/Signal/WASignalGroup/keyhelper.d.ts +16 -0
  23. package/lib/Signal/WASignalGroup/keyhelper.js +58 -13
  24. package/lib/Signal/WASignalGroup/protobufs.js +2 -2
  25. package/lib/Signal/WASignalGroup/queue_job.js +68 -68
  26. package/lib/Signal/WASignalGroup/readme.md +5 -5
  27. package/lib/Signal/WASignalGroup/sender-chain-key.d.ts +14 -0
  28. package/lib/Signal/WASignalGroup/sender-chain-key.js +47 -0
  29. package/lib/Signal/WASignalGroup/sender-key-distribution-message.d.ts +17 -0
  30. package/lib/Signal/WASignalGroup/sender-key-distribution-message.js +71 -0
  31. package/lib/Signal/WASignalGroup/sender-key-message.d.ts +19 -0
  32. package/lib/Signal/WASignalGroup/sender-key-message.js +73 -0
  33. package/lib/Signal/WASignalGroup/sender-key-name.d.ts +19 -0
  34. package/lib/Signal/WASignalGroup/sender-key-name.js +59 -0
  35. package/lib/Signal/WASignalGroup/sender-key-record.d.ts +32 -0
  36. package/lib/Signal/WASignalGroup/sender-key-record.js +58 -0
  37. package/lib/Signal/WASignalGroup/sender-key-state.d.ts +44 -0
  38. package/lib/Signal/WASignalGroup/sender-key-state.js +147 -0
  39. package/lib/Signal/WASignalGroup/sender-message-key.d.ts +11 -0
  40. package/lib/Signal/WASignalGroup/sender-message-key.js +33 -0
  41. package/lib/Signal/WASignalGroup/sender_chain_key.js +49 -49
  42. package/lib/Signal/WASignalGroup/sender_key_distribution_message.js +77 -77
  43. package/lib/Signal/WASignalGroup/sender_key_message.js +91 -91
  44. package/lib/Signal/WASignalGroup/sender_key_name.js +69 -69
  45. package/lib/Signal/WASignalGroup/sender_key_record.js +55 -55
  46. package/lib/Signal/WASignalGroup/sender_key_state.js +128 -128
  47. package/lib/Signal/WASignalGroup/sender_message_key.js +38 -38
  48. package/lib/Signal/libsignal.d.ts +5 -1
  49. package/lib/Signal/libsignal.js +390 -161
  50. package/lib/Signal/lid-mapping.d.ts +28 -0
  51. package/lib/Signal/lid-mapping.js +184 -0
  52. package/lib/Socket/Client/abstract-socket-client.d.ts +15 -15
  53. package/lib/Socket/Client/abstract-socket-client.js +13 -13
  54. package/lib/Socket/Client/index.d.ts +2 -2
  55. package/lib/Socket/Client/mobile-socket-client.d.ts +12 -12
  56. package/lib/Socket/Client/mobile-socket-client.js +65 -65
  57. package/lib/Socket/Client/types.d.ts +1 -1
  58. package/lib/Socket/Client/websocket.d.ts +1 -1
  59. package/lib/Socket/business.d.ts +6 -6
  60. package/lib/Socket/business.js +152 -5
  61. package/lib/Socket/chats.d.ts +3 -4
  62. package/lib/Socket/chats.js +31 -26
  63. package/lib/Socket/communities.d.ts +223 -223
  64. package/lib/Socket/communities.js +432 -432
  65. package/lib/Socket/groups.d.ts +2 -4
  66. package/lib/Socket/groups.js +22 -14
  67. package/lib/Socket/index.d.ts +69 -69
  68. package/lib/Socket/index.js +3 -2
  69. package/lib/Socket/messages-recv.d.ts +3 -6
  70. package/lib/Socket/messages-recv.js +1449 -1707
  71. package/lib/Socket/messages-send.d.ts +2 -4
  72. package/lib/Socket/messages-send.js +617 -126
  73. package/lib/Socket/mex.d.ts +2 -2
  74. package/lib/Socket/mex.js +46 -46
  75. package/lib/Socket/newsletter.d.ts +2 -4
  76. package/lib/Socket/newsletter.js +294 -285
  77. package/lib/Socket/socket.js +318 -132
  78. package/lib/Socket/usync.js +3 -3
  79. package/lib/Store/index.d.ts +4 -4
  80. package/lib/Store/index.js +23 -23
  81. package/lib/Store/make-cache-manager-store.d.ts +13 -13
  82. package/lib/Store/make-cache-manager-store.js +89 -89
  83. package/lib/Store/make-in-memory-store.d.ts +122 -122
  84. package/lib/Store/make-in-memory-store.js +428 -428
  85. package/lib/Store/make-ordered-dictionary.d.ts +11 -11
  86. package/lib/Store/make-ordered-dictionary.js +85 -85
  87. package/lib/Store/object-repository.d.ts +9 -9
  88. package/lib/Store/object-repository.js +30 -30
  89. package/lib/Types/Auth.d.ts +5 -4
  90. package/lib/Types/Bussines.js +3 -0
  91. package/lib/Types/Bussiness.d.ts +28 -0
  92. package/lib/Types/Chat.d.ts +13 -8
  93. package/lib/Types/Contact.d.ts +4 -1
  94. package/lib/Types/Events.d.ts +13 -16
  95. package/lib/Types/GroupMetadata.d.ts +1 -1
  96. package/lib/Types/Message.d.ts +18 -7
  97. package/lib/Types/Message.js +7 -1
  98. package/lib/Types/MexUpdates.d.ts +8 -8
  99. package/lib/Types/MexUpdates.js +17 -17
  100. package/lib/Types/Newsletter.d.ts +1 -1
  101. package/lib/Types/Product.d.ts +1 -1
  102. package/lib/Types/Signal.d.ts +31 -1
  103. package/lib/Types/Socket.d.ts +34 -13
  104. package/lib/Types/State.d.ts +1 -1
  105. package/lib/Types/USync.d.ts +2 -2
  106. package/lib/Types/index.d.ts +16 -15
  107. package/lib/Types/index.js +4 -2
  108. package/lib/Utils/auth-utils.d.ts +20 -20
  109. package/lib/Utils/auth-utils.js +527 -204
  110. package/lib/Utils/baileys-event-stream.d.ts +17 -17
  111. package/lib/Utils/baileys-event-stream.js +69 -69
  112. package/lib/Utils/business.d.ts +28 -28
  113. package/lib/Utils/business.js +254 -254
  114. package/lib/Utils/chat-utils.d.ts +81 -81
  115. package/lib/Utils/chat-utils.js +808 -780
  116. package/lib/Utils/crypto.d.ts +55 -55
  117. package/lib/Utils/crypto.js +188 -178
  118. package/lib/Utils/decode-wa-message.d.ts +52 -40
  119. package/lib/Utils/decode-wa-message.js +322 -252
  120. package/lib/Utils/event-buffer.d.ts +38 -38
  121. package/lib/Utils/event-buffer.js +594 -564
  122. package/lib/Utils/generics.d.ts +131 -129
  123. package/lib/Utils/generics.js +629 -623
  124. package/lib/Utils/history.d.ts +22 -22
  125. package/lib/Utils/history.js +103 -109
  126. package/lib/Utils/index.d.ts +20 -19
  127. package/lib/Utils/index.js +39 -38
  128. package/lib/Utils/link-preview.d.ts +22 -22
  129. package/lib/Utils/link-preview.js +119 -119
  130. package/lib/Utils/logger.d.ts +13 -13
  131. package/lib/Utils/logger.js +7 -7
  132. package/lib/Utils/lt-hash.d.ts +13 -13
  133. package/lib/Utils/lt-hash.js +57 -57
  134. package/lib/Utils/make-mutex.d.ts +8 -8
  135. package/lib/Utils/make-mutex.js +48 -48
  136. package/lib/Utils/message-retry-manager.d.ts +88 -0
  137. package/lib/Utils/message-retry-manager.js +160 -0
  138. package/lib/Utils/messages-media.d.ts +134 -128
  139. package/lib/Utils/messages-media.js +868 -805
  140. package/lib/Utils/messages.d.ts +104 -102
  141. package/lib/Utils/messages.js +1744 -1578
  142. package/lib/Utils/noise-handler.d.ts +20 -19
  143. package/lib/Utils/noise-handler.js +164 -154
  144. package/lib/Utils/process-message.d.ts +48 -48
  145. package/lib/Utils/process-message.js +427 -428
  146. package/lib/Utils/signal.d.ts +41 -41
  147. package/lib/Utils/signal.js +165 -165
  148. package/lib/Utils/use-mongo-file-auth-state.d.ts +5 -5
  149. package/lib/Utils/use-mongo-file-auth-state.js +83 -83
  150. package/lib/Utils/use-multi-file-auth-state.d.ts +17 -17
  151. package/lib/Utils/use-multi-file-auth-state.js +237 -237
  152. package/lib/Utils/use-single-file-auth-state.d.ts +12 -12
  153. package/lib/Utils/use-single-file-auth-state.js +79 -79
  154. package/lib/Utils/validate-connection.d.ts +12 -12
  155. package/lib/Utils/validate-connection.js +219 -186
  156. package/lib/WABinary/constants.d.ts +29 -29
  157. package/lib/WABinary/constants.js +1315 -1315
  158. package/lib/WABinary/decode.d.ts +8 -8
  159. package/lib/WABinary/decode.js +287 -287
  160. package/lib/WABinary/encode.d.ts +2 -2
  161. package/lib/WABinary/encode.js +264 -264
  162. package/lib/WABinary/generic-utils.d.ts +27 -27
  163. package/lib/WABinary/generic-utils.js +141 -141
  164. package/lib/WABinary/index.d.ts +5 -5
  165. package/lib/WABinary/index.js +24 -24
  166. package/lib/WABinary/jid-utils.d.ts +58 -53
  167. package/lib/WABinary/jid-utils.js +103 -91
  168. package/lib/WABinary/types.d.ts +21 -21
  169. package/lib/WABinary/types.js +2 -2
  170. package/lib/WAM/BinaryInfo.d.ts +15 -15
  171. package/lib/WAM/BinaryInfo.js +16 -16
  172. package/lib/WAM/constants.d.ts +46 -46
  173. package/lib/WAM/constants.js +15370 -15370
  174. package/lib/WAM/encode.d.ts +2 -2
  175. package/lib/WAM/encode.js +163 -164
  176. package/lib/WAM/index.d.ts +3 -3
  177. package/lib/WAM/index.js +22 -22
  178. package/lib/WAUSync/Protocols/USyncBotProfileProtocol.d.ts +27 -27
  179. package/lib/WAUSync/Protocols/USyncBotProfileProtocol.js +68 -68
  180. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +3 -3
  181. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +2 -2
  182. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +2 -2
  183. package/lib/WAUSync/Protocols/USyncLIDProtocol.d.ts +9 -8
  184. package/lib/WAUSync/Protocols/USyncLIDProtocol.js +37 -29
  185. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +2 -2
  186. package/lib/WAUSync/Protocols/index.d.ts +6 -6
  187. package/lib/WAUSync/USyncQuery.d.ts +3 -3
  188. package/lib/WAUSync/index.d.ts +3 -3
  189. package/lib/index.d.ts +13 -13
  190. package/lib/index.js +33 -33
  191. package/package.json +96 -94
  192. package/lib/Socket/registration.d.ts +0 -266
  193. package/lib/Socket/registration.js +0 -166
@@ -0,0 +1,9 @@
1
+ export declare class CiphertextMessage {
2
+ readonly UNSUPPORTED_VERSION: number
3
+ readonly CURRENT_VERSION: number
4
+ readonly WHISPER_TYPE: number
5
+ readonly PREKEY_TYPE: number
6
+ readonly SENDERKEY_TYPE: number
7
+ readonly SENDERKEY_DISTRIBUTION_TYPE: number
8
+ readonly ENCRYPTED_MESSAGE_OVERHEAD: number
9
+ }
@@ -0,0 +1,19 @@
1
+ "use strict"
2
+
3
+ Object.defineProperty(exports, "__esModule", { value: true })
4
+
5
+ class CiphertextMessage {
6
+ constructor() {
7
+ this.UNSUPPORTED_VERSION = 1
8
+ this.CURRENT_VERSION = 3
9
+ this.WHISPER_TYPE = 2
10
+ this.PREKEY_TYPE = 3
11
+ this.SENDERKEY_TYPE = 4
12
+ this.SENDERKEY_DISTRIBUTION_TYPE = 5
13
+ this.ENCRYPTED_MESSAGE_OVERHEAD = 53
14
+ }
15
+ }
16
+
17
+ module.exports = {
18
+ CiphertextMessage
19
+ }
@@ -1,16 +1,16 @@
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
- }
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
16
  module.exports = CiphertextMessage;
@@ -0,0 +1,17 @@
1
+ import { SenderKeyDistributionMessage } from './sender-key-distribution-message'
2
+ import { SenderKeyName } from './sender-key-name'
3
+ import { SenderKeyRecord } from './sender-key-record'
4
+
5
+ interface SenderKeyStore {
6
+ loadSenderKey(senderKeyName: SenderKeyName): Promise<SenderKeyRecord>
7
+ storeSenderKey(senderKeyName: SenderKeyName, record: SenderKeyRecord): Promise<void>
8
+ }
9
+
10
+ export declare class GroupSessionBuilder {
11
+ private readonly senderKeyStore
12
+ constructor(senderKeyStore: SenderKeyStore)
13
+ process(senderKeyName: SenderKeyName, senderKeyDistributionMessage: SenderKeyDistributionMessage): Promise<void>
14
+ create(senderKeyName: SenderKeyName): Promise<SenderKeyDistributionMessage>
15
+ }
16
+
17
+ export {}
@@ -0,0 +1,72 @@
1
+ "use strict"
2
+
3
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
+ if (k2 === undefined) k2 = k
5
+ var desc = Object.getOwnPropertyDescriptor(m, k)
6
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
7
+ desc = { enumerable: true, get: function() { return m[k] } }
8
+ }
9
+ Object.defineProperty(o, k2, desc)
10
+ }) : (function(o, m, k, k2) {
11
+ if (k2 === undefined) k2 = k
12
+ o[k2] = m[k]
13
+ }))
14
+
15
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
16
+ Object.defineProperty(o, "default", { enumerable: true, value: v })
17
+ }) : function(o, v) {
18
+ o["default"] = v
19
+ })
20
+
21
+ var __importStar = (this && this.__importStar) || (function () {
22
+ var ownKeys = function(o) {
23
+ ownKeys = Object.getOwnPropertyNames || function (o) {
24
+ var ar = []
25
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k
26
+ return ar
27
+ }
28
+ return ownKeys(o)
29
+ }
30
+ return function (mod) {
31
+ if (mod && mod.__esModule) return mod
32
+ var result = {}
33
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i])
34
+ __setModuleDefault(result, mod)
35
+ return result
36
+ }
37
+ })()
38
+
39
+ Object.defineProperty(exports, "__esModule", { value: true })
40
+
41
+ const keyhelper = __importStar(require("./keyhelper"))
42
+ const sender_key_distribution_message_1 = require("./sender-key-distribution-message")
43
+
44
+ class GroupSessionBuilder {
45
+ constructor(senderKeyStore) {
46
+ this.senderKeyStore = senderKeyStore
47
+ }
48
+ async process(senderKeyName, senderKeyDistributionMessage) {
49
+ const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName)
50
+ senderKeyRecord.addSenderKeyState(senderKeyDistributionMessage.getId(), senderKeyDistributionMessage.getIteration(), senderKeyDistributionMessage.getChainKey(), senderKeyDistributionMessage.getSignatureKey())
51
+ await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord)
52
+ }
53
+ async create(senderKeyName) {
54
+ const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName)
55
+ if (senderKeyRecord.isEmpty()) {
56
+ const keyId = keyhelper.generateSenderKeyId()
57
+ const senderKey = keyhelper.generateSenderKey()
58
+ const signingKey = keyhelper.generateSenderSigningKey()
59
+ senderKeyRecord.setSenderKeyState(keyId, 0, senderKey, signingKey)
60
+ await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord)
61
+ }
62
+ const state = senderKeyRecord.getSenderKeyState()
63
+ if (!state) {
64
+ throw new Error('No session state available')
65
+ }
66
+ return new sender_key_distribution_message_1.SenderKeyDistributionMessage(state.getKeyId(), state.getSenderChainKey().getIteration(), state.getSenderChainKey().getSeed(), state.getSigningKeyPublic())
67
+ }
68
+ }
69
+
70
+ module.exports = {
71
+ GroupSessionBuilder
72
+ }
@@ -1,42 +1,42 @@
1
- package groupproto;
2
-
3
- message SenderKeyMessage {
4
- optional uint32 id = 1;
5
- optional uint32 iteration = 2;
6
- optional bytes ciphertext = 3;
7
- }
8
-
9
- message SenderKeyDistributionMessage {
10
- optional uint32 id = 1;
11
- optional uint32 iteration = 2;
12
- optional bytes chainKey = 3;
13
- optional bytes signingKey = 4;
14
- }
15
-
16
- message SenderChainKey {
17
- optional uint32 iteration = 1;
18
- optional bytes seed = 2;
19
- }
20
-
21
- message SenderMessageKey {
22
- optional uint32 iteration = 1;
23
- optional bytes seed = 2;
24
- }
25
-
26
- message SenderSigningKey {
27
- optional bytes public = 1;
28
- optional bytes private = 2;
29
- }
30
-
31
- message SenderKeyStateStructure {
32
-
33
-
34
- optional uint32 senderKeyId = 1;
35
- optional SenderChainKey senderChainKey = 2;
36
- optional SenderSigningKey senderSigningKey = 3;
37
- repeated SenderMessageKey senderMessageKeys = 4;
38
- }
39
-
40
- message SenderKeyRecordStructure {
41
- repeated SenderKeyStateStructure senderKeyStates = 1;
1
+ package groupproto;
2
+
3
+ message SenderKeyMessage {
4
+ optional uint32 id = 1;
5
+ optional uint32 iteration = 2;
6
+ optional bytes ciphertext = 3;
7
+ }
8
+
9
+ message SenderKeyDistributionMessage {
10
+ optional uint32 id = 1;
11
+ optional uint32 iteration = 2;
12
+ optional bytes chainKey = 3;
13
+ optional bytes signingKey = 4;
14
+ }
15
+
16
+ message SenderChainKey {
17
+ optional uint32 iteration = 1;
18
+ optional bytes seed = 2;
19
+ }
20
+
21
+ message SenderMessageKey {
22
+ optional uint32 iteration = 1;
23
+ optional bytes seed = 2;
24
+ }
25
+
26
+ message SenderSigningKey {
27
+ optional bytes public = 1;
28
+ optional bytes private = 2;
29
+ }
30
+
31
+ message SenderKeyStateStructure {
32
+
33
+
34
+ optional uint32 senderKeyId = 1;
35
+ optional SenderChainKey senderChainKey = 2;
36
+ optional SenderSigningKey senderSigningKey = 3;
37
+ repeated SenderMessageKey senderMessageKeys = 4;
38
+ }
39
+
40
+ message SenderKeyRecordStructure {
41
+ repeated SenderKeyStateStructure senderKeyStates = 1;
42
42
  }
@@ -0,0 +1,19 @@
1
+ import { SenderKeyName } from './sender-key-name'
2
+ import { SenderKeyRecord } from './sender-key-record'
3
+
4
+ export interface SenderKeyStore {
5
+ loadSenderKey(senderKeyName: SenderKeyName): Promise<SenderKeyRecord>
6
+ storeSenderKey(senderKeyName: SenderKeyName, record: SenderKeyRecord): Promise<void>
7
+ }
8
+
9
+ export declare class GroupCipher {
10
+ private readonly senderKeyStore
11
+ private readonly senderKeyName
12
+ constructor(senderKeyStore: SenderKeyStore, senderKeyName: SenderKeyName)
13
+ private queueJob
14
+ encrypt(paddedPlaintext: Uint8Array | string): Promise<Uint8Array>
15
+ decrypt(senderKeyMessageBytes: Uint8Array): Promise<Uint8Array>
16
+ private getSenderKey
17
+ private getPlainText
18
+ private getCipherText
19
+ }
@@ -1,120 +1,111 @@
1
- const queue_job = require('./queue_job');
2
- const SenderKeyMessage = require('./sender_key_message');
3
- const crypto = require('@neelegirl/libsignal/src/crypto');
1
+ "use strict"
4
2
 
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
- );
3
+ Object.defineProperty(exports, "__esModule", { value: true })
66
4
 
67
- await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
5
+ const crypto_1 = require("@neelegirl/libsignal/src/crypto")
6
+ const sender_key_message_1 = require("./sender-key-message")
68
7
 
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
- );
8
+ class GroupCipher {
9
+ constructor(senderKeyStore, senderKeyName) {
10
+ this.senderKeyStore = senderKeyStore
11
+ this.senderKeyName = senderKeyName
82
12
  }
83
-
84
- if (iteration - senderChainKey.getIteration() > 2000) {
85
- throw new Error('Over 2000 messages into the future!');
13
+ async encrypt(paddedPlaintext) {
14
+ const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName)
15
+
16
+ if (!record) {
17
+ throw new Error('No SenderKeyRecord found for encryption')
18
+ }
19
+
20
+ const senderKeyState = record.getSenderKeyState()
21
+
22
+ if (!senderKeyState) {
23
+ throw new Error('No session to encrypt message')
24
+ }
25
+
26
+ const iteration = senderKeyState.getSenderChainKey().getIteration()
27
+ const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1)
28
+ const ciphertext = await this.getCipherText(senderKey.getIv(), senderKey.getCipherKey(), paddedPlaintext)
29
+ const senderKeyMessage = new sender_key_message_1.SenderKeyMessage(senderKeyState.getKeyId(), senderKey.getIteration(), ciphertext, senderKeyState.getSigningKeyPrivate())
30
+
31
+ await this.senderKeyStore.storeSenderKey(this.senderKeyName, record)
32
+
33
+ return senderKeyMessage.serialize()
86
34
  }
87
-
88
- while (senderChainKey.getIteration() < iteration) {
89
- senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey());
90
- senderChainKey = senderChainKey.getNext();
35
+ async decrypt(senderKeyMessageBytes) {
36
+ const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName)
37
+
38
+ if (!record) {
39
+ throw new Error('No SenderKeyRecord found for decryption')
40
+ }
41
+
42
+ const senderKeyMessage = new sender_key_message_1.SenderKeyMessage(null, null, null, null, senderKeyMessageBytes)
43
+ const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId())
44
+
45
+ if (!senderKeyState) {
46
+ throw new Error('No session found to decrypt message');
47
+ }
48
+
49
+ senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic())
50
+
51
+ const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration())
52
+ const plaintext = await this.getPlainText(senderKey.getIv(), senderKey.getCipherKey(), senderKeyMessage.getCipherText())
53
+
54
+ await this.senderKeyStore.storeSenderKey(this.senderKeyName, record)
55
+
56
+ return plaintext
91
57
  }
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');
58
+ getSenderKey(senderKeyState, iteration) {
59
+ let senderChainKey = senderKeyState.getSenderChainKey()
60
+
61
+ if (senderChainKey.getIteration() > iteration) {
62
+ if (senderKeyState.hasSenderMessageKey(iteration)) {
63
+ const messageKey = senderKeyState.removeSenderMessageKey(iteration)
64
+
65
+ if (!messageKey) {
66
+ throw new Error('No sender message key found for iteration')
67
+ }
68
+
69
+ return messageKey
70
+ }
71
+
72
+ throw new Error(`Received message with old counter: ${senderChainKey.getIteration()}, ${iteration}`)
73
+ }
74
+
75
+ if (iteration - senderChainKey.getIteration() > 2000) {
76
+ throw new Error('Over 2000 messages into the future!');
77
+ }
78
+
79
+ while (senderChainKey.getIteration() < iteration) {
80
+ senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey())
81
+ senderChainKey = senderChainKey.getNext()
82
+ }
83
+
84
+ senderKeyState.setSenderChainKey(senderChainKey.getNext())
85
+
86
+ return senderChainKey.getSenderMessageKey()
104
87
  }
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');
88
+ async getPlainText(iv, key, ciphertext) {
89
+ try {
90
+ return crypto_1.decrypt(key, ciphertext, iv)
91
+ }
92
+ catch (e) {
93
+ throw new Error('InvalidMessageException')
94
+ }
95
+ }
96
+ async getCipherText(iv, key, plaintext) {
97
+ try {
98
+ const ivBuffer = typeof iv === 'string' ? Buffer.from(iv, 'base64') : iv
99
+ const keyBuffer = typeof key === 'string' ? Buffer.from(key, 'base64') : key
100
+ const plaintextBuffer = typeof plaintext === 'string' ? Buffer.from(plaintext) : plaintext
101
+ return crypto_1.encrypt(keyBuffer, plaintextBuffer, ivBuffer)
102
+ }
103
+ catch (e) {
104
+ throw new Error('InvalidMessageException')
105
+ }
116
106
  }
117
- }
118
107
  }
119
108
 
120
- module.exports = GroupCipher;
109
+ module.exports = {
110
+ GroupCipher
111
+ }
@@ -1,46 +1,46 @@
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
- }
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
46
  module.exports = GroupSessionBuilder;
@@ -0,0 +1,11 @@
1
+ export { GroupSessionBuilder } from './group-session-builder'
2
+ export { SenderKeyDistributionMessage } from './sender-key-distribution-message'
3
+ export { SenderKeyRecord } from './sender-key-record'
4
+ export { SenderKeyName } from './sender-key-name'
5
+ export { GroupCipher } from './group_cipher'
6
+ export { SenderKeyState } from './sender-key-state'
7
+ export { SenderKeyMessage } from './sender-key-message'
8
+ export { SenderMessageKey } from './sender-message-key'
9
+ export { SenderChainKey } from './sender-chain-key'
10
+ export { CiphertextMessage } from './ciphertext-message'
11
+ export * as keyhelper from './keyhelper'
@@ -1,6 +1,61 @@
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')
6
- // signal fixed
1
+ "use strict"
2
+
3
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
+ if (k2 === undefined) k2 = k
5
+ var desc = Object.getOwnPropertyDescriptor(m, k)
6
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
7
+ desc = { enumerable: true, get: function() { return m[k] } }
8
+ }
9
+ Object.defineProperty(o, k2, desc)
10
+ }) : (function(o, m, k, k2) {
11
+ if (k2 === undefined) k2 = k
12
+ o[k2] = m[k]
13
+ }))
14
+
15
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
16
+ Object.defineProperty(o, "default", { enumerable: true, value: v })
17
+ }) : function(o, v) {
18
+ o["default"] = v
19
+ })
20
+
21
+ var __importStar = (this && this.__importStar) || (function () {
22
+ var ownKeys = function(o) {
23
+ ownKeys = Object.getOwnPropertyNames || function (o) {
24
+ var ar = []
25
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k
26
+ return ar
27
+ }
28
+ return ownKeys(o)
29
+ }
30
+ return function (mod) {
31
+ if (mod && mod.__esModule) return mod
32
+ var result = {}
33
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i])
34
+ __setModuleDefault(result, mod)
35
+ return result
36
+ }
37
+ })()
38
+
39
+ Object.defineProperty(exports, "__esModule", { value: true })
40
+ exports.keyhelper = exports.CiphertextMessage = exports.SenderChainKey = exports.SenderMessageKey = exports.SenderKeyMessage = exports.SenderKeyState = exports.GroupCipher = exports.SenderKeyName = exports.SenderKeyRecord = exports.SenderKeyDistributionMessage = exports.GroupSessionBuilder = void 0
41
+ var group_session_builder_1 = require("./group-session-builder")
42
+ Object.defineProperty(exports, "GroupSessionBuilder", { enumerable: true, get: function () { return group_session_builder_1.GroupSessionBuilder } })
43
+ var sender_key_distribution_message_1 = require("./sender-key-distribution-message")
44
+ Object.defineProperty(exports, "SenderKeyDistributionMessage", { enumerable: true, get: function () { return sender_key_distribution_message_1.SenderKeyDistributionMessage } })
45
+ var sender_key_record_1 = require("./sender-key-record")
46
+ Object.defineProperty(exports, "SenderKeyRecord", { enumerable: true, get: function () { return sender_key_record_1.SenderKeyRecord } })
47
+ var sender_key_name_1 = require("./sender-key-name")
48
+ Object.defineProperty(exports, "SenderKeyName", { enumerable: true, get: function () { return sender_key_name_1.SenderKeyName } })
49
+ var group_cipher_1 = require("./group_cipher")
50
+ Object.defineProperty(exports, "GroupCipher", { enumerable: true, get: function () { return group_cipher_1.GroupCipher } })
51
+ var sender_key_state_1 = require("./sender-key-state")
52
+ Object.defineProperty(exports, "SenderKeyState", { enumerable: true, get: function () { return sender_key_state_1.SenderKeyState } })
53
+ var sender_key_message_1 = require("./sender-key-message")
54
+ Object.defineProperty(exports, "SenderKeyMessage", { enumerable: true, get: function () { return sender_key_message_1.SenderKeyMessage } })
55
+ var sender_message_key_1 = require("./sender-message-key")
56
+ Object.defineProperty(exports, "SenderMessageKey", { enumerable: true, get: function () { return sender_message_key_1.SenderMessageKey } })
57
+ var sender_chain_key_1 = require("./sender-chain-key")
58
+ Object.defineProperty(exports, "SenderChainKey", { enumerable: true, get: function () { return sender_chain_key_1.SenderChainKey } })
59
+ var ciphertext_message_1 = require("./ciphertext-message")
60
+ Object.defineProperty(exports, "CiphertextMessage", { enumerable: true, get: function () { return ciphertext_message_1.CiphertextMessage } })
61
+ exports.keyhelper = __importStar(require("./keyhelper"))