Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Create new CLI package #2573

Merged
merged 96 commits into from
Oct 14, 2023
Merged
Show file tree
Hide file tree
Changes from 89 commits
Commits
Show all changes
96 commits
Select commit Hold shift + click to select a range
559ae95
Create new CLI package
jmrossy Jul 26, 2023
a2aa1b5
Progress on deploy commands
jmrossy Jul 27, 2023
4aa2fb2
Finish implementation of core deploy command
jmrossy Jul 28, 2023
e382ecc
Implement cli warp deploy command
jmrossy Jul 29, 2023
7ec381c
Merge branch 'main' into rossy/cli
jmrossy Jul 29, 2023
e81eaf3
Update readme
jmrossy Jul 29, 2023
0cc2473
Create stubs for send commands
jmrossy Jul 29, 2023
951f189
Finish implementation of send commands
jmrossy Jul 29, 2023
4a4fa07
Run prettier
jmrossy Jul 29, 2023
369c71a
Update dockerfile for CLI package
jmrossy Jul 30, 2023
032986d
Improve send message logging
jmrossy Jul 30, 2023
b7bd7b8
Remove extra console.log line
jmrossy Jul 30, 2023
f0e7643
Merge branch 'main' into rossy/cli
jmrossy Jul 31, 2023
46a316a
Improve send commands
jmrossy Jul 31, 2023
1aafda3
Minor fix to warp deploy
jmrossy Aug 1, 2023
7ca03d1
Merge branch 'main' into rossy/cli
jmrossy Aug 1, 2023
9ff88de
Update CLI CI test
jmrossy Aug 1, 2023
91e4262
Merge branch 'main' into rossy/cli
jmrossy Aug 2, 2023
aff0499
Bump versions to 1.4.3-beta0
jmrossy Aug 2, 2023
f686eb2
Merge branch 'main' into rossy/cli
jmrossy Aug 6, 2023
ce5fbfc
Fix build errors from merge
jmrossy Aug 6, 2023
e914051
Address feedback from @yorhodes
jmrossy Aug 6, 2023
0bd1d09
Run prettier
jmrossy Aug 6, 2023
bfec96b
Merge branch 'main' into rossy/cli
jmrossy Aug 9, 2023
18f3d9f
Add new multisig config create command
jmrossy Aug 10, 2023
b5b8fab
Merge branch 'main' into rossy/cli
jmrossy Aug 11, 2023
1029299
Bump versions to 1.4.3-beta2
jmrossy Aug 11, 2023
fad0df8
Merge branch 'main' into rossy/cli
jmrossy Sep 22, 2023
8c2a620
Add create and validate commands for warp configs
jmrossy Sep 22, 2023
e0ecd6b
Bump versions for beta CLI publish
jmrossy Sep 22, 2023
6959b7f
Add alias for addresses command
jmrossy Sep 22, 2023
24162fe
Merge branch 'main' into rossy/cli
jmrossy Sep 28, 2023
13103da
Address feedback and reorganize cli config code
jmrossy Sep 28, 2023
7033a73
Remove stableVersion fields from package.json files
jmrossy Sep 28, 2023
f8f2105
Merge branch 'main' into rossy/cli
jmrossy Oct 3, 2023
4795ca5
Fix multisig casing and output file month number
jmrossy Oct 3, 2023
384652b
Upgrade packages to 1.5.3
jmrossy Oct 3, 2023
1908ae1
Merge branch 'main' into rossy/cli
jmrossy Oct 5, 2023
7ed8bc2
Add option to skip prompts for core deploy
jmrossy Oct 5, 2023
7b86a4a
Move CLI CI into node.yml
jmrossy Oct 5, 2023
eed11f5
Fix yarn command in ci-test
jmrossy Oct 6, 2023
b592245
Set artifacts path in deploy command
jmrossy Oct 6, 2023
8e44f62
Derp, fix artifact file path
jmrossy Oct 6, 2023
f9cffa3
Use example multisig config for ci test
jmrossy Oct 6, 2023
42de37c
Fix missing yes param
jmrossy Oct 6, 2023
ccad526
More fixes for ci-test
jmrossy Oct 7, 2023
7471530
Fix Ism cofigs and TestRecipient ISM
jmrossy Oct 7, 2023
528b554
Remove empty-artifacts file from git
jmrossy Oct 7, 2023
6692342
Attempt to use tmp for empty-artifacts
jmrossy Oct 7, 2023
3033188
Also use tmp for artifacts out
jmrossy Oct 7, 2023
1769053
Derp, path again
jmrossy Oct 7, 2023
1d9a994
Hack workaround for bigint console warn
jmrossy Oct 8, 2023
7f4fdea
Add filename select option for artifact and ism steps
jmrossy Oct 8, 2023
7fe4301
Bump versions ot 1.5.4-beta0
jmrossy Oct 9, 2023
ba8761d
Add CI test coverage for warp deploy
jmrossy Oct 9, 2023
84f13bf
Fix delivery check bug in HyperlaneCore
jmrossy Oct 9, 2023
4c9c04a
Add CI coverage for send commands
jmrossy Oct 10, 2023
0ed4d43
Merge branch 'main' into rossy/cli
jmrossy Oct 10, 2023
b044870
Increase timeout on some SDK unit tests
jmrossy Oct 10, 2023
287727c
Make SDK + CLI logging more consistent
jmrossy Oct 10, 2023
3d95734
Print tmp filenames to debug announcement
jmrossy Oct 10, 2023
31842f4
Install libssl3 before cli test
jmrossy Oct 10, 2023
5622d6d
Attempt to configure libssl
jmrossy Oct 10, 2023
4d98648
Attempt2
jmrossy Oct 10, 2023
b038479
Attempt to add libssl3 to agent dockerfile
jmrossy Oct 10, 2023
d6dabde
Update dockerfile again
jmrossy Oct 10, 2023
392e474
Revert dockerfile changes
jmrossy Oct 10, 2023
d467318
Merge branch 'main' into rossy/cli
jmrossy Oct 10, 2023
531c98f
Fix agent config file path
jmrossy Oct 10, 2023
e15ccdf
Increase validator startup sleep time
jmrossy Oct 11, 2023
cfc8a56
Add more logging
jmrossy Oct 11, 2023
688f61c
Try removing announce loop
jmrossy Oct 11, 2023
c57f986
Add more logging
jmrossy Oct 11, 2023
54180b6
Disable find cmd again
jmrossy Oct 11, 2023
7cb395b
Try to disable super noisy validator logs
jmrossy Oct 11, 2023
862f418
Skip announce tx entirely
jmrossy Oct 11, 2023
17c98a4
Try killing validator before running relayer
jmrossy Oct 11, 2023
ebad637
Fix missing quotation mark
jmrossy Oct 11, 2023
1d8add9
Attempt to silence noisy logs
jmrossy Oct 11, 2023
86a0743
Keep trying
jmrossy Oct 11, 2023
885ffda
Remove first docker kill command
jmrossy Oct 11, 2023
8593440
Extract message IDs
jmrossy Oct 11, 2023
e6b4262
Let validator be noisy?
jmrossy Oct 12, 2023
44fb1d7
Add message status command
jmrossy Oct 12, 2023
3b16d8e
Add delivery checking to ci test
jmrossy Oct 12, 2023
1780b6a
Attempt to reduce logging again
jmrossy Oct 12, 2023
b88f7fd
Fix message id check
jmrossy Oct 12, 2023
6ddb80e
Merge branch 'main' into rossy/cli
jmrossy Oct 12, 2023
d5b4a54
Print message id to confirm
jmrossy Oct 12, 2023
4e18c27
Deploy ISMs before core
jmrossy Oct 12, 2023
b39eaa0
Remove console log line
jmrossy Oct 12, 2023
b45c9e4
Run relayer properly
nambrot Oct 13, 2023
18586b6
Fix missing ISM domain for secondary PI chains
jmrossy Oct 13, 2023
5120610
Improvements and fixes to ci script
jmrossy Oct 14, 2023
8c6d6f0
Route validator and relayer logs to file
jmrossy Oct 14, 2023
80086bf
Add comments for things to address during v3 updates
jmrossy Oct 14, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .eslintrc
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@
"@typescript-eslint/no-require-imports": ["warn"],
"@typescript-eslint/no-unused-vars": [
"error",
{
{
"argsIgnorePattern": "^_",
"varsIgnorePattern": "^_",
"caughtErrorsIgnorePattern": "^_"
Expand All @@ -48,4 +48,4 @@
}
]
}
}
}
3 changes: 3 additions & 0 deletions .github/CODEOWNERS
Validating CODEOWNERS rules …
Original file line number Diff line number Diff line change
Expand Up @@ -22,5 +22,8 @@ typescript/token @yorhodes @jmrossy @tkporter @aroralanuk
## Hello World
typescript/helloworld @yorhodes @nambrot

