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.
 
 
 
 
 
 
Noah Bayindirli 🥂 21b62faea4
address new license warnings on hyp*coll contracts (#3727)
7 months ago
.changeset Version Packages (#3718) 7 months ago
.codespell Add code spellcheck CI job (#3467) 8 months ago
.github Migrate SDK consts to Registry and use new registry utilities (#3615) 7 months ago
.husky export tx provider from sdk & remove safe util from infra (#3694) 7 months ago
.yarn Convert packages from CJS to ESM (#3531) 8 months ago
rust WIP: don't hardcode multicall gas limit (#3710) 7 months ago
solidity address new license warnings on hyp*coll contracts (#3727) 7 months ago
tools/grafana chore: Use templating for datasource in grafana dashboard file (#2542) 1 year ago
typescript Always get endpoint and endpoints secrets in helm charts (#3686) 7 months ago
vectors Support cosmos contract byte lengths other than 32 (#3147) 10 months ago
.dockerignore Hyperlane packages and typescript rebrand (#1077) 2 years ago
.eslintignore Convert packages from CJS to ESM (#3531) 8 months ago
.eslintrc Remove accidental .only and update lint rules (#3614) 8 months ago
.gitattributes Add Cosmos support to Utils and SDK (#2859) 1 year ago
.gitignore V3 agents rebase (#2746) 1 year ago
.gitmodules v3 Router SDK changes (#2752) 1 year ago
.lintstagedrc Fix prettier + githook (#503) 3 years ago
.prettierignore Sealevel (#2404) 1 year ago
.prettierrc Convert packages from CJS to ESM (#3531) 8 months ago
.yarnrc.yml Upgrade to yarn 4.0.2 1 year ago
CODE_OF_CONDUCT.md Add code spellcheck CI job (#3467) 8 months ago
CONTRIBUTING.md Add code spellcheck CI job (#3467) 8 months ago
DISCLAIMER.md Hyperlane packages and typescript rebrand (#1077) 2 years ago
Dockerfile Convert packages from CJS to ESM (#3531) 8 months ago
LICENSE.md chore: add APACHE2.0 license 4 years ago
README.md Add global log options to CLI (#3519) 8 months ago
codecov.yml Add code spellcheck CI job (#3467) 8 months ago
mono.code-workspace [Chore] Fix VSCode formatting and prettier precommit (#501) 3 years ago
package.json Remove accidental .only and update lint rules (#3614) 8 months ago
rust-toolchain Merge main to v3 (#2812) 1 year ago
tsconfig.json Convert packages from CJS to ESM (#3531) 8 months ago
yarn.lock Version Packages (#3718) 7 months ago

README.md

Hyperlane

GitHub Actions codecov Foundry License: MIT

Versioning

Note this is the branch for Hyperlane v3.

V2 is still in operation but is not being actively developed. The code for V2 can be found in the v2 branch.

V1 has since been deprecated in favor of V2, but if you are looking for code relating to the existing V1 deployments, refer to the v1 branch.

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.

Working on Hyperlane

Foundry

First ensure you have Foundry installed on your machine.

Run the following to install foundryup:

curl -L https://foundry.paradigm.xyz | bash

Then run foundryup to install forge, cast, anvil and chisel.

foundryup

Check out the Foundry Book for more information.

Workspaces

This monorepo uses Yarn Workspaces. Installing dependencies, building, testing, and running prettier for all packages can be done from the root directory of the repository.

  • Installing dependencies

    yarn install
    
  • Building

    yarn build
    

If you are using VSCode, you can launch the multi-root workspace with code mono.code-workspace, install the recommended workspace extensions, and use the editor settings.

Logging

The typescript tooling uses Pino based logging, which outputs structured JSON logs by default. The verbosity level and style can be configured with environment variables:

LOG_LEVEL=DEBUG|INFO|WARN|ERROR|OFF
LOG_FORMAT=PRETTY|JSON

Rust

See rust/README.md

Release Agents

  • Tag the commit with the current date in the format agents-yyyy-mm-dd; e.g. agents-2023-03-28.
  • Create a Github Release with a changelog against the previous version titled Agents MMMM DD, YYYY, e.g. Agents March 28, 2023.
  • Include the agent docker image tag in the description of the release
  • Create a summary of change highlights
  • Create a "breaking changes" section with any changes required
  • Deploy agents with the new image tag (if it makes sense to)