Hermes
IBC Relayer in Rust
Install / Use
/learn @informalsystems/HermesREADME
Hermes IBC relayer
[][cosmos-link]
Rust implementation of an Inter-Blockchain Communication (IBC) relayer.
This project comprises primarily of 6 crates:
ibc-relayerprovides an implementation of an IBC relayer, as a library.ibc-relayer-cliis a CLI (a wrapper over theibc-relayerlibrary), comprising thehermesbinary.ibc-chain-registryprovides functions to fetch data from the chain registry and automatically generate chain configuration for Hermes.ibc-telemetryis a library for use in the Hermes CLI, for gathering telemetry data and exposing that in a Prometheus endpoint.ibc-relayer-restis a library for use in the Hermes CLI, for exposing a REST API to inspect the state of the relayer.ibc-test-frameworkprovides the infrastructure and framework for writing end-to-end (E2E) tests that include the spawning of the relayer together with Cosmos full nodes.
See the table below for more details.
⚠️ The
ibcandibc-protocrates have been moved to their own repositories.
The repository also includes TLA+ specifications.
Status
| Crate name | Type | Version | Docs |
|:-------------:|:------:|:-------------:|:-----:|
| ibc-relayer-cli | bin: hermes | |
|
| ibc-relayer | lib |
|
|
| ibc-chain-registry | lib |
|
|
| ibc-relayer-rest | lib |
|
|
| ibc-telemetry | lib |
|
|
| ibc-test-framework | lib |
|
|
Requirements
The crates in this project require Rust 1.85.0.
Hermes Guide
We have a comprehensive guide at hermes.informal.systems.
Support
If you encounter any issues or have questions related to Hermes, we encourage you to open a GitHub issue. This ensures a streamlined process for tracking and resolving problems.
Please use the following link to report your issue: https://github.com/informalsystems/hermes/issues/new?assignees=&labels=&projects=&template=bug-report.md
Providing clear and detailed information in your issue will help us address it more efficiently.
Contributing
IBC is specified in English in the cosmos/ibc repo. Any protocol changes or clarifications should be contributed there.
This repo contains the TLA+ specification and Rust implementation for the IBC modules and relayer. If you're interested in contributing, please comment on an issue or open a new one!
See also CONTRIBUTING.md.
Versioning
We follow Semantic Versioning, though APIs are still under active development.
Resources
License
Copyright © 2023 Informal Systems Inc. and Hermes authors.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use the files in this repository except in compliance with the License. You may obtain a copy of the License at
https://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
<!-- markdown-link-check-disable --> <!-- markdown-link-check-enabled -->Related Skills
himalaya
346.4kCLI to manage emails via IMAP/SMTP. Use `himalaya` to list, read, write, reply, forward, search, and organize emails from the terminal. Supports multiple accounts and message composition with MML (MIME Meta Language).
node-connect
346.4kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
taskflow
346.4kname: taskflow description: Use when work should span one or more detached tasks but still behave like one job with a single owner context. TaskFlow is the durable flow substrate under authoring layer
frontend-design
107.2kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
