Skip to content

Commit

Permalink
docs: list ibc-rs adoption on README (informalsystems#1241)
Browse files Browse the repository at this point in the history
* ibc adaption list

* added legend for table

* fixed some names

* reflow

* update adoption table

* add intro paragraph

* changes from composable team

* fix md syntax

* update git emojis

* markdown format and grammar nits

* consistent grammar

---------

Co-authored-by: Adi Seredinschi <[email protected]>
Co-authored-by: Sean Chen <[email protected]>
  • Loading branch information
3 people authored Jun 19, 2024
1 parent 8424f69 commit 0bff1e8
Showing 1 changed file with 56 additions and 19 deletions.
75 changes: 56 additions & 19 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,12 +12,10 @@
</div>
<div>

[![Docs][docs-image]][docs-link]
[![Build Status][build-image]][build-link]
[![Docs][docs-image]][docs-link] [![Build Status][build-image]][build-link]
[![Code Coverage][codecov-image]][codecov-link]
[![Apache 2.0 Licensed][license-image]][license-link]
![Version][crates-io-version]
![Downloads][crates-io-downloads]
![Version][crates-io-version] ![Downloads][crates-io-downloads]
![Rust Stable][msrv-image]

</div>
Expand All @@ -30,23 +28,23 @@ sub-crates that can be used independently or together.

## Project Structure

| <div style="width:100px">Crate</div> | Description |
| ------------------------------------- | ----------- |
|[ibc](ibc) | Re-exports all the data structures and on-chain logic of various IBC core, clients and applications. |
|[ibc-data-types](ibc-data-types) | Re-exports all the IBC data types that are shared across different IBC implementations. |
|[ibc-core](ibc-core) | Contains data structures and implementations of all the IBC core specifications. |
|[ibc-clients](ibc-clients) | Contains data structures and implementations of various IBC light clients. |
|[ibc-apps](ibc-apps) | Contains data structures and implementations of various IBC applications. |
|[ibc-testkit](ibc-testkit) | Provides testing toolkit to aid `ibc-rs` and host chains in writing integration tests. |
|[ibc-query](ibc-query) | Contains utility traits and implementations for querying states of an integrated IBC module. |
|[ibc-derive](ibc-derive) | Derive macros for `ClientState` and `ConsensusState` traits, reducing boilerplate. |
| <div style="width:100px">Crate</div> | Description |
| ------------------------------------ | ---------------------------------------------------------------------------------------------------- |
| [ibc](ibc) | Re-exports all the data structures and on-chain logic of various IBC core, clients and applications. |
| [ibc-data-types](ibc-data-types) | Re-exports all the IBC data types that are shared across different IBC implementations. |
| [ibc-core](ibc-core) | Contains data structures and implementations of all the IBC core specifications. |
| [ibc-clients](ibc-clients) | Contains data structures and implementations of various IBC light clients. |
| [ibc-apps](ibc-apps) | Contains data structures and implementations of various IBC applications. |
| [ibc-testkit](ibc-testkit) | Provides testing toolkit to aid `ibc-rs` and host chains in writing integration tests. |
| [ibc-query](ibc-query) | Contains utility traits and implementations for querying states of an integrated IBC module. |
| [ibc-derive](ibc-derive) | Derive macros for `ClientState` and `ConsensusState` traits, reducing boilerplate. |

## Contributing

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

If you're interested in contributing, please take a look at the
If you're interested in contributing, please refer to the
[CONTRIBUTING](./CONTRIBUTING.md) guidelines. We welcome and appreciate
community contributions!

Expand All @@ -73,9 +71,48 @@ development.
- [IBC Go implementation][ibc-go]
- [Protobuf definitions in Rust][ibc-proto-rs]

## `ibc-rs` in the wild

The [IBC Protocol][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-case | Team | Used-Modules | Links | Phase |
| -: | ------------------------------- | :-----------: | :----------: | :---------------------------------------------------------: | :----------------------: |
| 1 | Solana IBC implementation | Composable | :100: | [Picasso Network][pica-network] | :white_check_mark: |
| 2 | Ethereum IBC relayer | Composable | :100: | [Picasso Network][pica-network] | :white_check_mark: |
| 3 | Polkadot SDK IBC implementation | Composable | :100: | [Picasso Network][pica-network] | :white_check_mark: |
| 4 | Nomic | Nomic | :100: | [Nomic network][nomic] | :white_check_mark: |
| 5 | Namada | Anoma | :100: | [Namada][namada] | :hourglass_flowing_sand: |
| 6 | Sovereign | Informal | :100: | [`sovereign-ibc`][sov-ibc] | :hourglass_flowing_sand: |
| 7 | Hermes IBC relayer | Informal | :100: | [`basecoin-rs`][basecoin-rs] | :hammer_and_pick: |
| 8 | Substrate pallet | Octopus | :100: | [Substrate IBC Pallet][substrate-ibc] | :hammer_and_pick: |
| 9 | Near Protocol | Octopus | :100: | [`near-ibc`][near-ibc] | :hourglass_flowing_sand: |
| 10 | Tendermint Light Client | Electron Labs | `ics07` | [`Electron-Labs/tendermint-rs`][electronlabs-tendermint-rs] | :hourglass_flowing_sand: |
| 11 | Starknet | Informal | :eyes: | :eyes: | :eyes: |

Legend:

- :white_check_mark: IBC integration in production
- :hourglass_flowing_sand: IBC integration in development (testnet or devnet)
- :hammer_and_pick: used in testing and/or development
- :100: full IBC integration
- :eyes: early exploration phase

[pica-network]: https://www.picasso.network
[nomic]: https://www.nomic.io
[namada]: https://namada.net
[basecoin-rs]: https://github.com/informalsystems/basecoin-rs
[hermes]: https://hermes.informal.systems
[sov-ibc]: https://github.com/informalsystems/sovereign-ibc
[substrate-ibc]: https://github.com/octopus-network/substrate-ibc
[near-ibc]: https://github.com/octopus-network/near-ibc
[electronlabs-tendermint-rs]: https://github.com/Electron-Labs/tendermint-rs

## License

Copyright © 2022 Informal Systems Inc. and ibc-rs authors.
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
Expand All @@ -100,12 +137,12 @@ specific language governing permissions and limitations under the License.
[crates-io-version]: https://img.shields.io/crates/v/ibc.svg
[crates-io-downloads]: https://img.shields.io/crates/d/ibc.svg
[msrv-image]: https://img.shields.io/crates/msrv/ibc

[//]: # (general links)
[ibc]: https://github.com/cosmos/ibc
[ibc-go]: https://github.com/cosmos/ibc-go
[ibc-proto-rs]: https://github.com/cosmos/ibc-proto-rs
[ibc-homepage]: https://cosmos.network/ibc
[ibc-protocol]: https://ibcprotocol.dev
[cosmos-link]: https://cosmos.network
[semver]: https://semver.org/
[cosmos-shield]: https://img.shields.io/static/v1?label=&labelColor=1B1E36&color=1B1E36&message=cosmos%20ecosystem&style=for-the-badge&logo=

0 comments on commit 0bff1e8

Please sign in to comment.