@queenanya/baileys 6.7.0 → 6.8.0
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.
- package/WASignalGroup/readme.md +6 -0
- package/lib/Defaults/baileys-version.json +3 -3
- package/lib/Defaults/index.d.ts +284 -284
- package/lib/Defaults/index.js +120 -120
- package/lib/Defaults/phonenumber-mcc.json +223 -223
- package/lib/Signal/libsignal.d.ts +3 -3
- package/lib/Signal/libsignal.js +152 -152
- package/lib/Socket/Client/abstract-socket-client.d.ts +17 -17
- package/lib/Socket/Client/abstract-socket-client.js +13 -13
- package/lib/Socket/Client/index.d.ts +3 -3
- package/lib/Socket/Client/index.js +19 -19
- package/lib/Socket/Client/mobile-socket-client.d.ts +13 -13
- package/lib/Socket/Client/mobile-socket-client.js +65 -65
- package/lib/Socket/Client/web-socket-client.d.ts +12 -12
- package/lib/Socket/Client/web-socket-client.js +62 -62
- package/lib/Socket/business.d.ts +135 -135
- package/lib/Socket/business.js +259 -259
- package/lib/Socket/chats.d.ts +79 -79
- package/lib/Socket/chats.js +854 -854
- package/lib/Socket/groups.d.ts +113 -113
- package/lib/Socket/groups.js +302 -302
- package/lib/Socket/index.d.ts +137 -137
- package/lib/Socket/index.js +10 -10
- package/lib/Socket/messages-recv.d.ts +124 -124
- package/lib/Socket/messages-recv.js +747 -747
- package/lib/Socket/messages-send.d.ts +119 -119
- package/lib/Socket/messages-send.js +663 -663
- package/lib/Socket/registration.d.ts +232 -232
- package/lib/Socket/registration.js +166 -166
- package/lib/Socket/socket.d.ts +42 -42
- package/lib/Socket/socket.js +588 -588
- package/lib/Store/index.d.ts +3 -3
- package/lib/Store/index.js +10 -10
- package/lib/Store/make-cache-manager-store.d.ts +13 -13
- package/lib/Store/make-cache-manager-store.js +83 -83
- package/lib/Store/make-in-memory-store.d.ts +117 -117
- package/lib/Store/make-in-memory-store.js +437 -437
- package/lib/Store/make-ordered-dictionary.d.ts +13 -13
- package/lib/Store/make-ordered-dictionary.js +81 -81
- package/lib/Store/object-repository.d.ts +10 -10
- package/lib/Store/object-repository.js +27 -27
- package/lib/Types/Auth.d.ts +108 -108
- package/lib/Types/Auth.js +2 -2
- package/lib/Types/Call.d.ts +13 -13
- package/lib/Types/Call.js +2 -2
- package/lib/Types/Chat.d.ts +102 -102
- package/lib/Types/Chat.js +4 -4
- package/lib/Types/Contact.d.ts +19 -19
- package/lib/Types/Contact.js +2 -2
- package/lib/Types/Events.d.ts +157 -157
- package/lib/Types/Events.js +2 -2
- package/lib/Types/GroupMetadata.d.ts +52 -52
- package/lib/Types/GroupMetadata.js +2 -2
- package/lib/Types/Label.d.ts +35 -35
- package/lib/Types/Label.js +27 -27
- package/lib/Types/LabelAssociation.d.ts +29 -29
- package/lib/Types/LabelAssociation.js +9 -9
- package/lib/Types/Message.d.ts +261 -261
- package/lib/Types/Message.js +9 -9
- package/lib/Types/Product.d.ts +78 -78
- package/lib/Types/Product.js +2 -2
- package/lib/Types/Signal.d.ts +57 -57
- package/lib/Types/Signal.js +2 -2
- package/lib/Types/Socket.d.ts +111 -111
- package/lib/Types/Socket.js +2 -2
- package/lib/Types/State.d.ts +27 -27
- package/lib/Types/State.js +2 -2
- package/lib/Types/index.d.ts +56 -56
- package/lib/Types/index.js +41 -41
- package/lib/Utils/auth-utils.d.ts +18 -18
- package/lib/Utils/auth-utils.js +204 -204
- package/lib/Utils/baileys-event-stream.d.ts +16 -16
- package/lib/Utils/baileys-event-stream.js +63 -63
- package/lib/Utils/business.d.ts +22 -22
- package/lib/Utils/business.js +234 -234
- package/lib/Utils/chat-utils.d.ts +71 -71
- package/lib/Utils/chat-utils.js +724 -724
- package/lib/Utils/crypto.d.ts +41 -41
- package/lib/Utils/crypto.js +151 -151
- package/lib/Utils/decode-wa-message.d.ts +19 -19
- package/lib/Utils/decode-wa-message.js +174 -174
- package/lib/Utils/event-buffer.d.ts +35 -35
- package/lib/Utils/event-buffer.js +514 -514
- package/lib/Utils/generics.d.ts +94 -94
- package/lib/Utils/generics.js +367 -367
- package/lib/Utils/history.d.ts +15 -15
- package/lib/Utils/history.js +91 -91
- package/lib/Utils/index.d.ts +17 -17
- package/lib/Utils/index.js +33 -33
- package/lib/Utils/link-preview.d.ts +21 -21
- package/lib/Utils/link-preview.js +93 -93
- package/lib/Utils/logger.d.ts +4 -4
- package/lib/Utils/logger.js +7 -7
- package/lib/Utils/lt-hash.d.ts +12 -12
- package/lib/Utils/lt-hash.js +51 -51
- package/lib/Utils/make-mutex.d.ts +7 -7
- package/lib/Utils/make-mutex.js +43 -43
- package/lib/Utils/messages-media.d.ts +107 -107
- package/lib/Utils/messages-media.js +680 -680
- package/lib/Utils/messages.d.ts +76 -76
- package/lib/Utils/messages.js +768 -768
- package/lib/Utils/noise-handler.d.ts +20 -20
- package/lib/Utils/noise-handler.js +142 -142
- package/lib/Utils/process-message.d.ts +41 -41
- package/lib/Utils/process-message.js +320 -320
- package/lib/Utils/signal.d.ts +32 -32
- package/lib/Utils/signal.js +151 -151
- package/lib/Utils/use-multi-file-auth-state.d.ts +12 -12
- package/lib/Utils/use-multi-file-auth-state.js +80 -80
- package/lib/Utils/validate-connection.d.ts +11 -11
- package/lib/Utils/validate-connection.js +191 -222
- package/lib/WABinary/constants.d.ts +27 -27
- package/lib/WABinary/constants.js +40 -40
- package/lib/WABinary/decode.d.ts +7 -7
- package/lib/WABinary/decode.js +252 -252
- package/lib/WABinary/encode.d.ts +3 -3
- package/lib/WABinary/encode.js +228 -228
- package/lib/WABinary/generic-utils.d.ts +15 -15
- package/lib/WABinary/generic-utils.js +110 -110
- package/lib/WABinary/index.d.ts +5 -5
- package/lib/WABinary/index.js +21 -21
- package/lib/WABinary/jid-utils.d.ts +29 -29
- package/lib/WABinary/jid-utils.js +59 -59
- package/lib/WABinary/types.d.ts +18 -18
- package/lib/WABinary/types.js +2 -2
- package/lib/index.d.ts +10 -10
- package/lib/index.js +29 -29
- package/package.json +1 -1
- package/CHANGELOG.md +0 -4
package/lib/Types/index.d.ts
CHANGED
|
@@ -1,56 +1,56 @@
|
|
|
1
|
-
export * from './Auth';
|
|
2
|
-
export * from './GroupMetadata';
|
|
3
|
-
export * from './Chat';
|
|
4
|
-
export * from './Contact';
|
|
5
|
-
export * from './State';
|
|
6
|
-
export * from './Message';
|
|
7
|
-
export * from './Socket';
|
|
8
|
-
export * from './Events';
|
|
9
|
-
export * from './Product';
|
|
10
|
-
export * from './Call';
|
|
11
|
-
export * from './Signal';
|
|
12
|
-
import { AuthenticationState } from './Auth';
|
|
13
|
-
import { SocketConfig } from './Socket';
|
|
14
|
-
export type UserFacingSocketConfig = Partial<SocketConfig> & {
|
|
15
|
-
auth: AuthenticationState;
|
|
16
|
-
};
|
|
17
|
-
export declare enum DisconnectReason {
|
|
18
|
-
connectionClosed = 428,
|
|
19
|
-
connectionLost = 408,
|
|
20
|
-
connectionReplaced = 440,
|
|
21
|
-
timedOut = 408,
|
|
22
|
-
loggedOut = 401,
|
|
23
|
-
badSession = 500,
|
|
24
|
-
restartRequired = 515,
|
|
25
|
-
multideviceMismatch = 411,
|
|
26
|
-
forbidden = 403,
|
|
27
|
-
unavailableService = 503
|
|
28
|
-
}
|
|
29
|
-
export type WAInitResponse = {
|
|
30
|
-
ref: string;
|
|
31
|
-
ttl: number;
|
|
32
|
-
status: 200;
|
|
33
|
-
};
|
|
34
|
-
export type WABusinessHoursConfig = {
|
|
35
|
-
day_of_week: string;
|
|
36
|
-
mode: string;
|
|
37
|
-
open_time?: number;
|
|
38
|
-
close_time?: number;
|
|
39
|
-
};
|
|
40
|
-
export type WABusinessProfile = {
|
|
41
|
-
description: string;
|
|
42
|
-
email: string | undefined;
|
|
43
|
-
business_hours: {
|
|
44
|
-
timezone?: string;
|
|
45
|
-
config?: WABusinessHoursConfig[];
|
|
46
|
-
business_config?: WABusinessHoursConfig[];
|
|
47
|
-
};
|
|
48
|
-
website: string[];
|
|
49
|
-
category?: string;
|
|
50
|
-
wid?: string;
|
|
51
|
-
address?: string;
|
|
52
|
-
};
|
|
53
|
-
export type CurveKeyPair = {
|
|
54
|
-
private: Uint8Array;
|
|
55
|
-
public: Uint8Array;
|
|
56
|
-
};
|
|
1
|
+
export * from './Auth';
|
|
2
|
+
export * from './GroupMetadata';
|
|
3
|
+
export * from './Chat';
|
|
4
|
+
export * from './Contact';
|
|
5
|
+
export * from './State';
|
|
6
|
+
export * from './Message';
|
|
7
|
+
export * from './Socket';
|
|
8
|
+
export * from './Events';
|
|
9
|
+
export * from './Product';
|
|
10
|
+
export * from './Call';
|
|
11
|
+
export * from './Signal';
|
|
12
|
+
import { AuthenticationState } from './Auth';
|
|
13
|
+
import { SocketConfig } from './Socket';
|
|
14
|
+
export type UserFacingSocketConfig = Partial<SocketConfig> & {
|
|
15
|
+
auth: AuthenticationState;
|
|
16
|
+
};
|
|
17
|
+
export declare enum DisconnectReason {
|
|
18
|
+
connectionClosed = 428,
|
|
19
|
+
connectionLost = 408,
|
|
20
|
+
connectionReplaced = 440,
|
|
21
|
+
timedOut = 408,
|
|
22
|
+
loggedOut = 401,
|
|
23
|
+
badSession = 500,
|
|
24
|
+
restartRequired = 515,
|
|
25
|
+
multideviceMismatch = 411,
|
|
26
|
+
forbidden = 403,
|
|
27
|
+
unavailableService = 503
|
|
28
|
+
}
|
|
29
|
+
export type WAInitResponse = {
|
|
30
|
+
ref: string;
|
|
31
|
+
ttl: number;
|
|
32
|
+
status: 200;
|
|
33
|
+
};
|
|
34
|
+
export type WABusinessHoursConfig = {
|
|
35
|
+
day_of_week: string;
|
|
36
|
+
mode: string;
|
|
37
|
+
open_time?: number;
|
|
38
|
+
close_time?: number;
|
|
39
|
+
};
|
|
40
|
+
export type WABusinessProfile = {
|
|
41
|
+
description: string;
|
|
42
|
+
email: string | undefined;
|
|
43
|
+
business_hours: {
|
|
44
|
+
timezone?: string;
|
|
45
|
+
config?: WABusinessHoursConfig[];
|
|
46
|
+
business_config?: WABusinessHoursConfig[];
|
|
47
|
+
};
|
|
48
|
+
website: string[];
|
|
49
|
+
category?: string;
|
|
50
|
+
wid?: string;
|
|
51
|
+
address?: string;
|
|
52
|
+
};
|
|
53
|
+
export type CurveKeyPair = {
|
|
54
|
+
private: Uint8Array;
|
|
55
|
+
public: Uint8Array;
|
|
56
|
+
};
|
package/lib/Types/index.js
CHANGED
|
@@ -1,41 +1,41 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.DisconnectReason = void 0;
|
|
18
|
-
__exportStar(require("./Auth"), exports);
|
|
19
|
-
__exportStar(require("./GroupMetadata"), exports);
|
|
20
|
-
__exportStar(require("./Chat"), exports);
|
|
21
|
-
__exportStar(require("./Contact"), exports);
|
|
22
|
-
__exportStar(require("./State"), exports);
|
|
23
|
-
__exportStar(require("./Message"), exports);
|
|
24
|
-
__exportStar(require("./Socket"), exports);
|
|
25
|
-
__exportStar(require("./Events"), exports);
|
|
26
|
-
__exportStar(require("./Product"), exports);
|
|
27
|
-
__exportStar(require("./Call"), exports);
|
|
28
|
-
__exportStar(require("./Signal"), exports);
|
|
29
|
-
var DisconnectReason;
|
|
30
|
-
(function (DisconnectReason) {
|
|
31
|
-
DisconnectReason[DisconnectReason["connectionClosed"] = 428] = "connectionClosed";
|
|
32
|
-
DisconnectReason[DisconnectReason["connectionLost"] = 408] = "connectionLost";
|
|
33
|
-
DisconnectReason[DisconnectReason["connectionReplaced"] = 440] = "connectionReplaced";
|
|
34
|
-
DisconnectReason[DisconnectReason["timedOut"] = 408] = "timedOut";
|
|
35
|
-
DisconnectReason[DisconnectReason["loggedOut"] = 401] = "loggedOut";
|
|
36
|
-
DisconnectReason[DisconnectReason["badSession"] = 500] = "badSession";
|
|
37
|
-
DisconnectReason[DisconnectReason["restartRequired"] = 515] = "restartRequired";
|
|
38
|
-
DisconnectReason[DisconnectReason["multideviceMismatch"] = 411] = "multideviceMismatch";
|
|
39
|
-
DisconnectReason[DisconnectReason["forbidden"] = 403] = "forbidden";
|
|
40
|
-
DisconnectReason[DisconnectReason["unavailableService"] = 503] = "unavailableService";
|
|
41
|
-
})(DisconnectReason = exports.DisconnectReason || (exports.DisconnectReason = {}));
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.DisconnectReason = void 0;
|
|
18
|
+
__exportStar(require("./Auth"), exports);
|
|
19
|
+
__exportStar(require("./GroupMetadata"), exports);
|
|
20
|
+
__exportStar(require("./Chat"), exports);
|
|
21
|
+
__exportStar(require("./Contact"), exports);
|
|
22
|
+
__exportStar(require("./State"), exports);
|
|
23
|
+
__exportStar(require("./Message"), exports);
|
|
24
|
+
__exportStar(require("./Socket"), exports);
|
|
25
|
+
__exportStar(require("./Events"), exports);
|
|
26
|
+
__exportStar(require("./Product"), exports);
|
|
27
|
+
__exportStar(require("./Call"), exports);
|
|
28
|
+
__exportStar(require("./Signal"), exports);
|
|
29
|
+
var DisconnectReason;
|
|
30
|
+
(function (DisconnectReason) {
|
|
31
|
+
DisconnectReason[DisconnectReason["connectionClosed"] = 428] = "connectionClosed";
|
|
32
|
+
DisconnectReason[DisconnectReason["connectionLost"] = 408] = "connectionLost";
|
|
33
|
+
DisconnectReason[DisconnectReason["connectionReplaced"] = 440] = "connectionReplaced";
|
|
34
|
+
DisconnectReason[DisconnectReason["timedOut"] = 408] = "timedOut";
|
|
35
|
+
DisconnectReason[DisconnectReason["loggedOut"] = 401] = "loggedOut";
|
|
36
|
+
DisconnectReason[DisconnectReason["badSession"] = 500] = "badSession";
|
|
37
|
+
DisconnectReason[DisconnectReason["restartRequired"] = 515] = "restartRequired";
|
|
38
|
+
DisconnectReason[DisconnectReason["multideviceMismatch"] = 411] = "multideviceMismatch";
|
|
39
|
+
DisconnectReason[DisconnectReason["forbidden"] = 403] = "forbidden";
|
|
40
|
+
DisconnectReason[DisconnectReason["unavailableService"] = 503] = "unavailableService";
|
|
41
|
+
})(DisconnectReason = exports.DisconnectReason || (exports.DisconnectReason = {}));
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
import type { Logger } from 'pino';
|
|
2
|
-
import type { AuthenticationCreds, CacheStore, SignalKeyStore, SignalKeyStoreWithTransaction, TransactionCapabilityOptions } from '../Types';
|
|
3
|
-
/**
|
|
4
|
-
* Adds caching capability to a SignalKeyStore
|
|
5
|
-
* @param store the store to add caching to
|
|
6
|
-
* @param logger to log trace events
|
|
7
|
-
* @param _cache cache store to use
|
|
8
|
-
*/
|
|
9
|
-
export declare function makeCacheableSignalKeyStore(store: SignalKeyStore, logger: Logger, _cache?: CacheStore): SignalKeyStore;
|
|
10
|
-
/**
|
|
11
|
-
* Adds DB like transaction capability (https://en.wikipedia.org/wiki/Database_transaction) to the SignalKeyStore,
|
|
12
|
-
* this allows batch read & write operations & improves the performance of the lib
|
|
13
|
-
* @param state the key store to apply this capability to
|
|
14
|
-
* @param logger logger to log events
|
|
15
|
-
* @returns SignalKeyStore with transaction capability
|
|
16
|
-
*/
|
|
17
|
-
export declare const addTransactionCapability: (state: SignalKeyStore, logger: Logger, { maxCommitRetries, delayBetweenTriesMs }: TransactionCapabilityOptions) => SignalKeyStoreWithTransaction;
|
|
18
|
-
export declare const initAuthCreds: () => AuthenticationCreds;
|
|
1
|
+
import type { Logger } from 'pino';
|
|
2
|
+
import type { AuthenticationCreds, CacheStore, SignalKeyStore, SignalKeyStoreWithTransaction, TransactionCapabilityOptions } from '../Types';
|
|
3
|
+
/**
|
|
4
|
+
* Adds caching capability to a SignalKeyStore
|
|
5
|
+
* @param store the store to add caching to
|
|
6
|
+
* @param logger to log trace events
|
|
7
|
+
* @param _cache cache store to use
|
|
8
|
+
*/
|
|
9
|
+
export declare function makeCacheableSignalKeyStore(store: SignalKeyStore, logger: Logger, _cache?: CacheStore): SignalKeyStore;
|
|
10
|
+
/**
|
|
11
|
+
* Adds DB like transaction capability (https://en.wikipedia.org/wiki/Database_transaction) to the SignalKeyStore,
|
|
12
|
+
* this allows batch read & write operations & improves the performance of the lib
|
|
13
|
+
* @param state the key store to apply this capability to
|
|
14
|
+
* @param logger logger to log events
|
|
15
|
+
* @returns SignalKeyStore with transaction capability
|
|
16
|
+
*/
|
|
17
|
+
export declare const addTransactionCapability: (state: SignalKeyStore, logger: Logger, { maxCommitRetries, delayBetweenTriesMs }: TransactionCapabilityOptions) => SignalKeyStoreWithTransaction;
|
|
18
|
+
export declare const initAuthCreds: () => AuthenticationCreds;
|
package/lib/Utils/auth-utils.js
CHANGED
|
@@ -1,204 +1,204 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.initAuthCreds = exports.addTransactionCapability = exports.makeCacheableSignalKeyStore = void 0;
|
|
7
|
-
const crypto_1 = require("crypto");
|
|
8
|
-
const node_cache_1 = __importDefault(require("node-cache"));
|
|
9
|
-
const uuid_1 = require("uuid");
|
|
10
|
-
const Defaults_1 = require("../Defaults");
|
|
11
|
-
const crypto_2 = require("./crypto");
|
|
12
|
-
const generics_1 = require("./generics");
|
|
13
|
-
/**
|
|
14
|
-
* Adds caching capability to a SignalKeyStore
|
|
15
|
-
* @param store the store to add caching to
|
|
16
|
-
* @param logger to log trace events
|
|
17
|
-
* @param _cache cache store to use
|
|
18
|
-
*/
|
|
19
|
-
function makeCacheableSignalKeyStore(store, logger, _cache) {
|
|
20
|
-
const cache = _cache || new node_cache_1.default({
|
|
21
|
-
stdTTL: Defaults_1.DEFAULT_CACHE_TTLS.SIGNAL_STORE,
|
|
22
|
-
useClones: false,
|
|
23
|
-
deleteOnExpire: true,
|
|
24
|
-
});
|
|
25
|
-
function getUniqueId(type, id) {
|
|
26
|
-
return `${type}.${id}`;
|
|
27
|
-
}
|
|
28
|
-
return {
|
|
29
|
-
async get(type, ids) {
|
|
30
|
-
const data = {};
|
|
31
|
-
const idsToFetch = [];
|
|
32
|
-
for (const id of ids) {
|
|
33
|
-
const item = cache.get(getUniqueId(type, id));
|
|
34
|
-
if (typeof item !== 'undefined') {
|
|
35
|
-
data[id] = item;
|
|
36
|
-
}
|
|
37
|
-
else {
|
|
38
|
-
idsToFetch.push(id);
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
if (idsToFetch.length) {
|
|
42
|
-
logger.trace({ items: idsToFetch.length }, 'loading from store');
|
|
43
|
-
const fetched = await store.get(type, idsToFetch);
|
|
44
|
-
for (const id of idsToFetch) {
|
|
45
|
-
const item = fetched[id];
|
|
46
|
-
if (item) {
|
|
47
|
-
data[id] = item;
|
|
48
|
-
cache.set(getUniqueId(type, id), item);
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
return data;
|
|
53
|
-
},
|
|
54
|
-
async set(data) {
|
|
55
|
-
let keys = 0;
|
|
56
|
-
for (const type in data) {
|
|
57
|
-
for (const id in data[type]) {
|
|
58
|
-
cache.set(getUniqueId(type, id), data[type][id]);
|
|
59
|
-
keys += 1;
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
logger.trace({ keys }, 'updated cache');
|
|
63
|
-
await store.set(data);
|
|
64
|
-
},
|
|
65
|
-
async clear() {
|
|
66
|
-
var _a;
|
|
67
|
-
cache.flushAll();
|
|
68
|
-
await ((_a = store.clear) === null || _a === void 0 ? void 0 : _a.call(store));
|
|
69
|
-
}
|
|
70
|
-
};
|
|
71
|
-
}
|
|
72
|
-
exports.makeCacheableSignalKeyStore = makeCacheableSignalKeyStore;
|
|
73
|
-
/**
|
|
74
|
-
* Adds DB like transaction capability (https://en.wikipedia.org/wiki/Database_transaction) to the SignalKeyStore,
|
|
75
|
-
* this allows batch read & write operations & improves the performance of the lib
|
|
76
|
-
* @param state the key store to apply this capability to
|
|
77
|
-
* @param logger logger to log events
|
|
78
|
-
* @returns SignalKeyStore with transaction capability
|
|
79
|
-
*/
|
|
80
|
-
const addTransactionCapability = (state, logger, { maxCommitRetries, delayBetweenTriesMs }) => {
|
|
81
|
-
// number of queries made to the DB during the transaction
|
|
82
|
-
// only there for logging purposes
|
|
83
|
-
let dbQueriesInTransaction = 0;
|
|
84
|
-
let transactionCache = {};
|
|
85
|
-
let mutations = {};
|
|
86
|
-
let transactionsInProgress = 0;
|
|
87
|
-
return {
|
|
88
|
-
get: async (type, ids) => {
|
|
89
|
-
if (isInTransaction()) {
|
|
90
|
-
const dict = transactionCache[type];
|
|
91
|
-
const idsRequiringFetch = dict
|
|
92
|
-
? ids.filter(item => typeof dict[item] === 'undefined')
|
|
93
|
-
: ids;
|
|
94
|
-
// only fetch if there are any items to fetch
|
|
95
|
-
if (idsRequiringFetch.length) {
|
|
96
|
-
dbQueriesInTransaction += 1;
|
|
97
|
-
const result = await state.get(type, idsRequiringFetch);
|
|
98
|
-
transactionCache[type] || (transactionCache[type] = {});
|
|
99
|
-
Object.assign(transactionCache[type], result);
|
|
100
|
-
}
|
|
101
|
-
return ids.reduce((dict, id) => {
|
|
102
|
-
var _a;
|
|
103
|
-
const value = (_a = transactionCache[type]) === null || _a === void 0 ? void 0 : _a[id];
|
|
104
|
-
if (value) {
|
|
105
|
-
dict[id] = value;
|
|
106
|
-
}
|
|
107
|
-
return dict;
|
|
108
|
-
}, {});
|
|
109
|
-
}
|
|
110
|
-
else {
|
|
111
|
-
return state.get(type, ids);
|
|
112
|
-
}
|
|
113
|
-
},
|
|
114
|
-
set: data => {
|
|
115
|
-
if (isInTransaction()) {
|
|
116
|
-
logger.trace({ types: Object.keys(data) }, 'caching in transaction');
|
|
117
|
-
for (const key in data) {
|
|
118
|
-
transactionCache[key] = transactionCache[key] || {};
|
|
119
|
-
Object.assign(transactionCache[key], data[key]);
|
|
120
|
-
mutations[key] = mutations[key] || {};
|
|
121
|
-
Object.assign(mutations[key], data[key]);
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
else {
|
|
125
|
-
return state.set(data);
|
|
126
|
-
}
|
|
127
|
-
},
|
|
128
|
-
isInTransaction,
|
|
129
|
-
async transaction(work) {
|
|
130
|
-
let result;
|
|
131
|
-
transactionsInProgress += 1;
|
|
132
|
-
if (transactionsInProgress === 1) {
|
|
133
|
-
logger.trace('entering transaction');
|
|
134
|
-
}
|
|
135
|
-
try {
|
|
136
|
-
result = await work();
|
|
137
|
-
// commit if this is the outermost transaction
|
|
138
|
-
if (transactionsInProgress === 1) {
|
|
139
|
-
if (Object.keys(mutations).length) {
|
|
140
|
-
logger.trace('committing transaction');
|
|
141
|
-
// retry mechanism to ensure we've some recovery
|
|
142
|
-
// in case a transaction fails in the first attempt
|
|
143
|
-
let tries = maxCommitRetries;
|
|
144
|
-
while (tries) {
|
|
145
|
-
tries -= 1;
|
|
146
|
-
try {
|
|
147
|
-
await state.set(mutations);
|
|
148
|
-
logger.trace({ dbQueriesInTransaction }, 'committed transaction');
|
|
149
|
-
break;
|
|
150
|
-
}
|
|
151
|
-
catch (error) {
|
|
152
|
-
logger.warn(`failed to commit ${Object.keys(mutations).length} mutations, tries left=${tries}`);
|
|
153
|
-
await (0, generics_1.delay)(delayBetweenTriesMs);
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
else {
|
|
158
|
-
logger.trace('no mutations in transaction');
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
finally {
|
|
163
|
-
transactionsInProgress -= 1;
|
|
164
|
-
if (transactionsInProgress === 0) {
|
|
165
|
-
transactionCache = {};
|
|
166
|
-
mutations = {};
|
|
167
|
-
dbQueriesInTransaction = 0;
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
return result;
|
|
171
|
-
}
|
|
172
|
-
};
|
|
173
|
-
function isInTransaction() {
|
|
174
|
-
return transactionsInProgress > 0;
|
|
175
|
-
}
|
|
176
|
-
};
|
|
177
|
-
exports.addTransactionCapability = addTransactionCapability;
|
|
178
|
-
const initAuthCreds = () => {
|
|
179
|
-
const identityKey = crypto_2.Curve.generateKeyPair();
|
|
180
|
-
return {
|
|
181
|
-
noiseKey: crypto_2.Curve.generateKeyPair(),
|
|
182
|
-
pairingEphemeralKeyPair: crypto_2.Curve.generateKeyPair(),
|
|
183
|
-
signedIdentityKey: identityKey,
|
|
184
|
-
signedPreKey: (0, crypto_2.signedKeyPair)(identityKey, 1),
|
|
185
|
-
registrationId: (0, generics_1.generateRegistrationId)(),
|
|
186
|
-
advSecretKey: (0, crypto_1.randomBytes)(32).toString('base64'),
|
|
187
|
-
processedHistoryMessages: [],
|
|
188
|
-
nextPreKeyId: 1,
|
|
189
|
-
firstUnuploadedPreKeyId: 1,
|
|
190
|
-
accountSyncCounter: 0,
|
|
191
|
-
accountSettings: {
|
|
192
|
-
unarchiveChats: false
|
|
193
|
-
},
|
|
194
|
-
// mobile creds
|
|
195
|
-
deviceId: Buffer.from((0, uuid_1.v4)().replace(/-/g, ''), 'hex').toString('base64url'),
|
|
196
|
-
phoneId: (0, uuid_1.v4)(),
|
|
197
|
-
identityId: (0, crypto_1.randomBytes)(20),
|
|
198
|
-
registered: false,
|
|
199
|
-
backupToken: (0, crypto_1.randomBytes)(20),
|
|
200
|
-
registration: {},
|
|
201
|
-
pairingCode: undefined,
|
|
202
|
-
};
|
|
203
|
-
};
|
|
204
|
-
exports.initAuthCreds = initAuthCreds;
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.initAuthCreds = exports.addTransactionCapability = exports.makeCacheableSignalKeyStore = void 0;
|
|
7
|
+
const crypto_1 = require("crypto");
|
|
8
|
+
const node_cache_1 = __importDefault(require("node-cache"));
|
|
9
|
+
const uuid_1 = require("uuid");
|
|
10
|
+
const Defaults_1 = require("../Defaults");
|
|
11
|
+
const crypto_2 = require("./crypto");
|
|
12
|
+
const generics_1 = require("./generics");
|
|
13
|
+
/**
|
|
14
|
+
* Adds caching capability to a SignalKeyStore
|
|
15
|
+
* @param store the store to add caching to
|
|
16
|
+
* @param logger to log trace events
|
|
17
|
+
* @param _cache cache store to use
|
|
18
|
+
*/
|
|
19
|
+
function makeCacheableSignalKeyStore(store, logger, _cache) {
|
|
20
|
+
const cache = _cache || new node_cache_1.default({
|
|
21
|
+
stdTTL: Defaults_1.DEFAULT_CACHE_TTLS.SIGNAL_STORE,
|
|
22
|
+
useClones: false,
|
|
23
|
+
deleteOnExpire: true,
|
|
24
|
+
});
|
|
25
|
+
function getUniqueId(type, id) {
|
|
26
|
+
return `${type}.${id}`;
|
|
27
|
+
}
|
|
28
|
+
return {
|
|
29
|
+
async get(type, ids) {
|
|
30
|
+
const data = {};
|
|
31
|
+
const idsToFetch = [];
|
|
32
|
+
for (const id of ids) {
|
|
33
|
+
const item = cache.get(getUniqueId(type, id));
|
|
34
|
+
if (typeof item !== 'undefined') {
|
|
35
|
+
data[id] = item;
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
idsToFetch.push(id);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
if (idsToFetch.length) {
|
|
42
|
+
logger.trace({ items: idsToFetch.length }, 'loading from store');
|
|
43
|
+
const fetched = await store.get(type, idsToFetch);
|
|
44
|
+
for (const id of idsToFetch) {
|
|
45
|
+
const item = fetched[id];
|
|
46
|
+
if (item) {
|
|
47
|
+
data[id] = item;
|
|
48
|
+
cache.set(getUniqueId(type, id), item);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
return data;
|
|
53
|
+
},
|
|
54
|
+
async set(data) {
|
|
55
|
+
let keys = 0;
|
|
56
|
+
for (const type in data) {
|
|
57
|
+
for (const id in data[type]) {
|
|
58
|
+
cache.set(getUniqueId(type, id), data[type][id]);
|
|
59
|
+
keys += 1;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
logger.trace({ keys }, 'updated cache');
|
|
63
|
+
await store.set(data);
|
|
64
|
+
},
|
|
65
|
+
async clear() {
|
|
66
|
+
var _a;
|
|
67
|
+
cache.flushAll();
|
|
68
|
+
await ((_a = store.clear) === null || _a === void 0 ? void 0 : _a.call(store));
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
exports.makeCacheableSignalKeyStore = makeCacheableSignalKeyStore;
|
|
73
|
+
/**
|
|
74
|
+
* Adds DB like transaction capability (https://en.wikipedia.org/wiki/Database_transaction) to the SignalKeyStore,
|
|
75
|
+
* this allows batch read & write operations & improves the performance of the lib
|
|
76
|
+
* @param state the key store to apply this capability to
|
|
77
|
+
* @param logger logger to log events
|
|
78
|
+
* @returns SignalKeyStore with transaction capability
|
|
79
|
+
*/
|
|
80
|
+
const addTransactionCapability = (state, logger, { maxCommitRetries, delayBetweenTriesMs }) => {
|
|
81
|
+
// number of queries made to the DB during the transaction
|
|
82
|
+
// only there for logging purposes
|
|
83
|
+
let dbQueriesInTransaction = 0;
|
|
84
|
+
let transactionCache = {};
|
|
85
|
+
let mutations = {};
|
|
86
|
+
let transactionsInProgress = 0;
|
|
87
|
+
return {
|
|
88
|
+
get: async (type, ids) => {
|
|
89
|
+
if (isInTransaction()) {
|
|
90
|
+
const dict = transactionCache[type];
|
|
91
|
+
const idsRequiringFetch = dict
|
|
92
|
+
? ids.filter(item => typeof dict[item] === 'undefined')
|
|
93
|
+
: ids;
|
|
94
|
+
// only fetch if there are any items to fetch
|
|
95
|
+
if (idsRequiringFetch.length) {
|
|
96
|
+
dbQueriesInTransaction += 1;
|
|
97
|
+
const result = await state.get(type, idsRequiringFetch);
|
|
98
|
+
transactionCache[type] || (transactionCache[type] = {});
|
|
99
|
+
Object.assign(transactionCache[type], result);
|
|
100
|
+
}
|
|
101
|
+
return ids.reduce((dict, id) => {
|
|
102
|
+
var _a;
|
|
103
|
+
const value = (_a = transactionCache[type]) === null || _a === void 0 ? void 0 : _a[id];
|
|
104
|
+
if (value) {
|
|
105
|
+
dict[id] = value;
|
|
106
|
+
}
|
|
107
|
+
return dict;
|
|
108
|
+
}, {});
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
return state.get(type, ids);
|
|
112
|
+
}
|
|
113
|
+
},
|
|
114
|
+
set: data => {
|
|
115
|
+
if (isInTransaction()) {
|
|
116
|
+
logger.trace({ types: Object.keys(data) }, 'caching in transaction');
|
|
117
|
+
for (const key in data) {
|
|
118
|
+
transactionCache[key] = transactionCache[key] || {};
|
|
119
|
+
Object.assign(transactionCache[key], data[key]);
|
|
120
|
+
mutations[key] = mutations[key] || {};
|
|
121
|
+
Object.assign(mutations[key], data[key]);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
return state.set(data);
|
|
126
|
+
}
|
|
127
|
+
},
|
|
128
|
+
isInTransaction,
|
|
129
|
+
async transaction(work) {
|
|
130
|
+
let result;
|
|
131
|
+
transactionsInProgress += 1;
|
|
132
|
+
if (transactionsInProgress === 1) {
|
|
133
|
+
logger.trace('entering transaction');
|
|
134
|
+
}
|
|
135
|
+
try {
|
|
136
|
+
result = await work();
|
|
137
|
+
// commit if this is the outermost transaction
|
|
138
|
+
if (transactionsInProgress === 1) {
|
|
139
|
+
if (Object.keys(mutations).length) {
|
|
140
|
+
logger.trace('committing transaction');
|
|
141
|
+
// retry mechanism to ensure we've some recovery
|
|
142
|
+
// in case a transaction fails in the first attempt
|
|
143
|
+
let tries = maxCommitRetries;
|
|
144
|
+
while (tries) {
|
|
145
|
+
tries -= 1;
|
|
146
|
+
try {
|
|
147
|
+
await state.set(mutations);
|
|
148
|
+
logger.trace({ dbQueriesInTransaction }, 'committed transaction');
|
|
149
|
+
break;
|
|
150
|
+
}
|
|
151
|
+
catch (error) {
|
|
152
|
+
logger.warn(`failed to commit ${Object.keys(mutations).length} mutations, tries left=${tries}`);
|
|
153
|
+
await (0, generics_1.delay)(delayBetweenTriesMs);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
logger.trace('no mutations in transaction');
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
finally {
|
|
163
|
+
transactionsInProgress -= 1;
|
|
164
|
+
if (transactionsInProgress === 0) {
|
|
165
|
+
transactionCache = {};
|
|
166
|
+
mutations = {};
|
|
167
|
+
dbQueriesInTransaction = 0;
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
return result;
|
|
171
|
+
}
|
|
172
|
+
};
|
|
173
|
+
function isInTransaction() {
|
|
174
|
+
return transactionsInProgress > 0;
|
|
175
|
+
}
|
|
176
|
+
};
|
|
177
|
+
exports.addTransactionCapability = addTransactionCapability;
|
|
178
|
+
const initAuthCreds = () => {
|
|
179
|
+
const identityKey = crypto_2.Curve.generateKeyPair();
|
|
180
|
+
return {
|
|
181
|
+
noiseKey: crypto_2.Curve.generateKeyPair(),
|
|
182
|
+
pairingEphemeralKeyPair: crypto_2.Curve.generateKeyPair(),
|
|
183
|
+
signedIdentityKey: identityKey,
|
|
184
|
+
signedPreKey: (0, crypto_2.signedKeyPair)(identityKey, 1),
|
|
185
|
+
registrationId: (0, generics_1.generateRegistrationId)(),
|
|
186
|
+
advSecretKey: (0, crypto_1.randomBytes)(32).toString('base64'),
|
|
187
|
+
processedHistoryMessages: [],
|
|
188
|
+
nextPreKeyId: 1,
|
|
189
|
+
firstUnuploadedPreKeyId: 1,
|
|
190
|
+
accountSyncCounter: 0,
|
|
191
|
+
accountSettings: {
|
|
192
|
+
unarchiveChats: false
|
|
193
|
+
},
|
|
194
|
+
// mobile creds
|
|
195
|
+
deviceId: Buffer.from((0, uuid_1.v4)().replace(/-/g, ''), 'hex').toString('base64url'),
|
|
196
|
+
phoneId: (0, uuid_1.v4)(),
|
|
197
|
+
identityId: (0, crypto_1.randomBytes)(20),
|
|
198
|
+
registered: false,
|
|
199
|
+
backupToken: (0, crypto_1.randomBytes)(20),
|
|
200
|
+
registration: {},
|
|
201
|
+
pairingCode: undefined,
|
|
202
|
+
};
|
|
203
|
+
};
|
|
204
|
+
exports.initAuthCreds = initAuthCreds;
|