@aztec/bot 0.76.4 → 0.77.0-testnet-ignition.21
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/dest/bot.d.ts +4 -4
- package/dest/bot.d.ts.map +1 -1
- package/dest/bot.js +45 -24
- package/dest/config.d.ts +42 -20
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +72 -52
- package/dest/factory.d.ts +7 -2
- package/dest/factory.d.ts.map +1 -1
- package/dest/factory.js +131 -59
- package/dest/index.d.ts +1 -1
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +1 -2
- package/dest/interface.d.ts +1 -1
- package/dest/interface.d.ts.map +1 -1
- package/dest/interface.js +1 -2
- package/dest/rpc.d.ts +2 -2
- package/dest/rpc.d.ts.map +1 -1
- package/dest/rpc.js +7 -5
- package/dest/runner.d.ts +1 -1
- package/dest/runner.d.ts.map +1 -1
- package/dest/runner.js +151 -156
- package/dest/utils.d.ts +3 -3
- package/dest/utils.d.ts.map +1 -1
- package/dest/utils.js +5 -4
- package/package.json +13 -14
- package/src/bot.ts +8 -9
- package/src/config.ts +38 -13
- package/src/factory.ts +101 -19
- package/src/index.ts +1 -1
- package/src/interface.ts +1 -1
- package/src/rpc.ts +2 -2
- package/src/runner.ts +1 -1
- package/src/utils.ts +3 -3
package/dest/factory.js
CHANGED
|
@@ -1,20 +1,30 @@
|
|
|
1
1
|
import { getSchnorrAccount } from '@aztec/accounts/schnorr';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { getDeployedTestAccountsWallets, getInitialTestAccounts } from '@aztec/accounts/testing';
|
|
3
|
+
import { BatchCall, FeeJuicePaymentMethodWithClaim, L1FeeJuicePortalManager, createLogger, createPXEClient, retryUntil } from '@aztec/aztec.js';
|
|
4
|
+
import { createEthereumChain, createL1Clients } from '@aztec/ethereum';
|
|
5
|
+
import { Fr } from '@aztec/foundation/fields';
|
|
4
6
|
import { EasyPrivateTokenContract } from '@aztec/noir-contracts.js/EasyPrivateToken';
|
|
5
7
|
import { TokenContract } from '@aztec/noir-contracts.js/Token';
|
|
8
|
+
import { deriveSigningKey } from '@aztec/stdlib/keys';
|
|
6
9
|
import { makeTracedFetch } from '@aztec/telemetry-client';
|
|
7
10
|
import { SupportedTokenContracts, getVersions } from './config.js';
|
|
8
11
|
import { getBalances, getPrivateBalance, isStandardTokenContract } from './utils.js';
|
|
9
12
|
const MINT_BALANCE = 1e12;
|
|
10
13
|
const MIN_BALANCE = 1e3;
|
|
11
14
|
export class BotFactory {
|
|
12
|
-
|
|
15
|
+
config;
|
|
16
|
+
pxe;
|
|
17
|
+
node;
|
|
18
|
+
log;
|
|
19
|
+
constructor(config, dependencies = {}){
|
|
13
20
|
this.config = config;
|
|
14
21
|
this.log = createLogger('bot');
|
|
15
22
|
if (config.flushSetupTransactions && !dependencies.node) {
|
|
16
23
|
throw new Error(`Either a node client or node url must be provided if transaction flushing is requested`);
|
|
17
24
|
}
|
|
25
|
+
if (config.senderPrivateKey && !dependencies.node) {
|
|
26
|
+
throw new Error(`Either a node client or node url must be provided for bridging L1 fee juice to deploy an account with private key`);
|
|
27
|
+
}
|
|
18
28
|
if (!dependencies.pxe && !config.pxeUrl) {
|
|
19
29
|
throw new Error(`Either a PXE client or a PXE URL must be provided`);
|
|
20
30
|
}
|
|
@@ -25,115 +35,142 @@ export class BotFactory {
|
|
|
25
35
|
return;
|
|
26
36
|
}
|
|
27
37
|
this.log.info(`Using remote PXE at ${config.pxeUrl}`);
|
|
28
|
-
this.pxe = createPXEClient(config.pxeUrl, getVersions(), makeTracedFetch([
|
|
38
|
+
this.pxe = createPXEClient(config.pxeUrl, getVersions(), makeTracedFetch([
|
|
39
|
+
1,
|
|
40
|
+
2,
|
|
41
|
+
3
|
|
42
|
+
], false));
|
|
29
43
|
}
|
|
30
44
|
/**
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
async setup() {
|
|
45
|
+
* Initializes a new bot by setting up the sender account, registering the recipient,
|
|
46
|
+
* deploying the token contract, and minting tokens if necessary.
|
|
47
|
+
*/ async setup() {
|
|
35
48
|
const recipient = await this.registerRecipient();
|
|
36
49
|
const wallet = await this.setupAccount();
|
|
37
50
|
const token = await this.setupToken(wallet);
|
|
38
51
|
await this.mintTokens(token);
|
|
39
|
-
return {
|
|
52
|
+
return {
|
|
53
|
+
wallet,
|
|
54
|
+
token,
|
|
55
|
+
pxe: this.pxe,
|
|
56
|
+
recipient
|
|
57
|
+
};
|
|
40
58
|
}
|
|
41
59
|
/**
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
60
|
+
* Checks if the sender account contract is initialized, and initializes it if necessary.
|
|
61
|
+
* @returns The sender wallet.
|
|
62
|
+
*/ async setupAccount() {
|
|
63
|
+
if (this.config.senderPrivateKey) {
|
|
64
|
+
return await this.setupAccountWithPrivateKey(this.config.senderPrivateKey);
|
|
65
|
+
} else {
|
|
66
|
+
return await this.setupTestAccount();
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
async setupAccountWithPrivateKey(privateKey) {
|
|
46
70
|
const salt = Fr.ONE;
|
|
47
|
-
const signingKey = deriveSigningKey(
|
|
48
|
-
const account = await getSchnorrAccount(this.pxe,
|
|
71
|
+
const signingKey = deriveSigningKey(privateKey);
|
|
72
|
+
const account = await getSchnorrAccount(this.pxe, privateKey, signingKey, salt);
|
|
49
73
|
const isInit = (await this.pxe.getContractMetadata(account.getAddress())).isContractInitialized;
|
|
50
74
|
if (isInit) {
|
|
51
75
|
this.log.info(`Account at ${account.getAddress().toString()} already initialized`);
|
|
52
76
|
const wallet = await account.register();
|
|
53
77
|
return wallet;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
this.log.info(`
|
|
57
|
-
const
|
|
78
|
+
} else {
|
|
79
|
+
const address = account.getAddress();
|
|
80
|
+
this.log.info(`Deploying account at ${address}`);
|
|
81
|
+
const claim = await this.bridgeL1FeeJuice(address, 10n ** 22n);
|
|
82
|
+
const wallet = await account.getWallet();
|
|
83
|
+
const paymentMethod = new FeeJuicePaymentMethodWithClaim(wallet, claim);
|
|
84
|
+
const sentTx = account.deploy({
|
|
85
|
+
fee: {
|
|
86
|
+
paymentMethod
|
|
87
|
+
}
|
|
88
|
+
});
|
|
58
89
|
const txHash = await sentTx.getTxHash();
|
|
59
90
|
this.log.info(`Sent tx with hash ${txHash.toString()}`);
|
|
60
|
-
|
|
61
|
-
this.log.verbose('Flushing transactions');
|
|
62
|
-
await this.node.flushTxs();
|
|
63
|
-
}
|
|
91
|
+
await this.tryFlushTxs();
|
|
64
92
|
this.log.verbose('Waiting for account deployment to settle');
|
|
65
|
-
await sentTx.wait({
|
|
66
|
-
|
|
93
|
+
await sentTx.wait({
|
|
94
|
+
timeout: this.config.txMinedWaitSeconds
|
|
95
|
+
});
|
|
96
|
+
this.log.info(`Account deployed at ${address}`);
|
|
97
|
+
return wallet;
|
|
67
98
|
}
|
|
68
99
|
}
|
|
100
|
+
async setupTestAccount() {
|
|
101
|
+
let [wallet] = await getDeployedTestAccountsWallets(this.pxe);
|
|
102
|
+
if (wallet) {
|
|
103
|
+
this.log.info(`Using funded test account: ${wallet.getAddress()}`);
|
|
104
|
+
} else {
|
|
105
|
+
this.log.info('Registering funded test account');
|
|
106
|
+
const [account] = await getInitialTestAccounts();
|
|
107
|
+
const manager = await getSchnorrAccount(this.pxe, account.secret, account.signingKey, account.salt);
|
|
108
|
+
wallet = await manager.register();
|
|
109
|
+
this.log.info(`Funded test account registered: ${wallet.getAddress()}`);
|
|
110
|
+
}
|
|
111
|
+
return wallet;
|
|
112
|
+
}
|
|
69
113
|
/**
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
async registerRecipient() {
|
|
114
|
+
* Registers the recipient for txs in the pxe.
|
|
115
|
+
*/ async registerRecipient() {
|
|
73
116
|
const recipient = await this.pxe.registerAccount(this.config.recipientEncryptionSecret, Fr.ONE);
|
|
74
117
|
return recipient.address;
|
|
75
118
|
}
|
|
76
119
|
/**
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
async setupToken(wallet) {
|
|
120
|
+
* Checks if the token contract is deployed and deploys it if necessary.
|
|
121
|
+
* @param wallet - Wallet to deploy the token contract from.
|
|
122
|
+
* @returns The TokenContract instance.
|
|
123
|
+
*/ async setupToken(wallet) {
|
|
82
124
|
let deploy;
|
|
83
|
-
const deployOpts = {
|
|
125
|
+
const deployOpts = {
|
|
126
|
+
contractAddressSalt: this.config.tokenSalt,
|
|
127
|
+
universalDeploy: true
|
|
128
|
+
};
|
|
84
129
|
if (this.config.contract === SupportedTokenContracts.TokenContract) {
|
|
85
130
|
deploy = TokenContract.deploy(wallet, wallet.getAddress(), 'BotToken', 'BOT', 18);
|
|
86
|
-
}
|
|
87
|
-
else if (this.config.contract === SupportedTokenContracts.EasyPrivateTokenContract) {
|
|
131
|
+
} else if (this.config.contract === SupportedTokenContracts.EasyPrivateTokenContract) {
|
|
88
132
|
deploy = EasyPrivateTokenContract.deploy(wallet, MINT_BALANCE, wallet.getAddress());
|
|
89
133
|
deployOpts.skipPublicDeployment = true;
|
|
90
134
|
deployOpts.skipClassRegistration = true;
|
|
91
135
|
deployOpts.skipInitialization = false;
|
|
92
136
|
deployOpts.skipPublicSimulation = true;
|
|
93
|
-
}
|
|
94
|
-
else {
|
|
137
|
+
} else {
|
|
95
138
|
throw new Error(`Unsupported token contract type: ${this.config.contract}`);
|
|
96
139
|
}
|
|
97
140
|
const address = (await deploy.getInstance(deployOpts)).address;
|
|
98
141
|
if ((await this.pxe.getContractMetadata(address)).isContractPubliclyDeployed) {
|
|
99
142
|
this.log.info(`Token at ${address.toString()} already deployed`);
|
|
100
143
|
return deploy.register();
|
|
101
|
-
}
|
|
102
|
-
else {
|
|
144
|
+
} else {
|
|
103
145
|
this.log.info(`Deploying token contract at ${address.toString()}`);
|
|
104
146
|
const sentTx = deploy.send(deployOpts);
|
|
105
147
|
const txHash = await sentTx.getTxHash();
|
|
106
148
|
this.log.info(`Sent tx with hash ${txHash.toString()}`);
|
|
107
|
-
|
|
108
|
-
this.log.verbose('Flushing transactions');
|
|
109
|
-
await this.node.flushTxs();
|
|
110
|
-
}
|
|
149
|
+
await this.tryFlushTxs();
|
|
111
150
|
this.log.verbose('Waiting for token setup to settle');
|
|
112
|
-
return sentTx.deployed({
|
|
151
|
+
return sentTx.deployed({
|
|
152
|
+
timeout: this.config.txMinedWaitSeconds
|
|
153
|
+
});
|
|
113
154
|
}
|
|
114
155
|
}
|
|
115
156
|
/**
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
async mintTokens(token) {
|
|
157
|
+
* Mints private and public tokens for the sender if their balance is below the minimum.
|
|
158
|
+
* @param token - Token contract.
|
|
159
|
+
*/ async mintTokens(token) {
|
|
120
160
|
const sender = token.wallet.getAddress();
|
|
121
161
|
const isStandardToken = isStandardTokenContract(token);
|
|
122
162
|
let privateBalance = 0n;
|
|
123
163
|
let publicBalance = 0n;
|
|
124
164
|
if (isStandardToken) {
|
|
125
165
|
({ privateBalance, publicBalance } = await getBalances(token, sender));
|
|
126
|
-
}
|
|
127
|
-
else {
|
|
166
|
+
} else {
|
|
128
167
|
privateBalance = await getPrivateBalance(token, sender);
|
|
129
168
|
}
|
|
130
169
|
const calls = [];
|
|
131
170
|
if (privateBalance < MIN_BALANCE) {
|
|
132
171
|
this.log.info(`Minting private tokens for ${sender.toString()}`);
|
|
133
|
-
const from = sender; // we are setting from to sender here because
|
|
134
|
-
calls.push(isStandardToken
|
|
135
|
-
? await token.methods.mint_to_private(from, sender, MINT_BALANCE).request()
|
|
136
|
-
: await token.methods.mint(MINT_BALANCE, sender).request());
|
|
172
|
+
const from = sender; // we are setting from to sender here because we need a sender to calculate the tag
|
|
173
|
+
calls.push(isStandardToken ? await token.methods.mint_to_private(from, sender, MINT_BALANCE).request() : await token.methods.mint(MINT_BALANCE, sender).request());
|
|
137
174
|
}
|
|
138
175
|
if (isStandardToken && publicBalance < MIN_BALANCE) {
|
|
139
176
|
this.log.info(`Minting public tokens for ${sender.toString()}`);
|
|
@@ -146,12 +183,47 @@ export class BotFactory {
|
|
|
146
183
|
const sentTx = new BatchCall(token.wallet, calls).send();
|
|
147
184
|
const txHash = await sentTx.getTxHash();
|
|
148
185
|
this.log.info(`Sent tx with hash ${txHash.toString()}`);
|
|
186
|
+
await this.tryFlushTxs();
|
|
187
|
+
this.log.verbose('Waiting for token mint to settle');
|
|
188
|
+
await sentTx.wait({
|
|
189
|
+
timeout: this.config.txMinedWaitSeconds
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
async bridgeL1FeeJuice(recipient, amount) {
|
|
193
|
+
const l1RpcUrls = this.config.l1RpcUrls;
|
|
194
|
+
if (!l1RpcUrls?.length) {
|
|
195
|
+
throw new Error('L1 Rpc url is required to bridge the fee juice to fund the deployment of the account.');
|
|
196
|
+
}
|
|
197
|
+
const mnemonicOrPrivateKey = this.config.l1PrivateKey || this.config.l1Mnemonic;
|
|
198
|
+
if (!mnemonicOrPrivateKey) {
|
|
199
|
+
throw new Error('Either a mnemonic or private key of an L1 account is required to bridge the fee juice to fund the deployment of the account.');
|
|
200
|
+
}
|
|
201
|
+
const { l1ChainId } = await this.pxe.getNodeInfo();
|
|
202
|
+
const chain = createEthereumChain(l1RpcUrls, l1ChainId);
|
|
203
|
+
const { publicClient, walletClient } = createL1Clients(chain.rpcUrls, mnemonicOrPrivateKey, chain.chainInfo);
|
|
204
|
+
const portal = await L1FeeJuicePortalManager.new(this.pxe, publicClient, walletClient, this.log);
|
|
205
|
+
const claim = await portal.bridgeTokensPublic(recipient, amount, true);
|
|
206
|
+
const isSynced = async ()=>await this.pxe.isL1ToL2MessageSynced(Fr.fromHexString(claim.messageHash));
|
|
207
|
+
await retryUntil(isSynced, `message ${claim.messageHash} sync`, 24, 1);
|
|
208
|
+
this.log.info(`Created a claim for ${amount} L1 fee juice to ${recipient}.`, claim);
|
|
209
|
+
// Progress by 2 L2 blocks so that the l1ToL2Message added above will be available to use on L2.
|
|
210
|
+
await this.advanceL2Block();
|
|
211
|
+
await this.advanceL2Block();
|
|
212
|
+
return claim;
|
|
213
|
+
}
|
|
214
|
+
async advanceL2Block() {
|
|
215
|
+
const initialBlockNumber = await this.node.getBlockNumber();
|
|
216
|
+
await this.tryFlushTxs();
|
|
217
|
+
await retryUntil(async ()=>await this.node.getBlockNumber() >= initialBlockNumber + 1);
|
|
218
|
+
}
|
|
219
|
+
async tryFlushTxs() {
|
|
149
220
|
if (this.config.flushSetupTransactions) {
|
|
150
221
|
this.log.verbose('Flushing transactions');
|
|
151
|
-
|
|
222
|
+
try {
|
|
223
|
+
await this.node.flushTxs();
|
|
224
|
+
} catch (err) {
|
|
225
|
+
this.log.error(`Failed to flush transactions: ${err}`);
|
|
226
|
+
}
|
|
152
227
|
}
|
|
153
|
-
this.log.verbose('Waiting for token mint to settle');
|
|
154
|
-
await sentTx.wait({ timeout: this.config.txMinedWaitSeconds });
|
|
155
228
|
}
|
|
156
229
|
}
|
|
157
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"factory.js","sourceRoot":"","sources":["../src/factory.ts"],"names":[],"mappings":"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"}
|
package/dest/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export { Bot } from './bot.js';
|
|
2
2
|
export { BotRunner } from './runner.js';
|
|
3
|
-
export { BotConfig, getBotConfigFromEnv, getBotDefaultConfig, botConfigMappings, SupportedTokenContracts, } from './config.js';
|
|
3
|
+
export { type BotConfig, getBotConfigFromEnv, getBotDefaultConfig, botConfigMappings, SupportedTokenContracts, } from './config.js';
|
|
4
4
|
export { createBotRunnerRpcServer, getBotRunnerApiHandler } from './rpc.js';
|
|
5
5
|
export * from './interface.js';
|
|
6
6
|
//# sourceMappingURL=index.d.ts.map
|
package/dest/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EACL,SAAS,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EACL,KAAK,SAAS,EACd,mBAAmB,EACnB,mBAAmB,EACnB,iBAAiB,EACjB,uBAAuB,GACxB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,wBAAwB,EAAE,sBAAsB,EAAE,MAAM,UAAU,CAAC;AAC5E,cAAc,gBAAgB,CAAC"}
|
package/dest/index.js
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
export { Bot } from './bot.js';
|
|
2
2
|
export { BotRunner } from './runner.js';
|
|
3
|
-
export { getBotConfigFromEnv, getBotDefaultConfig, botConfigMappings, SupportedTokenContracts
|
|
3
|
+
export { getBotConfigFromEnv, getBotDefaultConfig, botConfigMappings, SupportedTokenContracts } from './config.js';
|
|
4
4
|
export { createBotRunnerRpcServer, getBotRunnerApiHandler } from './rpc.js';
|
|
5
5
|
export * from './interface.js';
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUMvQixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ3hDLE9BQU8sRUFFTCxtQkFBbUIsRUFDbkIsbUJBQW1CLEVBQ25CLGlCQUFpQixFQUNqQix1QkFBdUIsR0FDeEIsTUFBTSxhQUFhLENBQUM7QUFDckIsT0FBTyxFQUFFLHdCQUF3QixFQUFFLHNCQUFzQixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQzVFLGNBQWMsZ0JBQWdCLENBQUMifQ==
|
package/dest/interface.d.ts
CHANGED
package/dest/interface.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../src/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../src/interface.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAI1D,OAAO,EAAE,KAAK,SAAS,EAAmB,MAAM,aAAa,CAAC;AAE9D,MAAM,WAAW,YAAY;IAC3B,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACvB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACtB,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACrB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACvB,SAAS,IAAI,OAAO,CAAC,SAAS,CAAC,CAAC;IAChC,MAAM,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC1C;AAED,eAAO,MAAM,kBAAkB,EAAE,YAAY,CAAC,YAAY,CAOzD,CAAC"}
|
package/dest/interface.js
CHANGED
|
@@ -6,6 +6,5 @@ export const BotRunnerApiSchema = {
|
|
|
6
6
|
run: z.function().args().returns(z.void()),
|
|
7
7
|
setup: z.function().args().returns(z.void()),
|
|
8
8
|
getConfig: z.function().args().returns(BotConfigSchema),
|
|
9
|
-
update: z.function().args(BotConfigSchema).returns(z.void())
|
|
9
|
+
update: z.function().args(BotConfigSchema).returns(z.void())
|
|
10
10
|
};
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2ludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsQ0FBQyxFQUFFLE1BQU0sS0FBSyxDQUFDO0FBRXhCLE9BQU8sRUFBa0IsZUFBZSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBVzlELE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUErQjtJQUM1RCxLQUFLLEVBQUUsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDNUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzNDLEdBQUcsRUFBRSxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsSUFBSSxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMxQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDNUMsU0FBUyxFQUFFLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxPQUFPLENBQUMsZUFBZSxDQUFDO0lBQ3ZELE1BQU0sRUFBRSxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUM7Q0FDN0QsQ0FBQyJ9
|
package/dest/rpc.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import type { ApiHandler } from '@aztec/foundation/json-rpc/server';
|
|
2
|
+
import type { BotRunner } from './runner.js';
|
|
3
3
|
/**
|
|
4
4
|
* Wraps a bot runner with a JSON RPC HTTP server.
|
|
5
5
|
* @param botRunner - The BotRunner.
|
package/dest/rpc.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rpc.d.ts","sourceRoot":"","sources":["../src/rpc.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"rpc.d.ts","sourceRoot":"","sources":["../src/rpc.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mCAAmC,CAAC;AAIpE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAE7C;;;;GAIG;AACH,wBAAgB,wBAAwB,CAAC,SAAS,EAAE,SAAS,QAK5D;AAED,wBAAgB,sBAAsB,CAAC,SAAS,EAAE,SAAS,GAAG,UAAU,CAEvE"}
|
package/dest/rpc.js
CHANGED
|
@@ -4,14 +4,16 @@ import { BotRunnerApiSchema } from './interface.js';
|
|
|
4
4
|
* Wraps a bot runner with a JSON RPC HTTP server.
|
|
5
5
|
* @param botRunner - The BotRunner.
|
|
6
6
|
* @returns An JSON-RPC HTTP server
|
|
7
|
-
*/
|
|
8
|
-
export function createBotRunnerRpcServer(botRunner) {
|
|
7
|
+
*/ export function createBotRunnerRpcServer(botRunner) {
|
|
9
8
|
createTracedJsonRpcServer(botRunner, BotRunnerApiSchema, {
|
|
10
9
|
http200OnError: false,
|
|
11
|
-
healthCheck: botRunner.isHealthy.bind(botRunner)
|
|
10
|
+
healthCheck: botRunner.isHealthy.bind(botRunner)
|
|
12
11
|
});
|
|
13
12
|
}
|
|
14
13
|
export function getBotRunnerApiHandler(botRunner) {
|
|
15
|
-
return [
|
|
14
|
+
return [
|
|
15
|
+
botRunner,
|
|
16
|
+
BotRunnerApiSchema,
|
|
17
|
+
botRunner.isHealthy.bind(botRunner)
|
|
18
|
+
];
|
|
16
19
|
}
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnBjLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3JwYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUVwRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUdwRDs7OztHQUlHO0FBQ0gsTUFBTSxVQUFVLHdCQUF3QixDQUFDLFNBQW9CO0lBQzNELHlCQUF5QixDQUFDLFNBQVMsRUFBRSxrQkFBa0IsRUFBRTtRQUN2RCxjQUFjLEVBQUUsS0FBSztRQUNyQixXQUFXLEVBQUUsU0FBUyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO0tBQ2pELENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxNQUFNLFVBQVUsc0JBQXNCLENBQUMsU0FBb0I7SUFDekQsT0FBTyxDQUFDLFNBQVMsRUFBRSxrQkFBa0IsRUFBRSxTQUFTLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO0FBQzlFLENBQUMifQ==
|
package/dest/runner.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { type AztecNode, type PXE } from '@aztec/aztec.js';
|
|
2
2
|
import { type TelemetryClient, type Traceable, type Tracer } from '@aztec/telemetry-client';
|
|
3
3
|
import { type BotConfig } from './config.js';
|
|
4
|
-
import {
|
|
4
|
+
import type { BotRunnerApi } from './interface.js';
|
|
5
5
|
export declare class BotRunner implements BotRunnerApi, Traceable {
|
|
6
6
|
#private;
|
|
7
7
|
private config;
|
package/dest/runner.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runner.d.ts","sourceRoot":"","sources":["../src/runner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,GAAG,EAAuC,MAAM,iBAAiB,CAAC;AAEhG,OAAO,EAAE,KAAK,eAAe,EAAE,KAAK,SAAS,EAAE,KAAK,MAAM,EAA8B,MAAM,yBAAyB,CAAC;AAGxH,OAAO,EAAE,KAAK,SAAS,EAAe,MAAM,aAAa,CAAC;AAC1D,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"runner.d.ts","sourceRoot":"","sources":["../src/runner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,GAAG,EAAuC,MAAM,iBAAiB,CAAC;AAEhG,OAAO,EAAE,KAAK,eAAe,EAAE,KAAK,SAAS,EAAE,KAAK,MAAM,EAA8B,MAAM,yBAAyB,CAAC;AAGxH,OAAO,EAAE,KAAK,SAAS,EAAe,MAAM,aAAa,CAAC;AAC1D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAEnD,qBAAa,SAAU,YAAW,YAAY,EAAE,SAAS;;IAYrD,OAAO,CAAC,MAAM;IAXhB,OAAO,CAAC,GAAG,CAAuB;IAClC,OAAO,CAAC,GAAG,CAAC,CAAe;IAC3B,OAAO,CAAC,GAAG,CAAC,CAAM;IAClB,OAAO,CAAC,IAAI,CAAY;IACxB,OAAO,CAAC,cAAc,CAAiB;IACvC,OAAO,CAAC,iBAAiB,CAAK;IAC9B,OAAO,CAAC,OAAO,CAAQ;IAEvB,SAAgB,MAAM,EAAE,MAAM,CAAC;gBAGrB,MAAM,EAAE,SAAS,EACzB,YAAY,EAAE;QAAE,GAAG,CAAC,EAAE,GAAG,CAAC;QAAC,IAAI,CAAC,EAAE,SAAS,CAAC;QAAC,SAAS,EAAE,eAAe,CAAA;KAAE;IAY3E,6EAA6E;IAChE,KAAK;YAOJ,OAAO;IAMrB;;;OAGG;IACU,KAAK;IAQlB;;OAEG;IACU,IAAI;IAQV,SAAS;IAIhB,0CAA0C;IACnC,SAAS;IAIhB;;;OAGG;IACU,MAAM,CAAC,MAAM,EAAE,SAAS;IAerC;;;OAGG;IACU,GAAG;IAwBhB,qDAAqD;IAC9C,SAAS;CAuCjB"}
|