@metamask-previews/multichain-transactions-controller 0.1.0-preview-99939da3 → 0.2.0-preview-224dff25
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/CHANGELOG.md +15 -1
- package/dist/MultichainTransactionsController.cjs +51 -76
- package/dist/MultichainTransactionsController.cjs.map +1 -1
- package/dist/MultichainTransactionsController.d.cts +5 -24
- package/dist/MultichainTransactionsController.d.cts.map +1 -1
- package/dist/MultichainTransactionsController.d.mts +5 -24
- package/dist/MultichainTransactionsController.d.mts.map +1 -1
- package/dist/MultichainTransactionsController.mjs +52 -77
- package/dist/MultichainTransactionsController.mjs.map +1 -1
- package/dist/constants.cjs +1 -11
- package/dist/constants.cjs.map +1 -1
- package/dist/constants.d.cts +0 -4
- package/dist/constants.d.cts.map +1 -1
- package/dist/constants.d.mts +0 -4
- package/dist/constants.d.mts.map +1 -1
- package/dist/constants.mjs +0 -10
- package/dist/constants.mjs.map +1 -1
- package/dist/index.cjs +1 -2
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +1 -1
- package/dist/index.d.cts.map +1 -1
- package/dist/index.d.mts +1 -1
- package/dist/index.d.mts.map +1 -1
- package/dist/index.mjs +1 -1
- package/dist/index.mjs.map +1 -1
- package/package.json +9 -9
- package/dist/MultichainTransactionsTracker.cjs +0 -124
- package/dist/MultichainTransactionsTracker.cjs.map +0 -1
- package/dist/MultichainTransactionsTracker.d.cts +0 -62
- package/dist/MultichainTransactionsTracker.d.cts.map +0 -1
- package/dist/MultichainTransactionsTracker.d.mts +0 -62
- package/dist/MultichainTransactionsTracker.d.mts.map +0 -1
- package/dist/MultichainTransactionsTracker.mjs +0 -120
- package/dist/MultichainTransactionsTracker.mjs.map +0 -1
- package/dist/Poller.cjs +0 -40
- package/dist/Poller.cjs.map +0 -1
- package/dist/Poller.d.cts +0 -7
- package/dist/Poller.d.cts.map +0 -1
- package/dist/Poller.d.mts +0 -7
- package/dist/Poller.d.mts.map +0 -1
- package/dist/Poller.mjs +0 -36
- package/dist/Poller.mjs.map +0 -1
|
@@ -1,124 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
3
|
-
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
4
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
5
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
6
|
-
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
7
|
-
};
|
|
8
|
-
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
9
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
10
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
11
|
-
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
12
|
-
};
|
|
13
|
-
var _MultichainTransactionsTracker_poller, _MultichainTransactionsTracker_updateTransactions, _MultichainTransactionsTracker_transactions;
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.MultichainTransactionsTracker = void 0;
|
|
16
|
-
const Poller_1 = require("./Poller.cjs");
|
|
17
|
-
// Every 5s in milliseconds.
|
|
18
|
-
const TRANSACTIONS_TRACKING_INTERVAL = 5 * 1000;
|
|
19
|
-
/**
|
|
20
|
-
* This class manages the tracking and periodic updating of transactions for multiple blockchain accounts.
|
|
21
|
-
*
|
|
22
|
-
* The tracker uses a polling mechanism to periodically check and update transactions
|
|
23
|
-
* for all tracked accounts, respecting each account's specific block time to determine
|
|
24
|
-
* when updates are needed.
|
|
25
|
-
*/
|
|
26
|
-
class MultichainTransactionsTracker {
|
|
27
|
-
constructor(updateTransactionsCallback) {
|
|
28
|
-
_MultichainTransactionsTracker_poller.set(this, void 0);
|
|
29
|
-
_MultichainTransactionsTracker_updateTransactions.set(this, void 0);
|
|
30
|
-
_MultichainTransactionsTracker_transactions.set(this, {});
|
|
31
|
-
__classPrivateFieldSet(this, _MultichainTransactionsTracker_updateTransactions, updateTransactionsCallback, "f");
|
|
32
|
-
__classPrivateFieldSet(this, _MultichainTransactionsTracker_poller, new Poller_1.Poller(() => {
|
|
33
|
-
this.updateTransactions().catch((error) => {
|
|
34
|
-
console.error('Failed to update transactions:', error);
|
|
35
|
-
});
|
|
36
|
-
}, TRANSACTIONS_TRACKING_INTERVAL), "f");
|
|
37
|
-
}
|
|
38
|
-
/**
|
|
39
|
-
* Starts the tracking process.
|
|
40
|
-
*/
|
|
41
|
-
start() {
|
|
42
|
-
__classPrivateFieldGet(this, _MultichainTransactionsTracker_poller, "f").start();
|
|
43
|
-
}
|
|
44
|
-
/**
|
|
45
|
-
* Stops the tracking process.
|
|
46
|
-
*/
|
|
47
|
-
stop() {
|
|
48
|
-
__classPrivateFieldGet(this, _MultichainTransactionsTracker_poller, "f").stop();
|
|
49
|
-
}
|
|
50
|
-
/**
|
|
51
|
-
* Checks if an account ID is being tracked.
|
|
52
|
-
*
|
|
53
|
-
* @param accountId - The account ID.
|
|
54
|
-
* @returns True if the account is being tracked, false otherwise.
|
|
55
|
-
*/
|
|
56
|
-
isTracked(accountId) {
|
|
57
|
-
return accountId in __classPrivateFieldGet(this, _MultichainTransactionsTracker_transactions, "f");
|
|
58
|
-
}
|
|
59
|
-
/**
|
|
60
|
-
* Asserts that an account ID is being tracked.
|
|
61
|
-
*
|
|
62
|
-
* @param accountId - The account ID.
|
|
63
|
-
* @throws If the account ID is not being tracked.
|
|
64
|
-
*/
|
|
65
|
-
assertBeingTracked(accountId) {
|
|
66
|
-
if (!this.isTracked(accountId)) {
|
|
67
|
-
throw new Error(`Account is not being tracked: ${accountId}`);
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Starts tracking a new account ID. This method has no effect on already tracked
|
|
72
|
-
* accounts.
|
|
73
|
-
*
|
|
74
|
-
* @param accountId - The account ID.
|
|
75
|
-
* @param blockTime - The block time (used when refreshing the account transactions).
|
|
76
|
-
* @param pagination - Options for paginating transaction results. Defaults to { limit: 10 }.
|
|
77
|
-
*/
|
|
78
|
-
track(accountId, blockTime, pagination = { limit: 10 }) {
|
|
79
|
-
if (!this.isTracked(accountId)) {
|
|
80
|
-
__classPrivateFieldGet(this, _MultichainTransactionsTracker_transactions, "f")[accountId] = {
|
|
81
|
-
lastUpdated: 0,
|
|
82
|
-
blockTime,
|
|
83
|
-
pagination,
|
|
84
|
-
};
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
/**
|
|
88
|
-
* Stops tracking a tracked account ID.
|
|
89
|
-
*
|
|
90
|
-
* @param accountId - The account ID.
|
|
91
|
-
* @throws If the account ID is not being tracked.
|
|
92
|
-
*/
|
|
93
|
-
untrack(accountId) {
|
|
94
|
-
this.assertBeingTracked(accountId);
|
|
95
|
-
delete __classPrivateFieldGet(this, _MultichainTransactionsTracker_transactions, "f")[accountId];
|
|
96
|
-
}
|
|
97
|
-
/**
|
|
98
|
-
* Update the transactions for a tracked account ID.
|
|
99
|
-
*
|
|
100
|
-
* @param accountId - The account ID.
|
|
101
|
-
* @throws If the account ID is not being tracked.
|
|
102
|
-
*/
|
|
103
|
-
async updateTransactionsForAccount(accountId) {
|
|
104
|
-
this.assertBeingTracked(accountId);
|
|
105
|
-
const info = __classPrivateFieldGet(this, _MultichainTransactionsTracker_transactions, "f")[accountId];
|
|
106
|
-
const isOutdated = Date.now() - info.lastUpdated >= info.blockTime;
|
|
107
|
-
const hasNoTransactionsYet = info.lastUpdated === 0;
|
|
108
|
-
if (hasNoTransactionsYet || isOutdated) {
|
|
109
|
-
await __classPrivateFieldGet(this, _MultichainTransactionsTracker_updateTransactions, "f").call(this, accountId, info.pagination);
|
|
110
|
-
__classPrivateFieldGet(this, _MultichainTransactionsTracker_transactions, "f")[accountId].lastUpdated = Date.now();
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
/**
|
|
114
|
-
* Update the transactions of all tracked accounts
|
|
115
|
-
*/
|
|
116
|
-
async updateTransactions() {
|
|
117
|
-
await Promise.allSettled(Object.keys(__classPrivateFieldGet(this, _MultichainTransactionsTracker_transactions, "f")).map(async (accountId) => {
|
|
118
|
-
await this.updateTransactionsForAccount(accountId);
|
|
119
|
-
}));
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
exports.MultichainTransactionsTracker = MultichainTransactionsTracker;
|
|
123
|
-
_MultichainTransactionsTracker_poller = new WeakMap(), _MultichainTransactionsTracker_updateTransactions = new WeakMap(), _MultichainTransactionsTracker_transactions = new WeakMap();
|
|
124
|
-
//# sourceMappingURL=MultichainTransactionsTracker.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MultichainTransactionsTracker.cjs","sourceRoot":"","sources":["../src/MultichainTransactionsTracker.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,yCAAkC;AAQlC,4BAA4B;AAC5B,MAAM,8BAA8B,GAAG,CAAC,GAAG,IAAI,CAAC;AAEhD;;;;;;GAMG;AACH,MAAa,6BAA6B;IAUxC,YACE,0BAGkB;QAbX,wDAAgB;QAEhB,oEAGU;QAEnB,sDAAiD,EAAE,EAAC;QAQlD,uBAAA,IAAI,qDAAuB,0BAA0B,MAAA,CAAC;QAEtD,uBAAA,IAAI,yCAAW,IAAI,eAAM,CAAC,GAAG,EAAE;YAC7B,IAAI,CAAC,kBAAkB,EAAE,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;gBACxC,OAAO,CAAC,KAAK,CAAC,gCAAgC,EAAE,KAAK,CAAC,CAAC;YACzD,CAAC,CAAC,CAAC;QACL,CAAC,EAAE,8BAA8B,CAAC,MAAA,CAAC;IACrC,CAAC;IAED;;OAEG;IACH,KAAK;QACH,uBAAA,IAAI,6CAAQ,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;IAED;;OAEG;IACH,IAAI;QACF,uBAAA,IAAI,6CAAQ,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;IAED;;;;;OAKG;IACH,SAAS,CAAC,SAAiB;QACzB,OAAO,SAAS,IAAI,uBAAA,IAAI,mDAAc,CAAC;IACzC,CAAC;IAED;;;;;OAKG;IACH,kBAAkB,CAAC,SAAiB;QAClC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;YAC9B,MAAM,IAAI,KAAK,CAAC,iCAAiC,SAAS,EAAE,CAAC,CAAC;SAC/D;IACH,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CACH,SAAiB,EACjB,SAAiB,EACjB,aAAgC,EAAE,KAAK,EAAE,EAAE,EAAE;QAE7C,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;YAC9B,uBAAA,IAAI,mDAAc,CAAC,SAAS,CAAC,GAAG;gBAC9B,WAAW,EAAE,CAAC;gBACd,SAAS;gBACT,UAAU;aACX,CAAC;SACH;IACH,CAAC;IAED;;;;;OAKG;IACH,OAAO,CAAC,SAAiB;QACvB,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QACnC,OAAO,uBAAA,IAAI,mDAAc,CAAC,SAAS,CAAC,CAAC;IACvC,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,4BAA4B,CAAC,SAAiB;QAClD,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QAEnC,MAAM,IAAI,GAAG,uBAAA,IAAI,mDAAc,CAAC,SAAS,CAAC,CAAC;QAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,SAAS,CAAC;QACnE,MAAM,oBAAoB,GAAG,IAAI,CAAC,WAAW,KAAK,CAAC,CAAC;QAEpD,IAAI,oBAAoB,IAAI,UAAU,EAAE;YACtC,MAAM,uBAAA,IAAI,yDAAoB,MAAxB,IAAI,EAAqB,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YAC3D,uBAAA,IAAI,mDAAc,CAAC,SAAS,CAAC,CAAC,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;SACxD;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,kBAAkB;QACtB,MAAM,OAAO,CAAC,UAAU,CACtB,MAAM,CAAC,IAAI,CAAC,uBAAA,IAAI,mDAAc,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE;YACtD,MAAM,IAAI,CAAC,4BAA4B,CAAC,SAAS,CAAC,CAAC;QACrD,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;CACF;AA3HD,sEA2HC","sourcesContent":["import type { PaginationOptions } from './MultichainTransactionsController';\nimport { Poller } from './Poller';\n\ntype TransactionInfo = {\n lastUpdated: number;\n blockTime: number;\n pagination: PaginationOptions;\n};\n\n// Every 5s in milliseconds.\nconst TRANSACTIONS_TRACKING_INTERVAL = 5 * 1000;\n\n/**\n * This class manages the tracking and periodic updating of transactions for multiple blockchain accounts.\n *\n * The tracker uses a polling mechanism to periodically check and update transactions\n * for all tracked accounts, respecting each account's specific block time to determine\n * when updates are needed.\n */\nexport class MultichainTransactionsTracker {\n readonly #poller: Poller;\n\n readonly #updateTransactions: (\n accountId: string,\n pagination: PaginationOptions,\n ) => Promise<void>;\n\n #transactions: Record<string, TransactionInfo> = {};\n\n constructor(\n updateTransactionsCallback: (\n accountId: string,\n pagination: PaginationOptions,\n ) => Promise<void>,\n ) {\n this.#updateTransactions = updateTransactionsCallback;\n\n this.#poller = new Poller(() => {\n this.updateTransactions().catch((error) => {\n console.error('Failed to update transactions:', error);\n });\n }, TRANSACTIONS_TRACKING_INTERVAL);\n }\n\n /**\n * Starts the tracking process.\n */\n start(): void {\n this.#poller.start();\n }\n\n /**\n * Stops the tracking process.\n */\n stop(): void {\n this.#poller.stop();\n }\n\n /**\n * Checks if an account ID is being tracked.\n *\n * @param accountId - The account ID.\n * @returns True if the account is being tracked, false otherwise.\n */\n isTracked(accountId: string) {\n return accountId in this.#transactions;\n }\n\n /**\n * Asserts that an account ID is being tracked.\n *\n * @param accountId - The account ID.\n * @throws If the account ID is not being tracked.\n */\n assertBeingTracked(accountId: string) {\n if (!this.isTracked(accountId)) {\n throw new Error(`Account is not being tracked: ${accountId}`);\n }\n }\n\n /**\n * Starts tracking a new account ID. This method has no effect on already tracked\n * accounts.\n *\n * @param accountId - The account ID.\n * @param blockTime - The block time (used when refreshing the account transactions).\n * @param pagination - Options for paginating transaction results. Defaults to { limit: 10 }.\n */\n track(\n accountId: string,\n blockTime: number,\n pagination: PaginationOptions = { limit: 10 },\n ) {\n if (!this.isTracked(accountId)) {\n this.#transactions[accountId] = {\n lastUpdated: 0,\n blockTime,\n pagination,\n };\n }\n }\n\n /**\n * Stops tracking a tracked account ID.\n *\n * @param accountId - The account ID.\n * @throws If the account ID is not being tracked.\n */\n untrack(accountId: string) {\n this.assertBeingTracked(accountId);\n delete this.#transactions[accountId];\n }\n\n /**\n * Update the transactions for a tracked account ID.\n *\n * @param accountId - The account ID.\n * @throws If the account ID is not being tracked.\n */\n async updateTransactionsForAccount(accountId: string) {\n this.assertBeingTracked(accountId);\n\n const info = this.#transactions[accountId];\n const isOutdated = Date.now() - info.lastUpdated >= info.blockTime;\n const hasNoTransactionsYet = info.lastUpdated === 0;\n\n if (hasNoTransactionsYet || isOutdated) {\n await this.#updateTransactions(accountId, info.pagination);\n this.#transactions[accountId].lastUpdated = Date.now();\n }\n }\n\n /**\n * Update the transactions of all tracked accounts\n */\n async updateTransactions() {\n await Promise.allSettled(\n Object.keys(this.#transactions).map(async (accountId) => {\n await this.updateTransactionsForAccount(accountId);\n }),\n );\n }\n}\n"]}
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import type { PaginationOptions } from "./MultichainTransactionsController.cjs";
|
|
2
|
-
/**
|
|
3
|
-
* This class manages the tracking and periodic updating of transactions for multiple blockchain accounts.
|
|
4
|
-
*
|
|
5
|
-
* The tracker uses a polling mechanism to periodically check and update transactions
|
|
6
|
-
* for all tracked accounts, respecting each account's specific block time to determine
|
|
7
|
-
* when updates are needed.
|
|
8
|
-
*/
|
|
9
|
-
export declare class MultichainTransactionsTracker {
|
|
10
|
-
#private;
|
|
11
|
-
constructor(updateTransactionsCallback: (accountId: string, pagination: PaginationOptions) => Promise<void>);
|
|
12
|
-
/**
|
|
13
|
-
* Starts the tracking process.
|
|
14
|
-
*/
|
|
15
|
-
start(): void;
|
|
16
|
-
/**
|
|
17
|
-
* Stops the tracking process.
|
|
18
|
-
*/
|
|
19
|
-
stop(): void;
|
|
20
|
-
/**
|
|
21
|
-
* Checks if an account ID is being tracked.
|
|
22
|
-
*
|
|
23
|
-
* @param accountId - The account ID.
|
|
24
|
-
* @returns True if the account is being tracked, false otherwise.
|
|
25
|
-
*/
|
|
26
|
-
isTracked(accountId: string): boolean;
|
|
27
|
-
/**
|
|
28
|
-
* Asserts that an account ID is being tracked.
|
|
29
|
-
*
|
|
30
|
-
* @param accountId - The account ID.
|
|
31
|
-
* @throws If the account ID is not being tracked.
|
|
32
|
-
*/
|
|
33
|
-
assertBeingTracked(accountId: string): void;
|
|
34
|
-
/**
|
|
35
|
-
* Starts tracking a new account ID. This method has no effect on already tracked
|
|
36
|
-
* accounts.
|
|
37
|
-
*
|
|
38
|
-
* @param accountId - The account ID.
|
|
39
|
-
* @param blockTime - The block time (used when refreshing the account transactions).
|
|
40
|
-
* @param pagination - Options for paginating transaction results. Defaults to { limit: 10 }.
|
|
41
|
-
*/
|
|
42
|
-
track(accountId: string, blockTime: number, pagination?: PaginationOptions): void;
|
|
43
|
-
/**
|
|
44
|
-
* Stops tracking a tracked account ID.
|
|
45
|
-
*
|
|
46
|
-
* @param accountId - The account ID.
|
|
47
|
-
* @throws If the account ID is not being tracked.
|
|
48
|
-
*/
|
|
49
|
-
untrack(accountId: string): void;
|
|
50
|
-
/**
|
|
51
|
-
* Update the transactions for a tracked account ID.
|
|
52
|
-
*
|
|
53
|
-
* @param accountId - The account ID.
|
|
54
|
-
* @throws If the account ID is not being tracked.
|
|
55
|
-
*/
|
|
56
|
-
updateTransactionsForAccount(accountId: string): Promise<void>;
|
|
57
|
-
/**
|
|
58
|
-
* Update the transactions of all tracked accounts
|
|
59
|
-
*/
|
|
60
|
-
updateTransactions(): Promise<void>;
|
|
61
|
-
}
|
|
62
|
-
//# sourceMappingURL=MultichainTransactionsTracker.d.cts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MultichainTransactionsTracker.d.cts","sourceRoot":"","sources":["../src/MultichainTransactionsTracker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,+CAA2C;AAY5E;;;;;;GAMG;AACH,qBAAa,6BAA6B;;gBAWtC,0BAA0B,EAAE,CAC1B,SAAS,EAAE,MAAM,EACjB,UAAU,EAAE,iBAAiB,KAC1B,OAAO,CAAC,IAAI,CAAC;IAWpB;;OAEG;IACH,KAAK,IAAI,IAAI;IAIb;;OAEG;IACH,IAAI,IAAI,IAAI;IAIZ;;;;;OAKG;IACH,SAAS,CAAC,SAAS,EAAE,MAAM;IAI3B;;;;;OAKG;IACH,kBAAkB,CAAC,SAAS,EAAE,MAAM;IAMpC;;;;;;;OAOG;IACH,KAAK,CACH,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,EACjB,UAAU,GAAE,iBAAiC;IAW/C;;;;;OAKG;IACH,OAAO,CAAC,SAAS,EAAE,MAAM;IAKzB;;;;;OAKG;IACG,4BAA4B,CAAC,SAAS,EAAE,MAAM;IAapD;;OAEG;IACG,kBAAkB;CAOzB"}
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import type { PaginationOptions } from "./MultichainTransactionsController.mjs";
|
|
2
|
-
/**
|
|
3
|
-
* This class manages the tracking and periodic updating of transactions for multiple blockchain accounts.
|
|
4
|
-
*
|
|
5
|
-
* The tracker uses a polling mechanism to periodically check and update transactions
|
|
6
|
-
* for all tracked accounts, respecting each account's specific block time to determine
|
|
7
|
-
* when updates are needed.
|
|
8
|
-
*/
|
|
9
|
-
export declare class MultichainTransactionsTracker {
|
|
10
|
-
#private;
|
|
11
|
-
constructor(updateTransactionsCallback: (accountId: string, pagination: PaginationOptions) => Promise<void>);
|
|
12
|
-
/**
|
|
13
|
-
* Starts the tracking process.
|
|
14
|
-
*/
|
|
15
|
-
start(): void;
|
|
16
|
-
/**
|
|
17
|
-
* Stops the tracking process.
|
|
18
|
-
*/
|
|
19
|
-
stop(): void;
|
|
20
|
-
/**
|
|
21
|
-
* Checks if an account ID is being tracked.
|
|
22
|
-
*
|
|
23
|
-
* @param accountId - The account ID.
|
|
24
|
-
* @returns True if the account is being tracked, false otherwise.
|
|
25
|
-
*/
|
|
26
|
-
isTracked(accountId: string): boolean;
|
|
27
|
-
/**
|
|
28
|
-
* Asserts that an account ID is being tracked.
|
|
29
|
-
*
|
|
30
|
-
* @param accountId - The account ID.
|
|
31
|
-
* @throws If the account ID is not being tracked.
|
|
32
|
-
*/
|
|
33
|
-
assertBeingTracked(accountId: string): void;
|
|
34
|
-
/**
|
|
35
|
-
* Starts tracking a new account ID. This method has no effect on already tracked
|
|
36
|
-
* accounts.
|
|
37
|
-
*
|
|
38
|
-
* @param accountId - The account ID.
|
|
39
|
-
* @param blockTime - The block time (used when refreshing the account transactions).
|
|
40
|
-
* @param pagination - Options for paginating transaction results. Defaults to { limit: 10 }.
|
|
41
|
-
*/
|
|
42
|
-
track(accountId: string, blockTime: number, pagination?: PaginationOptions): void;
|
|
43
|
-
/**
|
|
44
|
-
* Stops tracking a tracked account ID.
|
|
45
|
-
*
|
|
46
|
-
* @param accountId - The account ID.
|
|
47
|
-
* @throws If the account ID is not being tracked.
|
|
48
|
-
*/
|
|
49
|
-
untrack(accountId: string): void;
|
|
50
|
-
/**
|
|
51
|
-
* Update the transactions for a tracked account ID.
|
|
52
|
-
*
|
|
53
|
-
* @param accountId - The account ID.
|
|
54
|
-
* @throws If the account ID is not being tracked.
|
|
55
|
-
*/
|
|
56
|
-
updateTransactionsForAccount(accountId: string): Promise<void>;
|
|
57
|
-
/**
|
|
58
|
-
* Update the transactions of all tracked accounts
|
|
59
|
-
*/
|
|
60
|
-
updateTransactions(): Promise<void>;
|
|
61
|
-
}
|
|
62
|
-
//# sourceMappingURL=MultichainTransactionsTracker.d.mts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MultichainTransactionsTracker.d.mts","sourceRoot":"","sources":["../src/MultichainTransactionsTracker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,+CAA2C;AAY5E;;;;;;GAMG;AACH,qBAAa,6BAA6B;;gBAWtC,0BAA0B,EAAE,CAC1B,SAAS,EAAE,MAAM,EACjB,UAAU,EAAE,iBAAiB,KAC1B,OAAO,CAAC,IAAI,CAAC;IAWpB;;OAEG;IACH,KAAK,IAAI,IAAI;IAIb;;OAEG;IACH,IAAI,IAAI,IAAI;IAIZ;;;;;OAKG;IACH,SAAS,CAAC,SAAS,EAAE,MAAM;IAI3B;;;;;OAKG;IACH,kBAAkB,CAAC,SAAS,EAAE,MAAM;IAMpC;;;;;;;OAOG;IACH,KAAK,CACH,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,EACjB,UAAU,GAAE,iBAAiC;IAW/C;;;;;OAKG;IACH,OAAO,CAAC,SAAS,EAAE,MAAM;IAKzB;;;;;OAKG;IACG,4BAA4B,CAAC,SAAS,EAAE,MAAM;IAapD;;OAEG;IACG,kBAAkB;CAOzB"}
|
|
@@ -1,120 +0,0 @@
|
|
|
1
|
-
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
2
|
-
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
3
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
4
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
5
|
-
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
6
|
-
};
|
|
7
|
-
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
8
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
9
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
10
|
-
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
11
|
-
};
|
|
12
|
-
var _MultichainTransactionsTracker_poller, _MultichainTransactionsTracker_updateTransactions, _MultichainTransactionsTracker_transactions;
|
|
13
|
-
import { Poller } from "./Poller.mjs";
|
|
14
|
-
// Every 5s in milliseconds.
|
|
15
|
-
const TRANSACTIONS_TRACKING_INTERVAL = 5 * 1000;
|
|
16
|
-
/**
|
|
17
|
-
* This class manages the tracking and periodic updating of transactions for multiple blockchain accounts.
|
|
18
|
-
*
|
|
19
|
-
* The tracker uses a polling mechanism to periodically check and update transactions
|
|
20
|
-
* for all tracked accounts, respecting each account's specific block time to determine
|
|
21
|
-
* when updates are needed.
|
|
22
|
-
*/
|
|
23
|
-
export class MultichainTransactionsTracker {
|
|
24
|
-
constructor(updateTransactionsCallback) {
|
|
25
|
-
_MultichainTransactionsTracker_poller.set(this, void 0);
|
|
26
|
-
_MultichainTransactionsTracker_updateTransactions.set(this, void 0);
|
|
27
|
-
_MultichainTransactionsTracker_transactions.set(this, {});
|
|
28
|
-
__classPrivateFieldSet(this, _MultichainTransactionsTracker_updateTransactions, updateTransactionsCallback, "f");
|
|
29
|
-
__classPrivateFieldSet(this, _MultichainTransactionsTracker_poller, new Poller(() => {
|
|
30
|
-
this.updateTransactions().catch((error) => {
|
|
31
|
-
console.error('Failed to update transactions:', error);
|
|
32
|
-
});
|
|
33
|
-
}, TRANSACTIONS_TRACKING_INTERVAL), "f");
|
|
34
|
-
}
|
|
35
|
-
/**
|
|
36
|
-
* Starts the tracking process.
|
|
37
|
-
*/
|
|
38
|
-
start() {
|
|
39
|
-
__classPrivateFieldGet(this, _MultichainTransactionsTracker_poller, "f").start();
|
|
40
|
-
}
|
|
41
|
-
/**
|
|
42
|
-
* Stops the tracking process.
|
|
43
|
-
*/
|
|
44
|
-
stop() {
|
|
45
|
-
__classPrivateFieldGet(this, _MultichainTransactionsTracker_poller, "f").stop();
|
|
46
|
-
}
|
|
47
|
-
/**
|
|
48
|
-
* Checks if an account ID is being tracked.
|
|
49
|
-
*
|
|
50
|
-
* @param accountId - The account ID.
|
|
51
|
-
* @returns True if the account is being tracked, false otherwise.
|
|
52
|
-
*/
|
|
53
|
-
isTracked(accountId) {
|
|
54
|
-
return accountId in __classPrivateFieldGet(this, _MultichainTransactionsTracker_transactions, "f");
|
|
55
|
-
}
|
|
56
|
-
/**
|
|
57
|
-
* Asserts that an account ID is being tracked.
|
|
58
|
-
*
|
|
59
|
-
* @param accountId - The account ID.
|
|
60
|
-
* @throws If the account ID is not being tracked.
|
|
61
|
-
*/
|
|
62
|
-
assertBeingTracked(accountId) {
|
|
63
|
-
if (!this.isTracked(accountId)) {
|
|
64
|
-
throw new Error(`Account is not being tracked: ${accountId}`);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
/**
|
|
68
|
-
* Starts tracking a new account ID. This method has no effect on already tracked
|
|
69
|
-
* accounts.
|
|
70
|
-
*
|
|
71
|
-
* @param accountId - The account ID.
|
|
72
|
-
* @param blockTime - The block time (used when refreshing the account transactions).
|
|
73
|
-
* @param pagination - Options for paginating transaction results. Defaults to { limit: 10 }.
|
|
74
|
-
*/
|
|
75
|
-
track(accountId, blockTime, pagination = { limit: 10 }) {
|
|
76
|
-
if (!this.isTracked(accountId)) {
|
|
77
|
-
__classPrivateFieldGet(this, _MultichainTransactionsTracker_transactions, "f")[accountId] = {
|
|
78
|
-
lastUpdated: 0,
|
|
79
|
-
blockTime,
|
|
80
|
-
pagination,
|
|
81
|
-
};
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Stops tracking a tracked account ID.
|
|
86
|
-
*
|
|
87
|
-
* @param accountId - The account ID.
|
|
88
|
-
* @throws If the account ID is not being tracked.
|
|
89
|
-
*/
|
|
90
|
-
untrack(accountId) {
|
|
91
|
-
this.assertBeingTracked(accountId);
|
|
92
|
-
delete __classPrivateFieldGet(this, _MultichainTransactionsTracker_transactions, "f")[accountId];
|
|
93
|
-
}
|
|
94
|
-
/**
|
|
95
|
-
* Update the transactions for a tracked account ID.
|
|
96
|
-
*
|
|
97
|
-
* @param accountId - The account ID.
|
|
98
|
-
* @throws If the account ID is not being tracked.
|
|
99
|
-
*/
|
|
100
|
-
async updateTransactionsForAccount(accountId) {
|
|
101
|
-
this.assertBeingTracked(accountId);
|
|
102
|
-
const info = __classPrivateFieldGet(this, _MultichainTransactionsTracker_transactions, "f")[accountId];
|
|
103
|
-
const isOutdated = Date.now() - info.lastUpdated >= info.blockTime;
|
|
104
|
-
const hasNoTransactionsYet = info.lastUpdated === 0;
|
|
105
|
-
if (hasNoTransactionsYet || isOutdated) {
|
|
106
|
-
await __classPrivateFieldGet(this, _MultichainTransactionsTracker_updateTransactions, "f").call(this, accountId, info.pagination);
|
|
107
|
-
__classPrivateFieldGet(this, _MultichainTransactionsTracker_transactions, "f")[accountId].lastUpdated = Date.now();
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
/**
|
|
111
|
-
* Update the transactions of all tracked accounts
|
|
112
|
-
*/
|
|
113
|
-
async updateTransactions() {
|
|
114
|
-
await Promise.allSettled(Object.keys(__classPrivateFieldGet(this, _MultichainTransactionsTracker_transactions, "f")).map(async (accountId) => {
|
|
115
|
-
await this.updateTransactionsForAccount(accountId);
|
|
116
|
-
}));
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
_MultichainTransactionsTracker_poller = new WeakMap(), _MultichainTransactionsTracker_updateTransactions = new WeakMap(), _MultichainTransactionsTracker_transactions = new WeakMap();
|
|
120
|
-
//# sourceMappingURL=MultichainTransactionsTracker.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MultichainTransactionsTracker.mjs","sourceRoot":"","sources":["../src/MultichainTransactionsTracker.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,OAAO,EAAE,MAAM,EAAE,qBAAiB;AAQlC,4BAA4B;AAC5B,MAAM,8BAA8B,GAAG,CAAC,GAAG,IAAI,CAAC;AAEhD;;;;;;GAMG;AACH,MAAM,OAAO,6BAA6B;IAUxC,YACE,0BAGkB;QAbX,wDAAgB;QAEhB,oEAGU;QAEnB,sDAAiD,EAAE,EAAC;QAQlD,uBAAA,IAAI,qDAAuB,0BAA0B,MAAA,CAAC;QAEtD,uBAAA,IAAI,yCAAW,IAAI,MAAM,CAAC,GAAG,EAAE;YAC7B,IAAI,CAAC,kBAAkB,EAAE,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;gBACxC,OAAO,CAAC,KAAK,CAAC,gCAAgC,EAAE,KAAK,CAAC,CAAC;YACzD,CAAC,CAAC,CAAC;QACL,CAAC,EAAE,8BAA8B,CAAC,MAAA,CAAC;IACrC,CAAC;IAED;;OAEG;IACH,KAAK;QACH,uBAAA,IAAI,6CAAQ,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;IAED;;OAEG;IACH,IAAI;QACF,uBAAA,IAAI,6CAAQ,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;IAED;;;;;OAKG;IACH,SAAS,CAAC,SAAiB;QACzB,OAAO,SAAS,IAAI,uBAAA,IAAI,mDAAc,CAAC;IACzC,CAAC;IAED;;;;;OAKG;IACH,kBAAkB,CAAC,SAAiB;QAClC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;YAC9B,MAAM,IAAI,KAAK,CAAC,iCAAiC,SAAS,EAAE,CAAC,CAAC;SAC/D;IACH,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CACH,SAAiB,EACjB,SAAiB,EACjB,aAAgC,EAAE,KAAK,EAAE,EAAE,EAAE;QAE7C,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;YAC9B,uBAAA,IAAI,mDAAc,CAAC,SAAS,CAAC,GAAG;gBAC9B,WAAW,EAAE,CAAC;gBACd,SAAS;gBACT,UAAU;aACX,CAAC;SACH;IACH,CAAC;IAED;;;;;OAKG;IACH,OAAO,CAAC,SAAiB;QACvB,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QACnC,OAAO,uBAAA,IAAI,mDAAc,CAAC,SAAS,CAAC,CAAC;IACvC,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,4BAA4B,CAAC,SAAiB;QAClD,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QAEnC,MAAM,IAAI,GAAG,uBAAA,IAAI,mDAAc,CAAC,SAAS,CAAC,CAAC;QAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,SAAS,CAAC;QACnE,MAAM,oBAAoB,GAAG,IAAI,CAAC,WAAW,KAAK,CAAC,CAAC;QAEpD,IAAI,oBAAoB,IAAI,UAAU,EAAE;YACtC,MAAM,uBAAA,IAAI,yDAAoB,MAAxB,IAAI,EAAqB,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YAC3D,uBAAA,IAAI,mDAAc,CAAC,SAAS,CAAC,CAAC,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;SACxD;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,kBAAkB;QACtB,MAAM,OAAO,CAAC,UAAU,CACtB,MAAM,CAAC,IAAI,CAAC,uBAAA,IAAI,mDAAc,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE;YACtD,MAAM,IAAI,CAAC,4BAA4B,CAAC,SAAS,CAAC,CAAC;QACrD,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;CACF","sourcesContent":["import type { PaginationOptions } from './MultichainTransactionsController';\nimport { Poller } from './Poller';\n\ntype TransactionInfo = {\n lastUpdated: number;\n blockTime: number;\n pagination: PaginationOptions;\n};\n\n// Every 5s in milliseconds.\nconst TRANSACTIONS_TRACKING_INTERVAL = 5 * 1000;\n\n/**\n * This class manages the tracking and periodic updating of transactions for multiple blockchain accounts.\n *\n * The tracker uses a polling mechanism to periodically check and update transactions\n * for all tracked accounts, respecting each account's specific block time to determine\n * when updates are needed.\n */\nexport class MultichainTransactionsTracker {\n readonly #poller: Poller;\n\n readonly #updateTransactions: (\n accountId: string,\n pagination: PaginationOptions,\n ) => Promise<void>;\n\n #transactions: Record<string, TransactionInfo> = {};\n\n constructor(\n updateTransactionsCallback: (\n accountId: string,\n pagination: PaginationOptions,\n ) => Promise<void>,\n ) {\n this.#updateTransactions = updateTransactionsCallback;\n\n this.#poller = new Poller(() => {\n this.updateTransactions().catch((error) => {\n console.error('Failed to update transactions:', error);\n });\n }, TRANSACTIONS_TRACKING_INTERVAL);\n }\n\n /**\n * Starts the tracking process.\n */\n start(): void {\n this.#poller.start();\n }\n\n /**\n * Stops the tracking process.\n */\n stop(): void {\n this.#poller.stop();\n }\n\n /**\n * Checks if an account ID is being tracked.\n *\n * @param accountId - The account ID.\n * @returns True if the account is being tracked, false otherwise.\n */\n isTracked(accountId: string) {\n return accountId in this.#transactions;\n }\n\n /**\n * Asserts that an account ID is being tracked.\n *\n * @param accountId - The account ID.\n * @throws If the account ID is not being tracked.\n */\n assertBeingTracked(accountId: string) {\n if (!this.isTracked(accountId)) {\n throw new Error(`Account is not being tracked: ${accountId}`);\n }\n }\n\n /**\n * Starts tracking a new account ID. This method has no effect on already tracked\n * accounts.\n *\n * @param accountId - The account ID.\n * @param blockTime - The block time (used when refreshing the account transactions).\n * @param pagination - Options for paginating transaction results. Defaults to { limit: 10 }.\n */\n track(\n accountId: string,\n blockTime: number,\n pagination: PaginationOptions = { limit: 10 },\n ) {\n if (!this.isTracked(accountId)) {\n this.#transactions[accountId] = {\n lastUpdated: 0,\n blockTime,\n pagination,\n };\n }\n }\n\n /**\n * Stops tracking a tracked account ID.\n *\n * @param accountId - The account ID.\n * @throws If the account ID is not being tracked.\n */\n untrack(accountId: string) {\n this.assertBeingTracked(accountId);\n delete this.#transactions[accountId];\n }\n\n /**\n * Update the transactions for a tracked account ID.\n *\n * @param accountId - The account ID.\n * @throws If the account ID is not being tracked.\n */\n async updateTransactionsForAccount(accountId: string) {\n this.assertBeingTracked(accountId);\n\n const info = this.#transactions[accountId];\n const isOutdated = Date.now() - info.lastUpdated >= info.blockTime;\n const hasNoTransactionsYet = info.lastUpdated === 0;\n\n if (hasNoTransactionsYet || isOutdated) {\n await this.#updateTransactions(accountId, info.pagination);\n this.#transactions[accountId].lastUpdated = Date.now();\n }\n }\n\n /**\n * Update the transactions of all tracked accounts\n */\n async updateTransactions() {\n await Promise.allSettled(\n Object.keys(this.#transactions).map(async (accountId) => {\n await this.updateTransactionsForAccount(accountId);\n }),\n );\n }\n}\n"]}
|
package/dist/Poller.cjs
DELETED
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
3
|
-
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
4
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
5
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
6
|
-
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
7
|
-
};
|
|
8
|
-
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
9
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
10
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
11
|
-
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
12
|
-
};
|
|
13
|
-
var _Poller_interval, _Poller_callback, _Poller_handle;
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.Poller = void 0;
|
|
16
|
-
class Poller {
|
|
17
|
-
constructor(callback, interval) {
|
|
18
|
-
_Poller_interval.set(this, void 0);
|
|
19
|
-
_Poller_callback.set(this, void 0);
|
|
20
|
-
_Poller_handle.set(this, undefined);
|
|
21
|
-
__classPrivateFieldSet(this, _Poller_interval, interval, "f");
|
|
22
|
-
__classPrivateFieldSet(this, _Poller_callback, callback, "f");
|
|
23
|
-
}
|
|
24
|
-
start() {
|
|
25
|
-
if (__classPrivateFieldGet(this, _Poller_handle, "f")) {
|
|
26
|
-
return;
|
|
27
|
-
}
|
|
28
|
-
__classPrivateFieldSet(this, _Poller_handle, setInterval(__classPrivateFieldGet(this, _Poller_callback, "f"), __classPrivateFieldGet(this, _Poller_interval, "f")), "f");
|
|
29
|
-
}
|
|
30
|
-
stop() {
|
|
31
|
-
if (!__classPrivateFieldGet(this, _Poller_handle, "f")) {
|
|
32
|
-
return;
|
|
33
|
-
}
|
|
34
|
-
clearInterval(__classPrivateFieldGet(this, _Poller_handle, "f"));
|
|
35
|
-
__classPrivateFieldSet(this, _Poller_handle, undefined, "f");
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
exports.Poller = Poller;
|
|
39
|
-
_Poller_interval = new WeakMap(), _Poller_callback = new WeakMap(), _Poller_handle = new WeakMap();
|
|
40
|
-
//# sourceMappingURL=Poller.cjs.map
|
package/dist/Poller.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Poller.cjs","sourceRoot":"","sources":["../src/Poller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,MAAa,MAAM;IAOjB,YAAY,QAAoB,EAAE,QAAgB;QANzC,mCAAkB;QAElB,mCAAsB;QAE/B,yBAAsC,SAAS,EAAC;QAG9C,uBAAA,IAAI,oBAAa,QAAQ,MAAA,CAAC;QAC1B,uBAAA,IAAI,oBAAa,QAAQ,MAAA,CAAC;IAC5B,CAAC;IAED,KAAK;QACH,IAAI,uBAAA,IAAI,sBAAQ,EAAE;YAChB,OAAO;SACR;QAED,uBAAA,IAAI,kBAAW,WAAW,CAAC,uBAAA,IAAI,wBAAU,EAAE,uBAAA,IAAI,wBAAU,CAAC,MAAA,CAAC;IAC7D,CAAC;IAED,IAAI;QACF,IAAI,CAAC,uBAAA,IAAI,sBAAQ,EAAE;YACjB,OAAO;SACR;QACD,aAAa,CAAC,uBAAA,IAAI,sBAAQ,CAAC,CAAC;QAC5B,uBAAA,IAAI,kBAAW,SAAS,MAAA,CAAC;IAC3B,CAAC;CACF;AA3BD,wBA2BC","sourcesContent":["export class Poller {\n readonly #interval: number;\n\n readonly #callback: () => void;\n\n #handle: NodeJS.Timeout | undefined = undefined;\n\n constructor(callback: () => void, interval: number) {\n this.#interval = interval;\n this.#callback = callback;\n }\n\n start() {\n if (this.#handle) {\n return;\n }\n\n this.#handle = setInterval(this.#callback, this.#interval);\n }\n\n stop() {\n if (!this.#handle) {\n return;\n }\n clearInterval(this.#handle);\n this.#handle = undefined;\n }\n}\n"]}
|
package/dist/Poller.d.cts
DELETED
package/dist/Poller.d.cts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Poller.d.cts","sourceRoot":"","sources":["../src/Poller.ts"],"names":[],"mappings":"AAAA,qBAAa,MAAM;;gBAOL,QAAQ,EAAE,MAAM,IAAI,EAAE,QAAQ,EAAE,MAAM;IAKlD,KAAK;IAQL,IAAI;CAOL"}
|
package/dist/Poller.d.mts
DELETED
package/dist/Poller.d.mts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Poller.d.mts","sourceRoot":"","sources":["../src/Poller.ts"],"names":[],"mappings":"AAAA,qBAAa,MAAM;;gBAOL,QAAQ,EAAE,MAAM,IAAI,EAAE,QAAQ,EAAE,MAAM;IAKlD,KAAK;IAQL,IAAI;CAOL"}
|
package/dist/Poller.mjs
DELETED
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
2
|
-
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
3
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
4
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
5
|
-
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
6
|
-
};
|
|
7
|
-
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
8
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
9
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
10
|
-
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
11
|
-
};
|
|
12
|
-
var _Poller_interval, _Poller_callback, _Poller_handle;
|
|
13
|
-
export class Poller {
|
|
14
|
-
constructor(callback, interval) {
|
|
15
|
-
_Poller_interval.set(this, void 0);
|
|
16
|
-
_Poller_callback.set(this, void 0);
|
|
17
|
-
_Poller_handle.set(this, undefined);
|
|
18
|
-
__classPrivateFieldSet(this, _Poller_interval, interval, "f");
|
|
19
|
-
__classPrivateFieldSet(this, _Poller_callback, callback, "f");
|
|
20
|
-
}
|
|
21
|
-
start() {
|
|
22
|
-
if (__classPrivateFieldGet(this, _Poller_handle, "f")) {
|
|
23
|
-
return;
|
|
24
|
-
}
|
|
25
|
-
__classPrivateFieldSet(this, _Poller_handle, setInterval(__classPrivateFieldGet(this, _Poller_callback, "f"), __classPrivateFieldGet(this, _Poller_interval, "f")), "f");
|
|
26
|
-
}
|
|
27
|
-
stop() {
|
|
28
|
-
if (!__classPrivateFieldGet(this, _Poller_handle, "f")) {
|
|
29
|
-
return;
|
|
30
|
-
}
|
|
31
|
-
clearInterval(__classPrivateFieldGet(this, _Poller_handle, "f"));
|
|
32
|
-
__classPrivateFieldSet(this, _Poller_handle, undefined, "f");
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
_Poller_interval = new WeakMap(), _Poller_callback = new WeakMap(), _Poller_handle = new WeakMap();
|
|
36
|
-
//# sourceMappingURL=Poller.mjs.map
|
package/dist/Poller.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Poller.mjs","sourceRoot":"","sources":["../src/Poller.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,MAAM,OAAO,MAAM;IAOjB,YAAY,QAAoB,EAAE,QAAgB;QANzC,mCAAkB;QAElB,mCAAsB;QAE/B,yBAAsC,SAAS,EAAC;QAG9C,uBAAA,IAAI,oBAAa,QAAQ,MAAA,CAAC;QAC1B,uBAAA,IAAI,oBAAa,QAAQ,MAAA,CAAC;IAC5B,CAAC;IAED,KAAK;QACH,IAAI,uBAAA,IAAI,sBAAQ,EAAE;YAChB,OAAO;SACR;QAED,uBAAA,IAAI,kBAAW,WAAW,CAAC,uBAAA,IAAI,wBAAU,EAAE,uBAAA,IAAI,wBAAU,CAAC,MAAA,CAAC;IAC7D,CAAC;IAED,IAAI;QACF,IAAI,CAAC,uBAAA,IAAI,sBAAQ,EAAE;YACjB,OAAO;SACR;QACD,aAAa,CAAC,uBAAA,IAAI,sBAAQ,CAAC,CAAC;QAC5B,uBAAA,IAAI,kBAAW,SAAS,MAAA,CAAC;IAC3B,CAAC;CACF","sourcesContent":["export class Poller {\n readonly #interval: number;\n\n readonly #callback: () => void;\n\n #handle: NodeJS.Timeout | undefined = undefined;\n\n constructor(callback: () => void, interval: number) {\n this.#interval = interval;\n this.#callback = callback;\n }\n\n start() {\n if (this.#handle) {\n return;\n }\n\n this.#handle = setInterval(this.#callback, this.#interval);\n }\n\n stop() {\n if (!this.#handle) {\n return;\n }\n clearInterval(this.#handle);\n this.#handle = undefined;\n }\n}\n"]}
|