## CLI
typescript/cli @jmrossy @asaj
jmrossy marked this conversation as resolved.
Show resolved Hide resolved
jmrossy marked this conversation as resolved.
Show resolved Hide resolved

## Infra
typescript/infra @tkporter @nambrot
19 changes: 19 additions & 0 deletions .github/workflows/node.yml
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,25 @@ jobs:
- name: infra
run: yarn workspace @hyperlane-xyz/infra run test

test-cli:
runs-on: ubuntu-latest
needs: [yarn-build]
steps:
- uses: actions/checkout@v3
with:
submodules: recursive

- name: Install Foundry
uses: onbjerg/foundry-toolchain@v1

- uses: actions/cache@v3
with:
path: ./*
key: ${{ github.sha }}

- name: test
run: ./typescript/cli/ci-test.sh

test-env:
runs-on: ubuntu-latest
needs: [yarn-build]
Expand Down
1 change: 1 addition & 0 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ COPY typescript/utils/package.json ./typescript/utils/
COPY typescript/sdk/package.json ./typescript/sdk/
COPY typescript/helloworld/package.json ./typescript/helloworld/
COPY typescript/token/package.json ./typescript/token/
COPY typescript/cli/package.json ./typescript/cli/
COPY typescript/infra/package.json ./typescript/infra/
COPY solidity/package.json ./solidity/

Expand Down
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,8 @@
[codecov-badge]: https://img.shields.io/codecov/c/github/hyperlane-xyz/hyperlane-monorepo
[foundry]: https://getfoundry.sh/
[foundry-badge]: https://img.shields.io/badge/Built%20with-Foundry-FFDB1C.svg
[license]: https://opensource.org/licenses/MIT
[license-badge]: https://img.shields.io/badge/License-MIT-blue.svg
[license]: https://www.apache.org/licenses/LICENSE-2.0
[license-badge]: https://img.shields.io/badge/License-Apache-blue.svg

## Versioning

Expand Down
11 changes: 6 additions & 5 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,14 @@
"description": "A yarn workspace of core Hyperlane packages",
"version": "0.0.0",
"devDependencies": {
"@trivago/prettier-plugin-sort-imports": "^3.2.0",
"@trivago/prettier-plugin-sort-imports": "^4.2.0",
"@typescript-eslint/eslint-plugin": "^5.62.0",
"@typescript-eslint/parser": "^5.62.0",
"eslint": "^8.16.0",
"eslint-config-prettier": "^8.5.0",
"eslint": "^8.43.0",
"eslint-config-prettier": "^8.8.0",
"husky": "^8.0.0",
"lint-staged": "^12.4.3",
"prettier": "^2.4.1"
"prettier": "^2.8.8"
},
"packageManager": "[email protected]",
"private": true,
Expand All @@ -37,6 +37,7 @@
"lodash": "^4.17.21",
"recursive-readdir": "^2.2.3",
"underscore": "^1.13",
"undici": "^5.11"
"undici": "^5.11",
"@trivago/prettier-plugin-sort-imports/@babel/parser": "^7.22.7"
}
}
9 changes: 5 additions & 4 deletions solidity/package.json
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
{
"name": "@hyperlane-xyz/core",
"description": "Core solidity contracts for Hyperlane",
"version": "1.5.1",
"version": "1.5.4-beta0",
"dependencies": {
"@eth-optimism/contracts": "^0.6.0",
"@hyperlane-xyz/utils": "1.5.1",
"@hyperlane-xyz/utils": "1.5.4-beta0",
"@openzeppelin/contracts": "^4.8.0",
"@openzeppelin/contracts-upgradeable": "^4.8.0"
},
Expand All @@ -18,7 +18,7 @@
"ethers": "^5.7.2",
"hardhat": "^2.16.1",
"hardhat-gas-reporter": "^1.0.9",
"prettier": "^2.4.1",
"prettier": "^2.8.8",
"prettier-plugin-solidity": "^1.0.0-beta.5",
"solhint": "^3.3.2",
"solhint-plugin-prettier": "^0.0.5",
Expand Down Expand Up @@ -56,5 +56,6 @@
"gas-ci": "yarn gas --check --tolerance 2 || (echo 'Manually update gas snapshot' && exit 1)",
"slither": "slither ."
},
"types": "dist/index.d.ts"
"types": "dist/index.d.ts",
"stableVersion": "1.5.3"
}
2 changes: 2 additions & 0 deletions typescript/cli/.eslintignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
node_modules
dist
5 changes: 5 additions & 0 deletions typescript/cli/.eslintrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"rules": {
"no-console": ["off"]
}
}
5 changes: 5 additions & 0 deletions typescript/cli/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
.env*
/dist
/cache
/configs
/artifacts
57 changes: 57 additions & 0 deletions typescript/cli/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
# Hyperlane CLI

The Hyperlane CLI is a command-line tool written in Typescript that facilitates common operations on Hyperlane, such as deploying the core contracts and/or warp routes to new chains.

## Hyperlane overview

Hyperlane is an interchain messaging protocol that allows applications to communicate between blockchains.

Developers can use Hyperlane to share state between blockchains, allowing them to build interchain applications that live natively across multiple chains.

To read more about interchain applications, how the protocol works, and how to integrate with Hyperlane, please see the [documentation](https://docs.hyperlane.xyz).

## Setup

Node 16 or newer is required.

**Option 1: Global install:**

```bash
# Install with NPM
npm install -g @hyperlane-xyz/cli
# Or uninstall old versions
npm uninstall -g @hyperlane-xyz/cli
```

**Option 2: Temp install:**

```bash
# Run via NPM's npx command
npx @hyperlane-xyz/cli
# Or via Yarn's dlx command
yarn dlx @hyperlane-xyz/cli
```

**Option 3: Run from source:**

```bash
git clone https://github.com/hyperlane-xyz/hyperlane-monorepo.git
cd hyperlane-monorepo
yarn install && yarn build
cd typescript/cli
yarn hyperlane
```

## Common commands

View help: `hyperlane --help`

Create a core deployment config: `hyperlane config create`

Run hyperlane core deployments: `hyperlane deploy core`

Run warp route deployments: `hyperlane deploy warp`

View SDK contract addresses: `hyperlane chains addresses`

Send test message: `hyperlane send message`
167 changes: 167 additions & 0 deletions typescript/cli/ci-test.sh
jmrossy marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,167 @@
for CHAIN in anvil1 anvil2
do
mkdir /tmp/$CHAIN \
/tmp/$CHAIN/state \
/tmp/$CHAIN/validator \
/tmp/$CHAIN/relayer && \
chmod 777 /tmp/$CHAIN -R
done

anvil --chain-id 31337 -p 8545 --state /tmp/anvil1/state > /dev/null &
ANVIL_1_PID=$!

anvil --chain-id 31338 -p 8555 --state /tmp/anvil2/state > /dev/null &
ANVIL_2_PID=$!

sleep 1

set -e

echo "{}" > /tmp/empty-artifacts.json

echo "Deploying contracts to anvil1"
yarn workspace @hyperlane-xyz/cli run hyperlane deploy core \
--chains ./examples/anvil-chains.yaml \
--artifacts /tmp/empty-artifacts.json \
--out /tmp \
--ism ./examples/multisig-ism.yaml \
--origin anvil1 --remotes anvil2 \
--key 0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80 \
--yes

CORE_ARTIFACTS_FILE=`find /tmp/core-deployment* -type f -exec ls -t1 {} + | head -1`

echo "Deploying contracts to anvil2"
yarn workspace @hyperlane-xyz/cli run hyperlane deploy core \
--chains ./examples/anvil-chains.yaml \
--artifacts $CORE_ARTIFACTS_FILE \
--out /tmp \
--ism ./examples/multisig-ism.yaml \
--origin anvil2 --remotes anvil1 \
--key 0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80 \
--yes

CORE_ARTIFACTS_FILE=`find /tmp/core-deployment* -type f -exec ls -t1 {} + | head -1`

echo "Deploying warp routes"
yarn workspace @hyperlane-xyz/cli run hyperlane deploy warp \
--chains ./examples/anvil-chains.yaml \
--core $CORE_ARTIFACTS_FILE \
--config ./examples/warp-tokens.yaml \
--out /tmp \
--key 0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80 \
--yes

echo "Sending test message"
yarn workspace @hyperlane-xyz/cli run hyperlane send message \
--origin anvil1 \
--destination anvil2 \
--chains ./examples/anvil-chains.yaml \
--core $CORE_ARTIFACTS_FILE \
--quick \
--key 0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80 \
| tee /tmp/message1

MESSAGE1_ID=`cat /tmp/message1 | grep "Message ID" | grep -oP '0x[0-9a-f]+'`
echo "Message 1 ID: $MESSAGE1_ID"

WARP_ARTIFACTS_FILE=`find /tmp/warp-deployment* -type f -exec ls -t1 {} + | head -1`
ANVIL1_ROUTER=`cat $WARP_ARTIFACTS_FILE | jq -r ".anvil1.router"`

echo "Sending test warp transfer"
yarn workspace @hyperlane-xyz/cli run hyperlane send transfer \
--origin anvil1 \
--destination anvil2 \
--chains ./examples/anvil-chains.yaml \
--core $CORE_ARTIFACTS_FILE \
--router $ANVIL1_ROUTER \
--type native \
--quick \
--key 0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80 \
| tee /tmp/message2

MESSAGE2_ID=`cat /tmp/message2 | grep "Message ID" | grep -oP '0x[0-9a-f]+'`
echo "Message 2 ID: $MESSAGE2_ID"

kill $ANVIL_1_PID
kill $ANVIL_2_PID

anvil --chain-id 31337 -p 8545 --block-time 1 --state /tmp/anvil1/state > /dev/null &
ANVIL_1_PID=$!

anvil --chain-id 31338 -p 8555 --block-time 1 --state /tmp/anvil2/state > /dev/null &
ANVIL_2_PID=$!

AGENT_CONFIG_FILE=`ls -t1 /tmp | grep agent-config | head -1`

for i in "anvil1 8545 ANVIL1" "anvil2 8555 ANVIL2"
do
set -- $i
echo "Running validator on $1"
# Won't work on anything but linux due to -net=host
docker run \
--mount type=bind,source="/tmp",target=/data --net=host \
-e CONFIG_FILES=/data/${AGENT_CONFIG_FILE} -e HYP_VALIDATOR_ORIGINCHAINNAME=$1 \
-e HYP_VALIDATOR_REORGPERIOD=0 -e HYP_VALIDATOR_INTERVAL=1 \
-e HYP_BASE_CHAINS_${3}_CONNECTION_URL=http://127.0.0.1:${2} \
-e HYP_VALIDATOR_VALIDATOR_TYPE=hexKey \
-e HYP_VALIDATOR_VALIDATOR_KEY=0x2a871d0798f97d79848a013d4936a73bf4cc922c825d33c1cf7073dff6d409c6 \
-e HYP_VALIDATOR_CHECKPOINTSYNCER_TYPE=localStorage \
-e HYP_VALIDATOR_CHECKPOINTSYNCER_PATH=/data/${1}/validator \
-e HYP_BASE_TRACING_LEVEL=warn -e HYP_BASE_TRACING_FMT=pretty \
gcr.io/abacus-labs-dev/hyperlane-agent:main ./validator &
done

echo "Validator running, sleeping to let it sync"
sleep 15
echo "Done sleeping"

echo "Core artifacts:"
cat $CORE_ARTIFACTS_FILE

echo "Validator Announcement:"
cat /tmp/anvil1/validator/announcement.json

for i in "anvil1 anvil2 ANVIL2" "anvil2 anvil1 ANVIL1"
do
set -- $i
echo "Running relayer on $1"
docker run \
--mount type=bind,source="/tmp",target=/data --net=host \
-e CONFIG_FILES=/data/${AGENT_CONFIG_FILE} \
-e HYP_BASE_CHAINS_ANVIL1_CONNECTION_URL=http://127.0.0.1:8545 \
-e HYP_BASE_CHAINS_ANVIL2_CONNECTION_URL=http://127.0.0.1:8555 \
-e HYP_BASE_TRACING_LEVEL=warn -e HYP_BASE_TRACING_FMT=pretty \
-e HYP_RELAYER_ORIGINCHAINNAME=$1 -e HYP_RELAYER_DESTINATIONCHAINNAMES=$2 \
-e HYP_RELAYER_ALLOWLOCALCHECKPOINTSYNCERS=true -e HYP_RELAYER_DB=/data/$1/relayer \
-e HYP_RELAYER_GASPAYMENTENFORCEMENT='[{"type":"none"}]' \
-e HYP_BASE_CHAINS_${3}_SIGNER_TYPE=hexKey \
-e HYP_BASE_CHAINS_${3}_SIGNER_KEY=0xdbda1821b80551c9d65939329250298aa3472ba22feea921c0cf5d620ea67b97 \
-log-driver none \
gcr.io/abacus-labs-dev/hyperlane-agent:main ./relayer &
done

sleep 5
echo "Done running relayer, checking message delivery statuses"

for i in "1 $MESSAGE1_ID" "2 $MESSAGE2_ID"
do
set -- $i
echo "Checking delivery status of $1: $2"
yarn workspace @hyperlane-xyz/cli run hyperlane status \
--id $2 \
--destination anvil2 \
--chains ./examples/anvil-chains.yaml \
--core $CORE_ARTIFACTS_FILE \
| tee /tmp/message-status-$1
if ! grep -q "$2 was delivered" /tmp/message-status-$1; then
echo "ERROR: Message $1 was not delivered"
exit 1
else
echo "Message $1 was delivered!"
fi
done

docker ps -aq | xargs docker stop | xargs docker rm
kill $ANVIL_1_PID
kill $ANVIL_2_PID
Loading
Loading