forked from circlefin/evm-cctp-contracts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdeploy.s.sol
269 lines (226 loc) · 8.08 KB
/
deploy.s.sol
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
pragma solidity ^0.7.6;
import "forge-std/Script.sol";
import "../src/TokenMessenger.sol";
import "../src/TokenMinter.sol";
import "../src/MessageTransmitter.sol";
import "../src/messages/Message.sol";
contract DeployScript is Script {
address private attesterAddress;
address private usdcContractAddress;
address private usdcRemoteContractAddress;
address private remoteTokenMessengerAddress;
address private tokenControllerAddress;
address private messageTransmitterPauserAddress;
address private tokenMinterPauserAddress;
address private messageTransmitterRescuerAddress;
address private tokenMessengerRescuerAddress;
address private tokenMinterRescuerAddress;
uint32 private messageBodyVersion = 0;
uint32 private version = 0;
uint32 private domain;
uint32 private remoteDomain;
uint32 private maxMessageBodySize = 8192;
uint256 private burnLimitPerMessage;
uint256 private messageTransmitterDeployerPrivateKey;
uint256 private tokenMessengerDeployerPrivateKey;
uint256 private tokenMinterDeployerPrivateKey;
uint256 private tokenControllerPrivateKey;
/**
* @notice deploys Message Transmitter
* @param privateKey Private Key for signing the transactions
* @return MessageTransmitter instance
*/
function deployMessageTransmitter(uint256 privateKey)
private
returns (MessageTransmitter)
{
// Start recording transactions
vm.startBroadcast(privateKey);
// Deploy MessageTransmitter
MessageTransmitter messageTransmitter = new MessageTransmitter(
domain,
attesterAddress,
maxMessageBodySize,
version
);
// Add Pauser
messageTransmitter.updatePauser(messageTransmitterPauserAddress);
// Add Rescuer
messageTransmitter.updateRescuer(messageTransmitterRescuerAddress);
// Stop recording transactions
vm.stopBroadcast();
return messageTransmitter;
}
/**
* @notice deploys TokenMessenger
* @param privateKey Private Key for signing the transactions
* @param messageTransmitterAddress Message Transmitter Contract address
* @return TokenMessenger instance
*/
function deployTokenMessenger(
uint256 privateKey,
address messageTransmitterAddress
) private returns (TokenMessenger) {
// Start recording transations
vm.startBroadcast(privateKey);
// Deploy TokenMessenger
TokenMessenger tokenMessenger = new TokenMessenger(
messageTransmitterAddress,
messageBodyVersion
);
// Add Rescuer
tokenMessenger.updateRescuer(tokenMessengerRescuerAddress);
// Stop recording transations
vm.stopBroadcast();
return tokenMessenger;
}
/**
* @notice deploys TokenMinter
* @param privateKey Private Key for signing the transactions
* @param tokenMessengerAddress TokenMessenger Contract address
* @return TokenMinter instance
*/
function deployTokenMinter(
uint256 privateKey,
address tokenMessengerAddress
) private returns (TokenMinter) {
// Start recording transations
vm.startBroadcast(privateKey);
// Deploy TokenMinter
TokenMinter tokenMinter = new TokenMinter(tokenControllerAddress);
// Add Local TokenMessenger
tokenMinter.addLocalTokenMessenger(tokenMessengerAddress);
// Add Pauser
tokenMinter.updatePauser(tokenMinterPauserAddress);
// Add Rescuer
tokenMinter.updateRescuer(tokenMinterRescuerAddress);
// Stop recording transations
vm.stopBroadcast();
return tokenMinter;
}
/**
* @notice add local minter to the TokenMessenger
*/
function addMinterAddressToTokenMessenger(
TokenMessenger tokenMessenger,
uint256 privateKey,
address minterAddress
) private {
// Start recording transations
vm.startBroadcast(privateKey);
tokenMessenger.addLocalMinter(minterAddress);
// Stop recording transations
vm.stopBroadcast();
}
/**
* @notice link current chain and remote chain tokens
*/
function linkTokenPair(TokenMinter tokenMinter, uint256 privateKey)
private
{
// Start recording transations
vm.startBroadcast(privateKey);
bytes32 remoteUsdcContractAddressInBytes32 = Message.addressToBytes32(
usdcRemoteContractAddress
);
tokenMinter.setMaxBurnAmountPerMessage(
usdcContractAddress,
burnLimitPerMessage
);
tokenMinter.linkTokenPair(
usdcContractAddress,
remoteDomain,
remoteUsdcContractAddressInBytes32
);
// Stop recording transations
vm.stopBroadcast();
}
/**
* @notice add address of TokenMessenger deployed on another chain
*/
function addRemoteTokenMessenger(
TokenMessenger tokenMessenger,
uint256 privateKey
) private {
// Start recording transations
vm.startBroadcast(privateKey);
bytes32 remoteTokenMessengerAddressInBytes32 = Message.addressToBytes32(
remoteTokenMessengerAddress
);
tokenMessenger.addRemoteTokenMessenger(
remoteDomain,
remoteTokenMessengerAddressInBytes32
);
// Stop recording transations
vm.stopBroadcast();
}
/**
* @notice initialize variables from environment
*/
function setUp() public {
messageTransmitterDeployerPrivateKey = vm.envUint(
"MESSAGE_TRANSMITTER_DEPLOYER_KEY"
);
tokenMessengerDeployerPrivateKey = vm.envUint(
"TOKEN_MESSENGER_DEPLOYER_KEY"
);
tokenMinterDeployerPrivateKey = vm.envUint("TOKEN_MINTER_DEPLOYER_KEY");
tokenControllerPrivateKey = vm.envUint("TOKEN_CONTROLLER_DEPLOYER_KEY");
attesterAddress = vm.envAddress("ATTESTER_ADDRESS");
usdcContractAddress = vm.envAddress("USDC_CONTRACT_ADDRESS");
tokenControllerAddress = vm.envAddress("TOKEN_CONTROLLER_ADDRESS");
burnLimitPerMessage = vm.envUint("BURN_LIMIT_PER_MESSAGE");
usdcRemoteContractAddress = vm.envAddress(
"REMOTE_USDC_CONTRACT_ADDRESS"
);
remoteTokenMessengerAddress = vm.envAddress(
"REMOTE_TOKEN_MESSENGER_ADDRESS"
);
domain = uint32(vm.envUint("DOMAIN"));
remoteDomain = uint32(vm.envUint("REMOTE_DOMAIN"));
messageTransmitterPauserAddress = vm.envAddress(
"MESSAGE_TRANSMITTER_PAUSER_ADDRESS"
);
tokenMinterPauserAddress = vm.envAddress("TOKEN_MINTER_PAUSER_ADDRESS");
messageTransmitterRescuerAddress = vm.envAddress(
"MESSAGE_TRANSMITTER_RESCUER_ADDRESS"
);
tokenMessengerRescuerAddress = vm.envAddress(
"TOKEN_MESSENGER_RESCUER_ADDRESS"
);
tokenMinterRescuerAddress = vm.envAddress(
"TOKEN_MINTER_RESCUER_ADDRESS"
);
}
/**
* @notice main function that will be run by forge
*/
function run() public {
// Deploy MessageTransmitter
MessageTransmitter messageTransmitter = deployMessageTransmitter(
messageTransmitterDeployerPrivateKey
);
// Deploy TokenMessenger
TokenMessenger tokenMessenger = deployTokenMessenger(
tokenMessengerDeployerPrivateKey,
address(messageTransmitter)
);
// Deploy TokenMinter
TokenMinter tokenMinter = deployTokenMinter(
tokenMinterDeployerPrivateKey,
address(tokenMessenger)
);
// Add Local Minter
addMinterAddressToTokenMessenger(
tokenMessenger,
tokenMessengerDeployerPrivateKey,
address(tokenMinter)
);
// Link token pair and add remote token messenger
linkTokenPair(tokenMinter, tokenControllerPrivateKey);
addRemoteTokenMessenger(
tokenMessenger,
tokenMessengerDeployerPrivateKey
);
}
}