-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathcli.js
executable file
·189 lines (177 loc) · 9.95 KB
/
cli.js
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
#!/usr/bin/env node
/* eslint-disable max-len */
const { docopt } = require('docopt')
const { pegIn } = require('./lib/peg-in')
const { version } = require('./package.json')
const { setPNetwork } = require('./lib/set-pnetwork')
const { getPNetwork } = require('./lib/get-pnetwork')
const { deployVault } = require('./lib/deploy-vault')
const { verifyVault } = require('./lib/verify-vault')
const { getWEthAddress } = require('./lib/get-weth-address')
const { verifyUnwrapperContract } = require('./lib/verify-unwrapper')
const { isTokenSupported } = require('./lib/is-token-supported')
const { showWalletDetails } = require('./lib/show-wallet-details')
const { addSupportedToken } = require('./lib/add-supported-token')
const { showSuggestedFees } = require('./lib/show-suggested-fees')
const { getSupportedTokens } = require('./lib/get-supported-tokens')
const { deployUnwrapperContract } = require('./lib/deploy-unwrapper')
const { getEncodedInitArgs } = require('./lib/get-encoded-init-args')
const { setWEthUnwrapperAddress } = require('./lib/set-weth-unwrapper-address')
const { showExistingContractAddresses } = require('./lib/show-existing-contract-addresses')
const HELP_ARG = '--help'
const TOOL_NAME = 'cli.js'
const PEG_IN_CMD = 'pegIn'
const AMOUNT_ARG = '<amount>'
const TOKEN_FLAG = '--token'
const VERSION_ARG = '--version'
const NETWORK_ARG = '<network>'
const ETH_ADDRESS_ARG = '<ethAddress>'
const SET_PNETWORK_CMD = 'setPNetwork'
const GET_PNETWORK_CMD = 'getPNetwork'
const WETH_ADDRESS_ARG = '<wEthAddress>'
const GET_WETH_ADDRESS = 'getWEthAddress'
const TOKEN_ADDRESS_ARG = '<tokenAddress>'
const USER_DATA_OPTIONAL_ARG = '--userData'
const ORIGIN_CHAIN_ID_ARG = '<originChainId>'
const DEPLOY_VAULT_CMD = 'deployVaultContract'
const VERIFY_VAULT_CMD = 'verifyVaultContract'
const FLATTEN_CONTRACT_CMD = 'flattenContract'
const TOKENS_ARG = `${TOKEN_FLAG}=<ethAddress>`
const DEPLOYED_ADDRESS_ARG = '<deployedAddress>'
const IS_TOKEN_SUPPORTED_CMD = 'isTokenSupported'
const GET_ENCODED_INIT_ARGS_CMD = 'encodeInitArgs'
const SHOW_SUGGESTED_FEES_CMD = 'showSuggestedFees'
const SHOW_WALLET_DETAILS_CMD = 'showWalletDetails'
const ADD_SUPPORTED_TOKEN_CMD = 'addSupportedToken'
const GET_SUPPORTED_TOKENS_CMD = 'getSupportedTokens'
const VERIFY_UNWRAPPER_CMD = 'verifyUnwrapperContract'
const DEPLOY_UNWRAPPER_CMD = 'deployUnwrapperContract'
const DESTINATION_ADDRESS_ARG = '<destinationAddress>'
const DESTINATION_CHAIN_ID_ARG = '<destinationChainId>'
const USER_DATA_ARG = `${USER_DATA_OPTIONAL_ARG}=<hex>`
const SHOW_EXISTING_CONTRACTS_CMD = 'showExistingContracts'
const SET_WETH_UNWRAPPER_ADDRESS = 'setWEthUnwrapperAddress'
const USAGE_INFO = `
❍ pTokens ERC20 Vault Command Line Interface
Copyright Provable Things 2021
Questions: [email protected]
❍ Info:
A tool to aid with deployments of & interactions with the upgradeable pToken ERC20 vault logic contract.
NOTE: Functions that make transactions require a private key. Please provide a GPG encrpyted file called
'private-key.gpg' containing your key in the root of the repository. Create one via:
'echo <your-private-key> | gpg -c --output private-key.gpg'
Multiple private keys may be provisioned, and the tool will provide you with a list to select from.
NOTE: The tool requires a '.env' file to exist in the root of the repository with the following info:
ENDPOINT=<rpc-endpoint-for-blochain-to-interact-with>
Multiple such files may be provisioned, and the tool will provide you with a list to select from.
NOTE: To call functions which verify contracts, the following extra environment variable is required:
ETHERSCAN_API_KEY=<api-key-for-automated-contract-verifications>
❍ Usage:
${TOOL_NAME} ${HELP_ARG}
${TOOL_NAME} ${VERSION_ARG}
${TOOL_NAME} ${FLATTEN_CONTRACT_CMD}
${TOOL_NAME} ${SHOW_SUGGESTED_FEES_CMD}
${TOOL_NAME} ${SHOW_WALLET_DETAILS_CMD}
${TOOL_NAME} ${DEPLOY_VAULT_CMD}
${TOOL_NAME} ${SHOW_EXISTING_CONTRACTS_CMD}
${TOOL_NAME} ${GET_PNETWORK_CMD} ${DEPLOYED_ADDRESS_ARG}
${TOOL_NAME} ${GET_WETH_ADDRESS} ${DEPLOYED_ADDRESS_ARG}
${TOOL_NAME} ${GET_SUPPORTED_TOKENS_CMD} ${DEPLOYED_ADDRESS_ARG}
${TOOL_NAME} ${DEPLOY_UNWRAPPER_CMD} ${WETH_ADDRESS_ARG}
${TOOL_NAME} ${SET_PNETWORK_CMD} ${DEPLOYED_ADDRESS_ARG} ${ETH_ADDRESS_ARG}
${TOOL_NAME} ${VERIFY_VAULT_CMD} ${NETWORK_ARG} ${DEPLOYED_ADDRESS_ARG}
${TOOL_NAME} ${IS_TOKEN_SUPPORTED_CMD} ${DEPLOYED_ADDRESS_ARG} ${ETH_ADDRESS_ARG}
${TOOL_NAME} ${ADD_SUPPORTED_TOKEN_CMD} ${DEPLOYED_ADDRESS_ARG} ${ETH_ADDRESS_ARG}
${TOOL_NAME} ${SET_WETH_UNWRAPPER_ADDRESS} ${DEPLOYED_ADDRESS_ARG} ${ETH_ADDRESS_ARG}
${TOOL_NAME} ${VERIFY_UNWRAPPER_CMD} ${NETWORK_ARG} ${DEPLOYED_ADDRESS_ARG} ${WETH_ADDRESS_ARG}
${TOOL_NAME} ${GET_ENCODED_INIT_ARGS_CMD} ${WETH_ADDRESS_ARG} ${ORIGIN_CHAIN_ID_ARG} [${TOKENS_ARG}...]
${TOOL_NAME} ${PEG_IN_CMD} ${DEPLOYED_ADDRESS_ARG} ${AMOUNT_ARG} ${TOKEN_ADDRESS_ARG} ${DESTINATION_ADDRESS_ARG} ${DESTINATION_CHAIN_ID_ARG} [${USER_DATA_ARG}]
❍ Commands:
${SET_PNETWORK_CMD} ❍ Set the pNetwork address.
${SHOW_SUGGESTED_FEES_CMD} ❍ Show 'ethers.js' suggested fees.
${DEPLOY_UNWRAPPER_CMD} ❍ Deploy the WETH unwrapper contract.
${DEPLOY_VAULT_CMD} ❍ Deploy the ERC20 vault logic contract.
${VERIFY_VAULT_CMD} ❍ Verify a deployed pToken logic contract.
${VERIFY_UNWRAPPER_CMD} ❍ Verify a deployed WETH unwrapper contract.
${GET_PNETWORK_CMD} ❍ Show the pNetwork address of the vault at ${DEPLOYED_ADDRESS_ARG}.
${GET_WETH_ADDRESS} ❍ Show the wETH address set in the vault at ${DEPLOYED_ADDRESS_ARG}.
${FLATTEN_CONTRACT_CMD} ❍ Flatten the contract in case manual verification is required.
${GET_SUPPORTED_TOKENS_CMD} ❍ Show list of tokens supprted by the vault at ${DEPLOYED_ADDRESS_ARG}.
${SHOW_WALLET_DETAILS_CMD} ❍ Decrypts the private key and shows address & balance information.
${IS_TOKEN_SUPPORTED_CMD} ❍ Is token at ${ETH_ADDRESS_ARG} supported in vault at ${DEPLOYED_ADDRESS_ARG}.
${GET_ENCODED_INIT_ARGS_CMD} ❍ Calculate the initializer function arguments in ABI encoded format.
${SHOW_EXISTING_CONTRACTS_CMD} ❍ Show list of existing logic contract addresses on various blockchains.
${ADD_SUPPORTED_TOKEN_CMD} ❍ Adds token at ${ETH_ADDRESS_ARG} to the supported tokens in vault at ${DEPLOYED_ADDRESS_ARG}.
${PEG_IN_CMD} ❍ Peg in ${AMOUNT_ARG} of ${TOKEN_ADDRESS_ARG} to ${DESTINATION_ADDRESS_ARG} on ${DESTINATION_CHAIN_ID_ARG}.
${SET_WETH_UNWRAPPER_ADDRESS} ❍ Sets the WETH unwrapper contract at ${ETH_ADDRESS_ARG} in the vault at ${DEPLOYED_ADDRESS_ARG}.
❍ Options:
${HELP_ARG} ❍ Show this message.
${VERSION_ARG} ❍ Show tool version.
${ETH_ADDRESS_ARG} ❍ A valid ETH address.
${TOKEN_ADDRESS_ARG} ❍ ETH address of token.
${DEPLOYED_ADDRESS_ARG} ❍ The ETH address of the deployed vault.
${DESTINATION_ADDRESS_ARG} ❍ Destination address of a token peg in.
${USER_DATA_ARG} ❍ User data in hex format [default: 0x].
${TOKENS_ARG} ❍ ETH addresses of tokens the vault will support.
${AMOUNT_ARG} ❍ Amount of tokens in their most granular format.
${ORIGIN_CHAIN_ID_ARG} ❍ Metadata chain ID of the chain this contract is deployed to.
${DESTINATION_CHAIN_ID_ARG} ❍ Metadata chain ID of the chains this contract supports peg-ins to.
${WETH_ADDRESS_ARG} ❍ The address for the wrapped ETH token on the blockchain to be deployed to.
${NETWORK_ARG} ❍ Network the vault is deployed on. It must exist in the 'hardhat.config.json'.
`
const main = _ => {
const CLI_ARGS = docopt(USAGE_INFO, { version })
if (CLI_ARGS[FLATTEN_CONTRACT_CMD]) {
return Promise.resolve(
console.info('✘ `truffle-flattener` does not work w/ `unchecked` code blocks, so we cannot do this yet!')
)
} else if (CLI_ARGS[SHOW_SUGGESTED_FEES_CMD]) {
return showSuggestedFees()
} else if (CLI_ARGS[DEPLOY_VAULT_CMD]) {
return deployVault()
} else if (CLI_ARGS[DEPLOY_UNWRAPPER_CMD]) {
return deployUnwrapperContract(CLI_ARGS[WETH_ADDRESS_ARG])
} else if (CLI_ARGS[VERIFY_VAULT_CMD]) {
return verifyVault(CLI_ARGS[NETWORK_ARG], CLI_ARGS[DEPLOYED_ADDRESS_ARG])
} else if (CLI_ARGS[VERIFY_UNWRAPPER_CMD]) {
return verifyUnwrapperContract(
CLI_ARGS[NETWORK_ARG],
CLI_ARGS[DEPLOYED_ADDRESS_ARG],
CLI_ARGS[WETH_ADDRESS_ARG]
)
} else if (CLI_ARGS[SHOW_EXISTING_CONTRACTS_CMD]) {
return showExistingContractAddresses()
} else if (CLI_ARGS[SET_PNETWORK_CMD]) {
return setPNetwork(CLI_ARGS[DEPLOYED_ADDRESS_ARG], CLI_ARGS[ETH_ADDRESS_ARG])
} else if (CLI_ARGS[ADD_SUPPORTED_TOKEN_CMD]) {
return addSupportedToken(CLI_ARGS[DEPLOYED_ADDRESS_ARG], CLI_ARGS[ETH_ADDRESS_ARG])
} else if (CLI_ARGS[SET_WETH_UNWRAPPER_ADDRESS]) {
return setWEthUnwrapperAddress(CLI_ARGS[DEPLOYED_ADDRESS_ARG], CLI_ARGS[ETH_ADDRESS_ARG])
} else if (CLI_ARGS[GET_PNETWORK_CMD]) {
return getPNetwork(CLI_ARGS[DEPLOYED_ADDRESS_ARG])
} else if (CLI_ARGS[GET_SUPPORTED_TOKENS_CMD]) {
return getSupportedTokens(CLI_ARGS[DEPLOYED_ADDRESS_ARG])
} else if (CLI_ARGS[GET_WETH_ADDRESS]) {
return getWEthAddress(CLI_ARGS[DEPLOYED_ADDRESS_ARG])
} else if (CLI_ARGS[IS_TOKEN_SUPPORTED_CMD]) {
return isTokenSupported(CLI_ARGS[DEPLOYED_ADDRESS_ARG], CLI_ARGS[ETH_ADDRESS_ARG])
} else if (CLI_ARGS[SHOW_WALLET_DETAILS_CMD]) {
return showWalletDetails()
} else if (CLI_ARGS[GET_ENCODED_INIT_ARGS_CMD]) {
return getEncodedInitArgs(
CLI_ARGS[WETH_ADDRESS_ARG],
CLI_ARGS[TOKEN_FLAG],
CLI_ARGS[ORIGIN_CHAIN_ID_ARG],
)
} else if (CLI_ARGS[PEG_IN_CMD]) {
return pegIn(
CLI_ARGS[DEPLOYED_ADDRESS_ARG],
CLI_ARGS[AMOUNT_ARG],
CLI_ARGS[TOKEN_ADDRESS_ARG],
CLI_ARGS[DESTINATION_ADDRESS_ARG],
CLI_ARGS[DESTINATION_CHAIN_ID_ARG],
CLI_ARGS[USER_DATA_OPTIONAL_ARG],
)
}
}
main().catch(_err => console.error('✘', _err.message) || process.exit(1))