Home

Awesome

<div align="center"> <h1>ibc-rs</h1> </div>

banner

<div align="center"> <div>

Cosmos ecosystem

</div> <div>

Docs Build Status Code Coverage Apache 2.0 Licensed Version Downloads Rust Stable

</div> </div>

Rust implementation of the Inter-Blockchain Communication (IBC) protocol that hosts all the data structures and on-chain logic implementations of various IBC core, clients and applications. This repository organized as a collection of sub-crates that can be used independently or together.

Project Structure

<div style="width:100px">Crate</div>Description
ibcRe-exports all the data structures and on-chain logic of various IBC core, clients and applications.
ibc-data-typesRe-exports all the IBC data types that are shared across different IBC implementations.
ibc-coreContains data structures and implementations of all the IBC core specifications.
ibc-clientsContains data structures and implementations of various IBC light clients.
ibc-appsContains data structures and implementations of various IBC applications.
ibc-testkitProvides testing toolkit to aid ibc-rs and host chains in writing integration tests.
ibc-queryContains utility traits and implementations for querying states of an integrated IBC module.
ibc-deriveDerive macros for ClientState and ConsensusState traits, reducing boilerplate.

Contributing

IBC is specified in English in the cosmos/ibc repo. Any protocol changes or clarifications should be contributed there.

If you're interested in contributing, please refer to the CONTRIBUTING guidelines. We welcome and appreciate community contributions!

Community calls

The IBC-rs community calls are now part of the IBC Core community calls. During these calls, we update the community on our current direction and gather feedback on what to work on next. The community calls are also a platform for you to update everyone else on what you're working on and find opportunities to collaborate.

Please join the Google group to receive a calendar invitation to the monthly meetings.

Resources

ibc-rs in the wild

The IBC Protocol is integrated in numerous networks and projects. The ibc-rs implementation, in particular, is used for IBC integration, testing, or development for some of the most technically compelling use cases.

#Integration use-caseTeamUsed-ModulesLinksPhase
1Solana IBC implementationComposable:100:Picasso Network:white_check_mark:
2Ethereum IBC relayerComposable:100:Picasso Network:white_check_mark:
3Polkadot SDK IBC implementationComposable:100:Picasso Network:white_check_mark:
4NomicNomic:100:Nomic network:white_check_mark:
5CosmWasm Tendermint Light ClientInformalics07cosmwasm-ibc:white_check_mark:
6NamadaAnoma:100:Namada:hourglass_flowing_sand:
7SovereignInformal:100:sovereign-ibc:hourglass_flowing_sand:
8Hermes IBC relayerInformal:100:basecoin-rs:hammer_and_pick:
9Substrate palletOctopus:100:Substrate IBC Pallet:hammer_and_pick:
10Near ProtocolOctopus:100:near-ibc:hourglass_flowing_sand:
11Tendermint Light ClientElectron Labsics07Electron-Labs/tendermint-rs:hourglass_flowing_sand:
12StarknetInformal:eyes::eyes::eyes:
13SP1 Tendermint Light ClientInterchainics07cosmos/sp1-ics07-tendermint:hourglass_flowing_sand:

Legend:

License

Copyright © 2024 Informal Systems Inc. and ibc-rs 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.