@rocketh/deploy 0.10.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,264 @@
1
+ import { DeploymentConstruction, Deployment } from 'rocketh';
2
+ import { Chain, ContractFunctionName, ContractFunctionArgs, DecodeFunctionResultReturnType, WriteContractParameters, ReadContractParameters } from 'viem';
3
+
4
+ type Register = {};
5
+ type ResolvedRegister = {
6
+ /**
7
+ * TypeScript type to use for `address` values
8
+ * @default `0x${string}`
9
+ */
10
+ AddressType: Register extends {
11
+ AddressType: infer type;
12
+ } ? type : DefaultRegister['AddressType'];
13
+ /**
14
+ * TypeScript type to use for `int<M>` and `uint<M>` values, where `M > 48`
15
+ * @default bigint
16
+ */
17
+ BigIntType: Register extends {
18
+ BigIntType: infer type;
19
+ } ? type : DefaultRegister['BigIntType'];
20
+ /**
21
+ * TypeScript type to use for `bytes` values
22
+ * @default { inputs: `0x${string}`; outputs: `0x${string}`; }
23
+ */
24
+ BytesType: Register extends {
25
+ BytesType: infer type extends {
26
+ inputs: unknown;
27
+ outputs: unknown;
28
+ };
29
+ } ? type : DefaultRegister['BytesType'];
30
+ /**
31
+ * TypeScript type to use for `int<M>` and `uint<M>` values, where `M <= 48`
32
+ * @default number
33
+ */
34
+ IntType: Register extends {
35
+ IntType: infer type;
36
+ } ? type : DefaultRegister['IntType'];
37
+ /**
38
+ * Maximum depth for nested array types (e.g. string[][])
39
+ *
40
+ * Note: You probably only want to set this to a specific number if parsed types are returning as `unknown`
41
+ * and you want to figure out why. If you set this, you should probably also reduce `FixedArrayMaxLength`.
42
+ *
43
+ * @default false
44
+ */
45
+ ArrayMaxDepth: Register extends {
46
+ ArrayMaxDepth: infer type extends number | false;
47
+ } ? type : DefaultRegister['ArrayMaxDepth'];
48
+ /**
49
+ * Lower bound for fixed array length
50
+ * @default 1
51
+ */
52
+ FixedArrayMinLength: Register extends {
53
+ FixedArrayMinLength: infer type extends number;
54
+ } ? type : DefaultRegister['FixedArrayMinLength'];
55
+ /**
56
+ * Upper bound for fixed array length
57
+ * @default 99
58
+ */
59
+ FixedArrayMaxLength: Register extends {
60
+ FixedArrayMaxLength: infer type extends number;
61
+ } ? type : DefaultRegister['FixedArrayMaxLength'];
62
+ /**
63
+ * When set, validates {@link AbiParameter}'s `type` against {@link AbiType}
64
+ *
65
+ * Note: You probably only want to set this to `true` if parsed types are returning as `unknown`
66
+ * and you want to figure out why.
67
+ *
68
+ * @default false
69
+ */
70
+ StrictAbiType: Register extends {
71
+ StrictAbiType: infer type extends boolean;
72
+ } ? type : DefaultRegister['StrictAbiType'];
73
+ };
74
+ type DefaultRegister = {
75
+ /** Maximum depth for nested array types (e.g. string[][]) */
76
+ ArrayMaxDepth: false;
77
+ /** Lower bound for fixed array length */
78
+ FixedArrayMinLength: 1;
79
+ /** Upper bound for fixed array length */
80
+ FixedArrayMaxLength: 99;
81
+ /** TypeScript type to use for `address` values */
82
+ AddressType: `0x${string}`;
83
+ /** TypeScript type to use for `bytes` values */
84
+ BytesType: {
85
+ /** TypeScript type to use for `bytes` input values */
86
+ inputs: `0x${string}`;
87
+ /** TypeScript type to use for `bytes` output values */
88
+ outputs: `0x${string}`;
89
+ };
90
+ /** TypeScript type to use for `int<M>` and `uint<M>` values, where `M > 48` */
91
+ BigIntType: bigint;
92
+ /** TypeScript type to use for `int<M>` and `uint<M>` values, where `M <= 48` */
93
+ IntType: number;
94
+ /** When set, validates {@link AbiParameter}'s `type` against {@link AbiType} */
95
+ StrictAbiType: false;
96
+ };
97
+
98
+ /**
99
+ * Combines members of an intersection into a readable type.
100
+ *
101
+ * @link https://twitter.com/mattpocockuk/status/1622730173446557697?s=20&t=NdpAcmEFXY01xkqU3KO0Mg
102
+ * @example
103
+ * type Result = Pretty<{ a: string } | { b: string } | { c: number, d: bigint }>
104
+ * // ^? type Result = { a: string; b: string; c: number; d: bigint }
105
+ */
106
+ type Pretty<T> = {
107
+ [K in keyof T]: T[K];
108
+ } & unknown;
109
+ /**
110
+ * Creates range between two positive numbers using [tail recursion](https://www.typescriptlang.org/docs/handbook/release-notes/typescript-4-5.html#tail-recursion-elimination-on-conditional-types).
111
+ *
112
+ * @param Start - Number to start range
113
+ * @param Stop - Number to end range
114
+ * @returns Array with inclusive range from {@link Start} to {@link Stop}
115
+ *
116
+ * @example
117
+ * type Result = Range<1, 3>
118
+ * // ^? type Result = [1, 2, 3]
119
+ */
120
+ type Range<Start extends number, Stop extends number, Result extends number[] = [], Padding extends 0[] = [], Current extends number = [...Padding, ...Result]['length'] & number> = Current extends Stop ? Current extends Start ? [Current] : Result extends [] ? [] : [...Result, Current] : Current extends Start ? Range<Start, Stop, [Current], Padding> : Result extends [] ? Range<Start, Stop, [], [...Padding, 0]> : Range<Start, Stop, [...Result, Current], Padding>;
121
+
122
+ type MBytes = '' | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32;
123
+ type MBits = '' | 8 | 16 | 24 | 32 | 40 | 48 | 56 | 64 | 72 | 80 | 88 | 96 | 104 | 112 | 120 | 128 | 136 | 144 | 152 | 160 | 168 | 176 | 184 | 192 | 200 | 208 | 216 | 224 | 232 | 240 | 248 | 256;
124
+ type SolidityAddress = 'address';
125
+ type SolidityBool = 'bool';
126
+ type SolidityBytes = `bytes${MBytes}`;
127
+ type SolidityFunction = 'function';
128
+ type SolidityString = 'string';
129
+ type SolidityTuple = 'tuple';
130
+ type SolidityInt = `${'u' | ''}int${MBits}`;
131
+ type SolidityFixedArrayRange = Range<ResolvedRegister['FixedArrayMinLength'], ResolvedRegister['FixedArrayMaxLength']>[number];
132
+ /**
133
+ * Recursively build arrays up to maximum depth
134
+ * or use a more broad type when maximum depth is switched "off"
135
+ */
136
+ type _BuildArrayTypes<T extends string, Depth extends readonly number[] = []> = ResolvedRegister['ArrayMaxDepth'] extends false ? `${T}[${string}]` : Depth['length'] extends ResolvedRegister['ArrayMaxDepth'] ? T : T extends `${any}[${SolidityFixedArrayRange | ''}]` ? _BuildArrayTypes<T | `${T}[${SolidityFixedArrayRange | ''}]`, [...Depth, 1]> : _BuildArrayTypes<`${T}[${SolidityFixedArrayRange | ''}]`, [...Depth, 1]>;
137
+ type SolidityArrayWithoutTuple = _BuildArrayTypes<SolidityAddress | SolidityBool | SolidityBytes | SolidityFunction | SolidityInt | SolidityString>;
138
+ type SolidityArrayWithTuple = _BuildArrayTypes<SolidityTuple>;
139
+ type SolidityArray = SolidityArrayWithoutTuple | SolidityArrayWithTuple;
140
+ type AbiType = SolidityArray | SolidityAddress | SolidityBool | SolidityBytes | SolidityFunction | SolidityInt | SolidityString | SolidityTuple;
141
+ type ResolvedAbiType = ResolvedRegister['StrictAbiType'] extends true ? AbiType : string;
142
+ type AbiInternalType = ResolvedAbiType | `address ${string}` | `contract ${string}` | `enum ${string}` | `struct ${string}`;
143
+ type AbiParameter = Pretty<{
144
+ type: ResolvedAbiType;
145
+ name?: string | undefined;
146
+ /** Representation used by Solidity compiler */
147
+ internalType?: AbiInternalType | undefined;
148
+ } & ({
149
+ type: Exclude<ResolvedAbiType, SolidityTuple | SolidityArrayWithTuple>;
150
+ } | {
151
+ type: SolidityTuple | SolidityArrayWithTuple;
152
+ components: readonly AbiParameter[];
153
+ })>;
154
+ type AbiEventParameter = Pretty<AbiParameter & {
155
+ indexed?: boolean | undefined;
156
+ }>;
157
+ /**
158
+ * State mutability for {@link AbiFunction}
159
+ *
160
+ * @see https://docs.soliditylang.org/en/latest/contracts.html#state-mutability
161
+ */
162
+ type AbiStateMutability = 'pure' | 'view' | 'nonpayable' | 'payable';
163
+ /** ABI ["function"](https://docs.soliditylang.org/en/latest/abi-spec.html#json) type */
164
+ type AbiFunction = {
165
+ type: 'function';
166
+ /**
167
+ * @deprecated use `pure` or `view` from {@link AbiStateMutability} instead
168
+ * @see https://github.com/ethereum/solidity/issues/992
169
+ */
170
+ constant?: boolean | undefined;
171
+ /**
172
+ * @deprecated Vyper used to provide gas estimates
173
+ * @see https://github.com/vyperlang/vyper/issues/2151
174
+ */
175
+ gas?: number | undefined;
176
+ inputs: readonly AbiParameter[];
177
+ name: string;
178
+ outputs: readonly AbiParameter[];
179
+ /**
180
+ * @deprecated use `payable` or `nonpayable` from {@link AbiStateMutability} instead
181
+ * @see https://github.com/ethereum/solidity/issues/992
182
+ */
183
+ payable?: boolean | undefined;
184
+ stateMutability: AbiStateMutability;
185
+ };
186
+ /** ABI ["constructor"](https://docs.soliditylang.org/en/latest/abi-spec.html#json) type */
187
+ type AbiConstructor = {
188
+ type: 'constructor';
189
+ inputs: readonly AbiParameter[];
190
+ /**
191
+ * @deprecated use `payable` or `nonpayable` from {@link AbiStateMutability} instead
192
+ * @see https://github.com/ethereum/solidity/issues/992
193
+ */
194
+ payable?: boolean | undefined;
195
+ stateMutability: Extract<AbiStateMutability, 'payable' | 'nonpayable'>;
196
+ };
197
+ /** ABI ["fallback"](https://docs.soliditylang.org/en/latest/abi-spec.html#json) type */
198
+ type AbiFallback = {
199
+ type: 'fallback';
200
+ inputs?: readonly [] | undefined;
201
+ /**
202
+ * @deprecated use `payable` or `nonpayable` from {@link AbiStateMutability} instead
203
+ * @see https://github.com/ethereum/solidity/issues/992
204
+ */
205
+ payable?: boolean | undefined;
206
+ stateMutability: Extract<AbiStateMutability, 'payable' | 'nonpayable'>;
207
+ };
208
+ /** ABI ["receive"](https://docs.soliditylang.org/en/latest/contracts.html#receive-ether-function) type */
209
+ type AbiReceive = {
210
+ type: 'receive';
211
+ stateMutability: Extract<AbiStateMutability, 'payable'>;
212
+ };
213
+ /** ABI ["event"](https://docs.soliditylang.org/en/latest/abi-spec.html#events) type */
214
+ type AbiEvent = {
215
+ type: 'event';
216
+ anonymous?: boolean | undefined;
217
+ inputs: readonly AbiEventParameter[];
218
+ name: string;
219
+ };
220
+ /** ABI ["error"](https://docs.soliditylang.org/en/latest/abi-spec.html#errors) type */
221
+ type AbiError = {
222
+ type: 'error';
223
+ inputs: readonly AbiParameter[];
224
+ name: string;
225
+ };
226
+ /**
227
+ * Contract [ABI Specification](https://docs.soliditylang.org/en/latest/abi-spec.html#json)
228
+ */
229
+ type Abi = readonly (AbiConstructor | AbiError | AbiEvent | AbiFallback | AbiFunction | AbiReceive)[];
230
+
231
+ type EIP1193DATA = `0x${string}`;
232
+
233
+ declare module 'rocketh' {
234
+ interface Environment {
235
+ deploy: DeployFunction;
236
+ execute: ExecuteFunction;
237
+ read: ReadFunction;
238
+ executeByName: ExecuteFunctionByName;
239
+ readByName: ReadFunctionByName;
240
+ }
241
+ }
242
+ type DeployFunction = <TAbi extends Abi, TChain extends Chain = Chain>(name: string, args: DeploymentConstruction<TAbi>, options?: DeployOptions) => Promise<Deployment<TAbi> & {
243
+ updated: boolean;
244
+ }>;
245
+ type ExecuteFunction = <TAbi extends Abi, TFunctionName extends ContractFunctionName<TAbi, 'nonpayable' | 'payable'>, TArgs extends ContractFunctionArgs<TAbi, 'nonpayable' | 'payable', TFunctionName> = ContractFunctionArgs<TAbi, 'nonpayable' | 'payable', TFunctionName>>(deployment: Deployment<TAbi>, args: ExecutionArgs<TAbi, TFunctionName, TArgs>) => Promise<EIP1193DATA>;
246
+ type ExecuteFunctionByName = <TAbi extends Abi, TFunctionName extends ContractFunctionName<TAbi, 'nonpayable' | 'payable'>, TArgs extends ContractFunctionArgs<TAbi, 'nonpayable' | 'payable', TFunctionName> = ContractFunctionArgs<TAbi, 'nonpayable' | 'payable', TFunctionName>>(name: string, args: ExecutionArgs<TAbi, TFunctionName, TArgs>) => Promise<EIP1193DATA>;
247
+ type ReadFunction = <TAbi extends Abi, TFunctionName extends ContractFunctionName<TAbi, 'pure' | 'view'>, TArgs extends ContractFunctionArgs<TAbi, 'pure' | 'view', TFunctionName> = ContractFunctionArgs<TAbi, 'pure' | 'view', TFunctionName>>(deployment: Deployment<TAbi>, args: ReadingArgs<TAbi, TFunctionName, TArgs>) => Promise<DecodeFunctionResultReturnType<TAbi, TFunctionName>>;
248
+ type ReadFunctionByName = <TAbi extends Abi, TFunctionName extends ContractFunctionName<TAbi, 'pure' | 'view'>, TArgs extends ContractFunctionArgs<TAbi, 'pure' | 'view', TFunctionName> = ContractFunctionArgs<TAbi, 'pure' | 'view', TFunctionName>>(name: string, args: ReadingArgs<TAbi, TFunctionName, TArgs>) => Promise<DecodeFunctionResultReturnType<TAbi, TFunctionName>>;
249
+ type ExecutionArgs<TAbi extends Abi, TFunctionName extends ContractFunctionName<TAbi, 'nonpayable' | 'payable'>, TArgs extends ContractFunctionArgs<TAbi, 'nonpayable' | 'payable', TFunctionName> = ContractFunctionArgs<TAbi, 'nonpayable' | 'payable', TFunctionName>> = Omit<WriteContractParameters<TAbi, TFunctionName, TArgs>, 'address' | 'abi' | 'account' | 'nonce' | 'chain'> & {
250
+ account: string;
251
+ };
252
+ type ReadingArgs<TAbi extends Abi, TFunctionName extends ContractFunctionName<TAbi, 'pure' | 'view'>, TArgs extends ContractFunctionArgs<TAbi, 'pure' | 'view', TFunctionName> = ContractFunctionArgs<TAbi, 'pure' | 'view', TFunctionName>> = Omit<ReadContractParameters<TAbi, TFunctionName, TArgs>, 'address' | 'abi' | 'account' | 'nonce'> & {
253
+ account?: string;
254
+ };
255
+ type DeployOptions = {
256
+ linkedData?: any;
257
+ deterministic?: boolean | `0x${string}`;
258
+ } & ({
259
+ skipIfAlreadyDeployed?: boolean;
260
+ } | {
261
+ alwaysOverride?: boolean;
262
+ });
263
+
264
+ export type { DeployFunction, DeployOptions, ExecuteFunction, ExecuteFunctionByName, ExecutionArgs, ReadFunction, ReadFunctionByName, ReadingArgs };
package/dist/index.mjs ADDED
@@ -0,0 +1,304 @@
1
+ import { extendEnvironment } from 'rocketh';
2
+ import { encodeFunctionData, decodeFunctionResult, encodeDeployData, keccak256 } from 'viem';
3
+ import { logs } from 'named-logs';
4
+
5
+ const logger = logs("rocketh-deploy");
6
+ async function broadcastTransaction(env, signer, params) {
7
+ if (signer.type === "wallet" || signer.type === "remote") {
8
+ return signer.signer.request({
9
+ method: "eth_sendTransaction",
10
+ params
11
+ });
12
+ } else {
13
+ const rawTx = await signer.signer.request({
14
+ method: "eth_signTransaction",
15
+ params
16
+ });
17
+ return env.network.provider.request({
18
+ method: "eth_sendRawTransaction",
19
+ params: [rawTx]
20
+ });
21
+ }
22
+ }
23
+ extendEnvironment((env) => {
24
+ async function execute(deployment, args) {
25
+ const { account, ...viemArgs } = args;
26
+ let address;
27
+ if (account.startsWith("0x")) {
28
+ address = account;
29
+ } else {
30
+ if (env.accounts) {
31
+ address = env.accounts[account];
32
+ if (!address) {
33
+ throw new Error(`no address for ${account}`);
34
+ }
35
+ } else {
36
+ throw new Error(`no accounts setup, cannot get address for ${account}`);
37
+ }
38
+ }
39
+ const artifactToUse = deployment;
40
+ const abi = artifactToUse.abi;
41
+ const calldata = encodeFunctionData({
42
+ abi,
43
+ functionName: viemArgs.functionName,
44
+ args: viemArgs.args
45
+ });
46
+ const signer = env.addressSigners[address];
47
+ const txParam = {
48
+ to: deployment.address,
49
+ type: "0x2",
50
+ from: address,
51
+ chainId: `0x${env.network.chain.id.toString(16)}`,
52
+ data: calldata,
53
+ gas: viemArgs.gas && `0x${viemArgs.gas.toString(16)}`,
54
+ // gasPrice: viemArgs.gasPrice && `0x${viemArgs.gasPrice.toString(16)}` as `0x${string}`,
55
+ maxFeePerGas: viemArgs.maxFeePerGas && `0x${viemArgs.maxFeePerGas.toString(16)}`,
56
+ maxPriorityFeePerGas: viemArgs.maxPriorityFeePerGas && `0x${viemArgs.maxPriorityFeePerGas.toString(16)}`
57
+ // nonce: viemArgs.nonce && (`0x${viemArgs.nonce.toString(16)}` as `0x${string}`),
58
+ };
59
+ if (viemArgs.value) {
60
+ txParam.value = `0x${viemArgs.value?.toString(16)}`;
61
+ }
62
+ let txHash;
63
+ if (signer.type === "wallet" || signer.type === "remote") {
64
+ txHash = await signer.signer.request({
65
+ method: "eth_sendTransaction",
66
+ params: [txParam]
67
+ });
68
+ } else {
69
+ const rawTx = await signer.signer.request({
70
+ method: "eth_signTransaction",
71
+ params: [txParam]
72
+ });
73
+ txHash = await env.network.provider.request({
74
+ method: "eth_sendRawTransaction",
75
+ params: [rawTx]
76
+ });
77
+ }
78
+ const pendingExecution = {
79
+ type: "execution",
80
+ transaction: { hash: txHash, origin: address }
81
+ // description, // TODO
82
+ // TODO we should have the nonce, except for wallet like metamask where it is not usre you get the nonce you start with
83
+ };
84
+ await env.savePendingExecution(pendingExecution);
85
+ return txHash;
86
+ }
87
+ async function executeByName(name, args) {
88
+ const deployment = env.getOrNull(name);
89
+ if (!deployment) {
90
+ throw new Error(`no deployment named ${name}`);
91
+ }
92
+ return execute(deployment, args);
93
+ }
94
+ async function read(deployment, args) {
95
+ const { account, ...viemArgs } = args;
96
+ let address;
97
+ if (account) {
98
+ if (account.startsWith("0x")) {
99
+ address = account;
100
+ } else {
101
+ if (env.accounts) {
102
+ address = env.accounts[account];
103
+ if (!address) {
104
+ throw new Error(`no address for ${account}`);
105
+ }
106
+ } else {
107
+ throw new Error(`no accounts setup, cannot get address for ${account}`);
108
+ }
109
+ }
110
+ }
111
+ const artifactToUse = deployment;
112
+ const abi = artifactToUse.abi;
113
+ const calldata = encodeFunctionData({
114
+ abi,
115
+ functionName: viemArgs.functionName,
116
+ args: viemArgs.args
117
+ });
118
+ const result = await env.network.provider.request({
119
+ method: "eth_call",
120
+ params: [
121
+ {
122
+ to: deployment.address,
123
+ type: "0x2",
124
+ from: address,
125
+ chainId: `0x${env.network.chain.id.toString(16)}`,
126
+ data: calldata
127
+ // value: `0x${viemArgs.value?.toString(16)}` as `0x${string}`,
128
+ }
129
+ ]
130
+ });
131
+ const parsed = decodeFunctionResult({
132
+ abi,
133
+ functionName: viemArgs.functionName,
134
+ data: result,
135
+ args: viemArgs.args
136
+ });
137
+ return parsed;
138
+ }
139
+ async function readByName(name, args) {
140
+ const deployment = env.getOrNull(name);
141
+ if (!deployment) {
142
+ throw new Error(`no deployment named ${name}`);
143
+ }
144
+ return read(deployment, args);
145
+ }
146
+ async function deploy(name, args, options) {
147
+ const skipIfAlreadyDeployed = options && "skipIfAlreadyDeployed" in options && options.skipIfAlreadyDeployed;
148
+ const allwaysOverride = options && "allwaysOverride" in options && options.allwaysOverride;
149
+ if (allwaysOverride && skipIfAlreadyDeployed) {
150
+ throw new Error(`conflicting options: "allwaysOverride" and "skipIfAlreadyDeployed"`);
151
+ }
152
+ const existingDeployment = env.getOrNull(name);
153
+ if (existingDeployment && skipIfAlreadyDeployed) {
154
+ logger.info(`deployment for ${name} at ${existingDeployment.address}, skipIfAlreadyDeployed: true => we skip`);
155
+ return { ...existingDeployment, updated: false };
156
+ }
157
+ const { account, artifact, ...viemArgs } = args;
158
+ let address;
159
+ if (account.startsWith("0x")) {
160
+ address = account;
161
+ } else {
162
+ if (env.accounts) {
163
+ address = env.accounts[account];
164
+ if (!address) {
165
+ throw new Error(`no address for ${account}`);
166
+ }
167
+ } else {
168
+ throw new Error(`no accounts setup, cannot get address for ${account}`);
169
+ }
170
+ }
171
+ const artifactToUse = typeof artifact === "string" ? env.artifacts[artifact] : artifact;
172
+ const bytecode = artifactToUse.bytecode;
173
+ const abi = artifactToUse.abi;
174
+ const argsToUse = {
175
+ ...viemArgs,
176
+ account,
177
+ abi,
178
+ bytecode
179
+ };
180
+ const calldata = encodeDeployData(argsToUse);
181
+ const argsData = `0x${calldata.replace(bytecode, "")}`;
182
+ if (existingDeployment) {
183
+ logger.info(`existing deployment for ${name} at ${existingDeployment.address}`);
184
+ }
185
+ if (existingDeployment && !allwaysOverride) {
186
+ const previousBytecode = existingDeployment.bytecode;
187
+ const previousArgsData = existingDeployment.argsData;
188
+ const last2Bytes = previousBytecode.slice(-4);
189
+ const cborLength = parseInt(last2Bytes, 16);
190
+ const previousBytecodeWithoutCBOR = previousBytecode.slice(0, -cborLength * 2);
191
+ const newBytecodeWithoutCBOR = bytecode.slice(0, -cborLength * 2);
192
+ if (previousBytecodeWithoutCBOR === newBytecodeWithoutCBOR && previousArgsData === argsData) {
193
+ return { ...existingDeployment, updated: false };
194
+ }
195
+ }
196
+ const partialDeployment = {
197
+ ...artifactToUse,
198
+ argsData,
199
+ linkedData: options?.linkedData
200
+ };
201
+ const signer = env.addressSigners[address];
202
+ const chainId = `0x${env.network.chain.id.toString(16)}`;
203
+ const maxFeePerGas = viemArgs.maxFeePerGas && `0x${viemArgs.maxFeePerGas.toString(16)}`;
204
+ const maxPriorityFeePerGas = viemArgs.maxPriorityFeePerGas && `0x${viemArgs.maxPriorityFeePerGas.toString(16)}`;
205
+ const params = [
206
+ {
207
+ type: "0x2",
208
+ from: address,
209
+ chainId,
210
+ data: calldata,
211
+ gas: viemArgs.gas && `0x${viemArgs.gas.toString(16)}`,
212
+ maxFeePerGas,
213
+ maxPriorityFeePerGas
214
+ // gasPrice: viemArgs.gasPrice && `0x${viemArgs.gasPrice.toString(16)}` as `0x${string}`,
215
+ // value: `0x${viemArgs.value?.toString(16)}` as `0x${string}`,
216
+ // nonce: viemArgs.nonce && (`0x${viemArgs.nonce.toString(16)}` as `0x${string}`),
217
+ }
218
+ ];
219
+ let expectedAddress = void 0;
220
+ if (options?.deterministic) {
221
+ const deterministicFactoryAddress = `0x4e59b44847b379578588920ca78fbf26c0b4956c`;
222
+ const deterministicFactoryDeployerAddress = `0x3fab184622dc19b6109349b94811493bf2a45362`;
223
+ const factoryDeploymentData = `0xf8a58085174876e800830186a08080b853604580600e600039806000f350fe7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe03601600081602082378035828234f58015156039578182fd5b8082525050506014600cf31ba02222222222222222222222222222222222222222222222222222222222222222a02222222222222222222222222222222222222222222222222222222222222222`;
224
+ const code = await env.network.provider.request({
225
+ method: "eth_getCode",
226
+ params: [deterministicFactoryAddress, "latest"]
227
+ });
228
+ if (code === "0x") {
229
+ const balanceHexString = await env.network.provider.request({
230
+ method: "eth_getBalance",
231
+ params: [deterministicFactoryDeployerAddress, "latest"]
232
+ });
233
+ const balance = BigInt(balanceHexString);
234
+ if (balance < 10000000000000000n) {
235
+ const need = 10000000000000000n - balance;
236
+ const balanceToSend = `0x${need.toString(16)}`;
237
+ const txHash3 = await broadcastTransaction(env, signer, [
238
+ {
239
+ type: "0x2",
240
+ chainId,
241
+ from: address,
242
+ to: deterministicFactoryDeployerAddress,
243
+ value: balanceToSend,
244
+ gas: `0x${BigInt(21e3).toString(16)}`,
245
+ maxFeePerGas,
246
+ maxPriorityFeePerGas
247
+ }
248
+ ]);
249
+ await env.savePendingExecution({
250
+ type: "execution",
251
+ // TODO different type ?
252
+ transaction: { hash: txHash3, origin: address }
253
+ });
254
+ }
255
+ const txHash2 = await env.network.provider.request({
256
+ method: "eth_sendRawTransaction",
257
+ params: [factoryDeploymentData]
258
+ });
259
+ await env.savePendingExecution({
260
+ type: "execution",
261
+ // TODO different type ?
262
+ transaction: { hash: txHash2, origin: address }
263
+ });
264
+ }
265
+ const salt = typeof options.deterministic === "string" ? `0x${options.deterministic.slice(2).padStart(64, "0")}` : "0x0000000000000000000000000000000000000000000000000000000000000000";
266
+ const bytecode2 = params[0].data || "0x";
267
+ expectedAddress = "0x" + keccak256(`0xff${deterministicFactoryAddress.slice(2)}${salt.slice(2)}${keccak256(bytecode2).slice(2)}`).slice(
268
+ -40
269
+ );
270
+ const codeAlreadyDeployed = await env.network.provider.request({
271
+ method: "eth_getCode",
272
+ params: [expectedAddress, "latest"]
273
+ });
274
+ if (codeAlreadyDeployed !== "0x") {
275
+ env.showMessage(`contract was already deterministically deployed at ${expectedAddress}`);
276
+ const deployment2 = await env.save(name, {
277
+ address: expectedAddress,
278
+ ...partialDeployment
279
+ });
280
+ return { ...deployment2, updated: true };
281
+ }
282
+ params[0].data = salt + (bytecode2.slice(2) || "");
283
+ params[0].to = deterministicFactoryAddress;
284
+ }
285
+ const txHash = await broadcastTransaction(env, signer, params);
286
+ const pendingDeployment = {
287
+ type: "deployment",
288
+ expectedAddress,
289
+ partialDeployment,
290
+ transaction: { hash: txHash, origin: address },
291
+ name
292
+ // TODO we should have the nonce, except for wallet like metamask where it is not usre you get the nonce you start with
293
+ };
294
+ const deployment = await env.savePendingDeployment(pendingDeployment);
295
+ return { ...deployment, updated: true };
296
+ }
297
+ env.deploy = deploy;
298
+ env.execute = execute;
299
+ env.executeByName = executeByName;
300
+ env.read = read;
301
+ env.readByName = readByName;
302
+ return env;
303
+ });
304
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../src/index.ts"],"sourcesContent":["import {Abi} from 'abitype';\nimport {EIP1193DATA, EIP1193TransactionData} from 'eip-1193';\nimport type {\n\tArtifact,\n\tDeploymentConstruction,\n\tDeployment,\n\tEnvironment,\n\tPendingDeployment,\n\tPartialDeployment,\n\tPendingExecution,\n\tNamedSigner,\n} from 'rocketh';\nimport {extendEnvironment} from 'rocketh';\nimport {\n\tChain,\n\tContractFunctionArgs,\n\tContractFunctionName,\n\tDecodeFunctionResultReturnType,\n\tEncodeDeployDataParameters,\n\tReadContractParameters,\n\tWriteContractParameters,\n\tdecodeFunctionResult,\n\tencodeFunctionData,\n\tkeccak256,\n} from 'viem';\nimport {DeployContractParameters, encodeDeployData} from 'viem';\nimport {logs} from 'named-logs';\n\nconst logger = logs('rocketh-deploy');\n\ndeclare module 'rocketh' {\n\tinterface Environment {\n\t\tdeploy: DeployFunction;\n\t\texecute: ExecuteFunction;\n\t\tread: ReadFunction;\n\t\texecuteByName: ExecuteFunctionByName;\n\t\treadByName: ReadFunctionByName;\n\t}\n}\n\nexport type DeployFunction = <TAbi extends Abi, TChain extends Chain = Chain>(\n\tname: string,\n\targs: DeploymentConstruction<TAbi>,\n\toptions?: DeployOptions\n) => Promise<Deployment<TAbi> & {updated: boolean}>;\n\nexport type ExecuteFunction = <\n\tTAbi extends Abi,\n\tTFunctionName extends ContractFunctionName<TAbi, 'nonpayable' | 'payable'>,\n\tTArgs extends ContractFunctionArgs<TAbi, 'nonpayable' | 'payable', TFunctionName> = ContractFunctionArgs<\n\t\tTAbi,\n\t\t'nonpayable' | 'payable',\n\t\tTFunctionName\n\t>\n>(\n\tdeployment: Deployment<TAbi>,\n\targs: ExecutionArgs<TAbi, TFunctionName, TArgs>\n) => Promise<EIP1193DATA>;\n\nexport type ExecuteFunctionByName = <\n\tTAbi extends Abi,\n\tTFunctionName extends ContractFunctionName<TAbi, 'nonpayable' | 'payable'>,\n\tTArgs extends ContractFunctionArgs<TAbi, 'nonpayable' | 'payable', TFunctionName> = ContractFunctionArgs<\n\t\tTAbi,\n\t\t'nonpayable' | 'payable',\n\t\tTFunctionName\n\t>\n>(\n\tname: string,\n\targs: ExecutionArgs<TAbi, TFunctionName, TArgs>\n) => Promise<EIP1193DATA>;\n\nexport type ReadFunction = <\n\tTAbi extends Abi,\n\tTFunctionName extends ContractFunctionName<TAbi, 'pure' | 'view'>,\n\tTArgs extends ContractFunctionArgs<TAbi, 'pure' | 'view', TFunctionName> = ContractFunctionArgs<\n\t\tTAbi,\n\t\t'pure' | 'view',\n\t\tTFunctionName\n\t>\n>(\n\tdeployment: Deployment<TAbi>,\n\targs: ReadingArgs<TAbi, TFunctionName, TArgs>\n) => Promise<DecodeFunctionResultReturnType<TAbi, TFunctionName>>;\n\nexport type ReadFunctionByName = <\n\tTAbi extends Abi,\n\tTFunctionName extends ContractFunctionName<TAbi, 'pure' | 'view'>,\n\tTArgs extends ContractFunctionArgs<TAbi, 'pure' | 'view', TFunctionName> = ContractFunctionArgs<\n\t\tTAbi,\n\t\t'pure' | 'view',\n\t\tTFunctionName\n\t>\n>(\n\tname: string,\n\targs: ReadingArgs<TAbi, TFunctionName, TArgs>\n) => Promise<DecodeFunctionResultReturnType<TAbi, TFunctionName>>;\n\nexport type ExecutionArgs<\n\tTAbi extends Abi,\n\tTFunctionName extends ContractFunctionName<TAbi, 'nonpayable' | 'payable'>,\n\tTArgs extends ContractFunctionArgs<TAbi, 'nonpayable' | 'payable', TFunctionName> = ContractFunctionArgs<\n\t\tTAbi,\n\t\t'nonpayable' | 'payable',\n\t\tTFunctionName\n\t>\n> = Omit<WriteContractParameters<TAbi, TFunctionName, TArgs>, 'address' | 'abi' | 'account' | 'nonce' | 'chain'> & {\n\taccount: string;\n};\n\nexport type ReadingArgs<\n\tTAbi extends Abi,\n\tTFunctionName extends ContractFunctionName<TAbi, 'pure' | 'view'>,\n\tTArgs extends ContractFunctionArgs<TAbi, 'pure' | 'view', TFunctionName> = ContractFunctionArgs<\n\t\tTAbi,\n\t\t'pure' | 'view',\n\t\tTFunctionName\n\t>\n> = Omit<ReadContractParameters<TAbi, TFunctionName, TArgs>, 'address' | 'abi' | 'account' | 'nonce'> & {\n\taccount?: string;\n};\n\nexport type DeployOptions = {linkedData?: any; deterministic?: boolean | `0x${string}`} & (\n\t| {\n\t\t\tskipIfAlreadyDeployed?: boolean;\n\t }\n\t| {\n\t\t\talwaysOverride?: boolean;\n\t }\n);\n\nasync function broadcastTransaction(\n\tenv: Environment,\n\tsigner: NamedSigner,\n\tparams: [EIP1193TransactionData]\n): Promise<`0x${string}`> {\n\tif (signer.type === 'wallet' || signer.type === 'remote') {\n\t\treturn signer.signer.request({\n\t\t\tmethod: 'eth_sendTransaction',\n\t\t\tparams,\n\t\t});\n\t} else {\n\t\tconst rawTx = await signer.signer.request({\n\t\t\tmethod: 'eth_signTransaction',\n\t\t\tparams,\n\t\t});\n\n\t\treturn env.network.provider.request({\n\t\t\tmethod: 'eth_sendRawTransaction',\n\t\t\tparams: [rawTx],\n\t\t});\n\t}\n}\n\nextendEnvironment((env: Environment) => {\n\tasync function execute<\n\t\tTAbi extends Abi,\n\t\tTFunctionName extends ContractFunctionName<TAbi, 'nonpayable' | 'payable'>,\n\t\tTArgs extends ContractFunctionArgs<TAbi, 'nonpayable' | 'payable', TFunctionName> = ContractFunctionArgs<\n\t\t\tTAbi,\n\t\t\t'nonpayable' | 'payable',\n\t\t\tTFunctionName\n\t\t>\n\t>(deployment: Deployment<TAbi>, args: ExecutionArgs<TAbi, TFunctionName, TArgs>) {\n\t\tconst {account, ...viemArgs} = args;\n\t\tlet address: `0x${string}`;\n\t\tif (account.startsWith('0x')) {\n\t\t\taddress = account as `0x${string}`;\n\t\t} else {\n\t\t\tif (env.accounts) {\n\t\t\t\taddress = env.accounts[account];\n\t\t\t\tif (!address) {\n\t\t\t\t\tthrow new Error(`no address for ${account}`);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthrow new Error(`no accounts setup, cannot get address for ${account}`);\n\t\t\t}\n\t\t}\n\n\t\tconst artifactToUse = deployment as unknown as Artifact<TAbi>;\n\t\tconst abi = artifactToUse.abi;\n\t\tconst calldata = encodeFunctionData<TAbi, TFunctionName>({\n\t\t\tabi,\n\t\t\tfunctionName: viemArgs.functionName,\n\t\t\targs: viemArgs.args,\n\t\t} as any);\n\n\t\tconst signer = env.addressSigners[address];\n\n\t\tconst txParam: EIP1193TransactionData = {\n\t\t\tto: deployment.address,\n\t\t\ttype: '0x2',\n\t\t\tfrom: address,\n\t\t\tchainId: `0x${env.network.chain.id.toString(16)}` as `0x${string}`,\n\t\t\tdata: calldata,\n\t\t\tgas: viemArgs.gas && (`0x${viemArgs.gas.toString(16)}` as `0x${string}`),\n\t\t\t// gasPrice: viemArgs.gasPrice && `0x${viemArgs.gasPrice.toString(16)}` as `0x${string}`,\n\t\t\tmaxFeePerGas: viemArgs.maxFeePerGas && (`0x${viemArgs.maxFeePerGas.toString(16)}` as `0x${string}`),\n\t\t\tmaxPriorityFeePerGas:\n\t\t\t\tviemArgs.maxPriorityFeePerGas && (`0x${viemArgs.maxPriorityFeePerGas.toString(16)}` as `0x${string}`),\n\t\t\t// nonce: viemArgs.nonce && (`0x${viemArgs.nonce.toString(16)}` as `0x${string}`),\n\t\t};\n\t\tif (viemArgs.value) {\n\t\t\ttxParam.value = `0x${viemArgs.value?.toString(16)}` as `0x${string}`;\n\t\t}\n\n\t\tlet txHash: `0x${string}`;\n\t\tif (signer.type === 'wallet' || signer.type === 'remote') {\n\t\t\ttxHash = await signer.signer.request({\n\t\t\t\tmethod: 'eth_sendTransaction',\n\t\t\t\tparams: [txParam],\n\t\t\t});\n\t\t} else {\n\t\t\tconst rawTx = await signer.signer.request({\n\t\t\t\tmethod: 'eth_signTransaction',\n\t\t\t\tparams: [txParam],\n\t\t\t});\n\n\t\t\ttxHash = await env.network.provider.request({\n\t\t\t\tmethod: 'eth_sendRawTransaction',\n\t\t\t\tparams: [rawTx],\n\t\t\t});\n\t\t}\n\n\t\tconst pendingExecution: PendingExecution = {\n\t\t\ttype: 'execution',\n\t\t\ttransaction: {hash: txHash, origin: address},\n\t\t\t// description, // TODO\n\t\t\t// TODO we should have the nonce, except for wallet like metamask where it is not usre you get the nonce you start with\n\t\t};\n\t\tawait env.savePendingExecution(pendingExecution);\n\t\treturn txHash;\n\t}\n\n\tasync function executeByName<\n\t\tTAbi extends Abi,\n\t\tTFunctionName extends ContractFunctionName<TAbi, 'nonpayable' | 'payable'>,\n\t\tTArgs extends ContractFunctionArgs<TAbi, 'nonpayable' | 'payable', TFunctionName> = ContractFunctionArgs<\n\t\t\tTAbi,\n\t\t\t'nonpayable' | 'payable',\n\t\t\tTFunctionName\n\t\t>\n\t>(name: string, args: ExecutionArgs<TAbi, TFunctionName, TArgs>) {\n\t\tconst deployment = env.getOrNull<TAbi>(name);\n\t\tif (!deployment) {\n\t\t\tthrow new Error(`no deployment named ${name}`);\n\t\t}\n\n\t\treturn execute(deployment, args);\n\t}\n\n\tasync function read<\n\t\tTAbi extends Abi,\n\t\tTFunctionName extends ContractFunctionName<TAbi, 'pure' | 'view'>,\n\t\tTArgs extends ContractFunctionArgs<TAbi, 'pure' | 'view', TFunctionName> = ContractFunctionArgs<\n\t\t\tTAbi,\n\t\t\t'pure' | 'view',\n\t\t\tTFunctionName\n\t\t>\n\t>(\n\t\tdeployment: Deployment<TAbi>,\n\t\targs: ReadingArgs<TAbi, TFunctionName, TArgs>\n\t): Promise<DecodeFunctionResultReturnType<TAbi, TFunctionName>> {\n\t\tconst {account, ...viemArgs} = args;\n\t\tlet address: `0x${string}` | undefined;\n\t\tif (account) {\n\t\t\tif (account.startsWith('0x')) {\n\t\t\t\taddress = account as `0x${string}`;\n\t\t\t} else {\n\t\t\t\tif (env.accounts) {\n\t\t\t\t\taddress = env.accounts[account];\n\t\t\t\t\tif (!address) {\n\t\t\t\t\t\tthrow new Error(`no address for ${account}`);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tthrow new Error(`no accounts setup, cannot get address for ${account}`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst artifactToUse = deployment as unknown as Artifact<TAbi>;\n\t\tconst abi = artifactToUse.abi;\n\t\tconst calldata = encodeFunctionData<TAbi, TFunctionName>({\n\t\t\tabi,\n\t\t\tfunctionName: viemArgs.functionName,\n\t\t\targs: viemArgs.args,\n\t\t} as any);\n\n\t\tconst result: `0x${string}` = (await env.network.provider.request({\n\t\t\tmethod: 'eth_call',\n\t\t\tparams: [\n\t\t\t\t{\n\t\t\t\t\tto: deployment.address,\n\t\t\t\t\ttype: '0x2',\n\t\t\t\t\tfrom: address,\n\t\t\t\t\tchainId: `0x${env.network.chain.id.toString(16)}` as `0x${string}`,\n\t\t\t\t\tdata: calldata,\n\t\t\t\t\t// value: `0x${viemArgs.value?.toString(16)}` as `0x${string}`,\n\t\t\t\t},\n\t\t\t],\n\t\t})) as `0x${string}`;\n\n\t\tconst parsed = decodeFunctionResult<TAbi, TFunctionName>({\n\t\t\tabi,\n\t\t\tfunctionName: viemArgs.functionName,\n\t\t\tdata: result,\n\t\t\targs: viemArgs.args,\n\t\t} as any);\n\n\t\treturn parsed as DecodeFunctionResultReturnType<TAbi, TFunctionName>;\n\t}\n\n\tasync function readByName<\n\t\tTAbi extends Abi,\n\t\tTFunctionName extends ContractFunctionName<TAbi, 'pure' | 'view'>,\n\t\tTArgs extends ContractFunctionArgs<TAbi, 'pure' | 'view', TFunctionName> = ContractFunctionArgs<\n\t\t\tTAbi,\n\t\t\t'pure' | 'view',\n\t\t\tTFunctionName\n\t\t>\n\t>(\n\t\tname: string,\n\t\targs: ReadingArgs<TAbi, TFunctionName, TArgs>\n\t): Promise<DecodeFunctionResultReturnType<TAbi, TFunctionName>> {\n\t\tconst deployment = env.getOrNull<TAbi>(name);\n\t\tif (!deployment) {\n\t\t\tthrow new Error(`no deployment named ${name}`);\n\t\t}\n\n\t\treturn read(deployment, args);\n\t}\n\tasync function deploy<TAbi extends Abi>(\n\t\tname: string,\n\t\targs: DeploymentConstruction<TAbi>,\n\t\toptions?: DeployOptions\n\t): Promise<Deployment<TAbi> & {updated: boolean}> {\n\t\tconst skipIfAlreadyDeployed = options && 'skipIfAlreadyDeployed' in options && options.skipIfAlreadyDeployed;\n\t\tconst allwaysOverride = options && 'allwaysOverride' in options && options.allwaysOverride;\n\n\t\tif (allwaysOverride && skipIfAlreadyDeployed) {\n\t\t\tthrow new Error(`conflicting options: \"allwaysOverride\" and \"skipIfAlreadyDeployed\"`);\n\t\t}\n\n\t\tconst existingDeployment = env.getOrNull(name);\n\t\tif (existingDeployment && skipIfAlreadyDeployed) {\n\t\t\tlogger.info(`deployment for ${name} at ${existingDeployment.address}, skipIfAlreadyDeployed: true => we skip`);\n\t\t\treturn {...(existingDeployment as Deployment<TAbi>), updated: false};\n\t\t}\n\n\t\tconst {account, artifact, ...viemArgs} = args;\n\t\tlet address: `0x${string}`;\n\t\tif (account.startsWith('0x')) {\n\t\t\taddress = account as `0x${string}`;\n\t\t} else {\n\t\t\tif (env.accounts) {\n\t\t\t\taddress = env.accounts[account];\n\t\t\t\tif (!address) {\n\t\t\t\t\tthrow new Error(`no address for ${account}`);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthrow new Error(`no accounts setup, cannot get address for ${account}`);\n\t\t\t}\n\t\t}\n\n\t\t// TODO throw specific error if artifact not found\n\t\tconst artifactToUse = (typeof artifact === 'string' ? env.artifacts[artifact] : artifact) as Artifact<TAbi>;\n\n\t\tconst bytecode = artifactToUse.bytecode;\n\t\tconst abi = artifactToUse.abi;\n\n\t\tconst argsToUse = {\n\t\t\t...viemArgs,\n\t\t\taccount,\n\t\t\tabi,\n\t\t\tbytecode,\n\t\t};\n\n\t\tconst calldata = encodeDeployData(argsToUse as any); // TODO any\n\t\tconst argsData = `0x${calldata.replace(bytecode, '')}` as `0x${string}`;\n\n\t\tif (existingDeployment) {\n\t\t\tlogger.info(`existing deployment for ${name} at ${existingDeployment.address}`);\n\t\t}\n\n\t\tif (existingDeployment && !allwaysOverride) {\n\t\t\tconst previousBytecode = existingDeployment.bytecode;\n\t\t\tconst previousArgsData = existingDeployment.argsData;\n\t\t\t// we assume cbor encoding of hash at the end\n\t\t\t// TODO option to remove it, can parse metadata but would rather avoid this here\n\t\t\tconst last2Bytes = previousBytecode.slice(-4);\n\t\t\tconst cborLength = parseInt(last2Bytes, 16);\n\t\t\tconst previousBytecodeWithoutCBOR = previousBytecode.slice(0, -cborLength * 2);\n\t\t\tconst newBytecodeWithoutCBOR = bytecode.slice(0, -cborLength * 2);\n\t\t\tif (previousBytecodeWithoutCBOR === newBytecodeWithoutCBOR && previousArgsData === argsData) {\n\t\t\t\treturn {...(existingDeployment as Deployment<TAbi>), updated: false};\n\t\t\t} else {\n\t\t\t\t// logger.info(`-------------- WITHOUT CBOR---------------------`);\n\t\t\t\t// logger.info(previousBytecodeWithoutCBOR);\n\t\t\t\t// logger.info(newBytecodeWithoutCBOR);\n\t\t\t\t// logger.info(`-----------------------------------`);\n\t\t\t\t// logger.info(`-------------- ARGS DATA ---------------------`);\n\t\t\t\t// logger.info(previousArgsData);\n\t\t\t\t// logger.info(argsData);\n\t\t\t\t// logger.info(`-----------------------------------`);\n\t\t\t}\n\t\t}\n\n\t\tconst partialDeployment: PartialDeployment<TAbi> = {\n\t\t\t...artifactToUse,\n\t\t\targsData,\n\t\t\tlinkedData: options?.linkedData,\n\t\t};\n\n\t\tconst signer = env.addressSigners[address];\n\n\t\tconst chainId = `0x${env.network.chain.id.toString(16)}` as `0x${string}`;\n\t\tconst maxFeePerGas = viemArgs.maxFeePerGas && (`0x${viemArgs.maxFeePerGas.toString(16)}` as `0x${string}`);\n\t\tconst maxPriorityFeePerGas =\n\t\t\tviemArgs.maxPriorityFeePerGas && (`0x${viemArgs.maxPriorityFeePerGas.toString(16)}` as `0x${string}`);\n\n\t\tconst params: [EIP1193TransactionData] = [\n\t\t\t{\n\t\t\t\ttype: '0x2',\n\t\t\t\tfrom: address,\n\t\t\t\tchainId,\n\t\t\t\tdata: calldata,\n\t\t\t\tgas: viemArgs.gas && (`0x${viemArgs.gas.toString(16)}` as `0x${string}`),\n\t\t\t\tmaxFeePerGas,\n\t\t\t\tmaxPriorityFeePerGas,\n\t\t\t\t// gasPrice: viemArgs.gasPrice && `0x${viemArgs.gasPrice.toString(16)}` as `0x${string}`,\n\t\t\t\t// value: `0x${viemArgs.value?.toString(16)}` as `0x${string}`,\n\t\t\t\t// nonce: viemArgs.nonce && (`0x${viemArgs.nonce.toString(16)}` as `0x${string}`),\n\t\t\t},\n\t\t];\n\n\t\tlet expectedAddress: `0x${string}` | undefined = undefined;\n\t\tif (options?.deterministic) {\n\t\t\t// TODO make these configurable\n\t\t\tconst deterministicFactoryAddress = `0x4e59b44847b379578588920ca78fbf26c0b4956c`;\n\t\t\tconst deterministicFactoryDeployerAddress = `0x3fab184622dc19b6109349b94811493bf2a45362`;\n\t\t\tconst factoryDeploymentData = `0xf8a58085174876e800830186a08080b853604580600e600039806000f350fe7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe03601600081602082378035828234f58015156039578182fd5b8082525050506014600cf31ba02222222222222222222222222222222222222222222222222222222222222222a02222222222222222222222222222222222222222222222222222222222222222`;\n\n\t\t\tconst code = await env.network.provider.request({\n\t\t\t\tmethod: 'eth_getCode',\n\t\t\t\tparams: [deterministicFactoryAddress, 'latest'],\n\t\t\t});\n\t\t\tif (code === '0x') {\n\t\t\t\tconst balanceHexString = await env.network.provider.request({\n\t\t\t\t\tmethod: 'eth_getBalance',\n\t\t\t\t\tparams: [deterministicFactoryDeployerAddress, 'latest'],\n\t\t\t\t});\n\t\t\t\tconst balance = BigInt(balanceHexString);\n\t\t\t\tif (balance < 10000000000000000n) {\n\t\t\t\t\tconst need = 10000000000000000n - balance;\n\t\t\t\t\tconst balanceToSend = `0x${need.toString(16)}` as `0x${string}`;\n\t\t\t\t\tconst txHash = await broadcastTransaction(env, signer, [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttype: '0x2',\n\t\t\t\t\t\t\tchainId,\n\t\t\t\t\t\t\tfrom: address,\n\t\t\t\t\t\t\tto: deterministicFactoryDeployerAddress,\n\t\t\t\t\t\t\tvalue: balanceToSend,\n\t\t\t\t\t\t\tgas: `0x${BigInt(21000).toString(16)}`,\n\t\t\t\t\t\t\tmaxFeePerGas,\n\t\t\t\t\t\t\tmaxPriorityFeePerGas,\n\t\t\t\t\t\t},\n\t\t\t\t\t]);\n\t\t\t\t\tawait env.savePendingExecution({\n\t\t\t\t\t\ttype: 'execution', // TODO different type ?\n\t\t\t\t\t\ttransaction: {hash: txHash, origin: address},\n\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\tconst txHash = await env.network.provider.request({\n\t\t\t\t\tmethod: 'eth_sendRawTransaction',\n\t\t\t\t\tparams: [factoryDeploymentData],\n\t\t\t\t});\n\t\t\t\tawait env.savePendingExecution({\n\t\t\t\t\ttype: 'execution', // TODO different type ?\n\t\t\t\t\ttransaction: {hash: txHash, origin: address},\n\t\t\t\t});\n\t\t\t}\n\n\t\t\t// prepending the salt\n\t\t\tconst salt = (\n\t\t\t\ttypeof options.deterministic === 'string'\n\t\t\t\t\t? `0x${options.deterministic.slice(2).padStart(64, '0')}`\n\t\t\t\t\t: '0x0000000000000000000000000000000000000000000000000000000000000000'\n\t\t\t) as `0x${string}`;\n\n\t\t\tconst bytecode = params[0].data || '0x';\n\n\t\t\texpectedAddress = ('0x' +\n\t\t\t\tkeccak256(`0xff${deterministicFactoryAddress.slice(2)}${salt.slice(2)}${keccak256(bytecode).slice(2)}`).slice(\n\t\t\t\t\t-40\n\t\t\t\t)) as `0x${string}`;\n\n\t\t\tconst codeAlreadyDeployed = await env.network.provider.request({\n\t\t\t\tmethod: 'eth_getCode',\n\t\t\t\tparams: [expectedAddress, 'latest'],\n\t\t\t});\n\n\t\t\tif (codeAlreadyDeployed !== '0x') {\n\t\t\t\tenv.showMessage(`contract was already deterministically deployed at ${expectedAddress}`);\n\t\t\t\tconst deployment = await env.save(name, {\n\t\t\t\t\taddress: expectedAddress,\n\t\t\t\t\t...partialDeployment,\n\t\t\t\t});\n\t\t\t\treturn {...(deployment as Deployment<TAbi>), updated: true};\n\t\t\t}\n\n\t\t\tparams[0].data = (salt + (bytecode.slice(2) || '')) as `0x${string}`;\n\t\t\tparams[0].to = deterministicFactoryAddress;\n\t\t}\n\n\t\tconst txHash = await broadcastTransaction(env, signer, params);\n\n\t\tconst pendingDeployment: PendingDeployment<TAbi> = {\n\t\t\ttype: 'deployment',\n\t\t\texpectedAddress,\n\t\t\tpartialDeployment,\n\t\t\ttransaction: {hash: txHash, origin: address},\n\t\t\tname,\n\t\t\t// TODO we should have the nonce, except for wallet like metamask where it is not usre you get the nonce you start with\n\t\t};\n\t\tconst deployment = await env.savePendingDeployment(pendingDeployment);\n\t\treturn {...(deployment as Deployment<TAbi>), updated: true};\n\t}\n\n\tenv.deploy = deploy;\n\tenv.execute = execute;\n\tenv.executeByName = executeByName;\n\tenv.read = read;\n\tenv.readByName = readByName;\n\treturn env;\n});\n"],"names":[],"mappings":"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"}