The home for Hyperlane core contracts, sdk packages, and other infrastructure
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
hyperlane-monorepo/typescript/cli
Noah Bayindirli 🥂 a2a633b4df Merge branch 'main' into noah/merge 4 months ago
..
examples feat: implement hyperlane core deploy (#3869) 5 months ago
src Merge branch 'main' into noah/merge 4 months ago
test-configs Migrate SDK consts to Registry and use new registry utilities (#3615) 6 months ago
.eslintignore Main-to-v3 update and V3 CLI (#2818) 12 months ago
.eslintrc Main-to-v3 update and V3 CLI (#2818) 12 months ago
.gitignore Migrate SDK consts to Registry and use new registry utilities (#3615) 6 months ago
.mocharc.json Various CLI fixes and UX improvements (#2952) 11 months ago
CHANGELOG.md Version Packages (#3991) 4 months ago
README.md chore: Merge branch 'main' into cli-2.0 (#3863) 5 months ago
ci-advanced-test.sh Merge branch 'main' into noah/merge 4 months ago
cli.ts fix(cli): add hook/ism commands (#4060) 4 months ago
env.ts Add global log options to CLI (#3519) 7 months ago
package.json Merge branch 'main' into noah/merge 4 months ago
tsconfig.json Convert packages from CJS to ESM (#3531) 7 months ago

README.md

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.

Setup

Node 18 or newer is required.

Option 1: Global install:

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

Option 2: Temp install:

# 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:

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

Logging

The logging format can be toggled between human-readable vs JSON-structured logs using the LOG_FORMAT environment variable or the --log <pretty|json> flag. The logging verbosity can be configured using the LOG_LEVEL environment variable or the --verbosity <debug|info|warn|error|off> flag.