Skip to content

Commit 0bff1e8

Browse files
rnbguyadizereseanchen1991
authored
docs: list ibc-rs adoption on README (#1241)
* 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 <a@seredinschi.net> Co-authored-by: Sean Chen <seanchen11235@gmail.com>
1 parent 8424f69 commit 0bff1e8

File tree

1 file changed

+56
-19
lines changed

1 file changed

+56
-19
lines changed

README.md

Lines changed: 56 additions & 19 deletions
Original file line numberDiff line numberDiff line change
@@ -12,12 +12,10 @@
1212
</div>
1313
<div>
1414

15-
[![Docs][docs-image]][docs-link]
16-
[![Build Status][build-image]][build-link]
15+
[![Docs][docs-image]][docs-link] [![Build Status][build-image]][build-link]
1716
[![Code Coverage][codecov-image]][codecov-link]
1817
[![Apache 2.0 Licensed][license-image]][license-link]
19-
![Version][crates-io-version]
20-
![Downloads][crates-io-downloads]
18+
![Version][crates-io-version] ![Downloads][crates-io-downloads]
2119
![Rust Stable][msrv-image]
2220

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

3129
## Project Structure
3230

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

4442
## Contributing
4543

46-
IBC is specified in English in the [cosmos/ibc repo][ibc]. Any protocol changes
47-
or clarifications should be contributed there.
44+
IBC is specified in English in the [`cosmos/ibc` repo][ibc]. Any protocol
45+
changes or clarifications should be contributed there.
4846

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

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

74+
## `ibc-rs` in the wild
75+
76+
The [IBC Protocol][ibc-protocol] is integrated in numerous networks and
77+
projects. The `ibc-rs` implementation, in particular, is used for IBC
78+
integration, testing, or development for some of the most technically compelling
79+
use cases.
80+
81+
| # | Integration use-case | Team | Used-Modules | Links | Phase |
82+
| -: | ------------------------------- | :-----------: | :----------: | :---------------------------------------------------------: | :----------------------: |
83+
| 1 | Solana IBC implementation | Composable | :100: | [Picasso Network][pica-network] | :white_check_mark: |
84+
| 2 | Ethereum IBC relayer | Composable | :100: | [Picasso Network][pica-network] | :white_check_mark: |
85+
| 3 | Polkadot SDK IBC implementation | Composable | :100: | [Picasso Network][pica-network] | :white_check_mark: |
86+
| 4 | Nomic | Nomic | :100: | [Nomic network][nomic] | :white_check_mark: |
87+
| 5 | Namada | Anoma | :100: | [Namada][namada] | :hourglass_flowing_sand: |
88+
| 6 | Sovereign | Informal | :100: | [`sovereign-ibc`][sov-ibc] | :hourglass_flowing_sand: |
89+
| 7 | Hermes IBC relayer | Informal | :100: | [`basecoin-rs`][basecoin-rs] | :hammer_and_pick: |
90+
| 8 | Substrate pallet | Octopus | :100: | [Substrate IBC Pallet][substrate-ibc] | :hammer_and_pick: |
91+
| 9 | Near Protocol | Octopus | :100: | [`near-ibc`][near-ibc] | :hourglass_flowing_sand: |
92+
| 10 | Tendermint Light Client | Electron Labs | `ics07` | [`Electron-Labs/tendermint-rs`][electronlabs-tendermint-rs] | :hourglass_flowing_sand: |
93+
| 11 | Starknet | Informal | :eyes: | :eyes: | :eyes: |
94+
95+
Legend:
96+
97+
- :white_check_mark: IBC integration in production
98+
- :hourglass_flowing_sand: IBC integration in development (testnet or devnet)
99+
- :hammer_and_pick: used in testing and/or development
100+
- :100: full IBC integration
101+
- :eyes: early exploration phase
102+
103+
[pica-network]: https://www.picasso.network
104+
[nomic]: https://www.nomic.io
105+
[namada]: https://namada.net
106+
[basecoin-rs]: https://github.com/informalsystems/basecoin-rs
107+
[hermes]: https://hermes.informal.systems
108+
[sov-ibc]: https://github.com/informalsystems/sovereign-ibc
109+
[substrate-ibc]: https://github.com/octopus-network/substrate-ibc
110+
[near-ibc]: https://github.com/octopus-network/near-ibc
111+
[electronlabs-tendermint-rs]: https://github.com/Electron-Labs/tendermint-rs
112+
76113
## License
77114

78-
Copyright © 2022 Informal Systems Inc. and ibc-rs authors.
115+
Copyright © 2024 Informal Systems Inc. and `ibc-rs` authors.
79116

80117
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
81118
the files in this repository except in compliance with the License. You may
@@ -100,12 +137,12 @@ specific language governing permissions and limitations under the License.
100137
[crates-io-version]: https://img.shields.io/crates/v/ibc.svg
101138
[crates-io-downloads]: https://img.shields.io/crates/d/ibc.svg
102139
[msrv-image]: https://img.shields.io/crates/msrv/ibc
103-
104140
[//]: # (general links)
105141
[ibc]: https://github.com/cosmos/ibc
106142
[ibc-go]: https://github.com/cosmos/ibc-go
107143
[ibc-proto-rs]: https://github.com/cosmos/ibc-proto-rs
108144
[ibc-homepage]: https://cosmos.network/ibc
145+
[ibc-protocol]: https://ibcprotocol.dev
109146
[cosmos-link]: https://cosmos.network
110147
[semver]: https://semver.org/
111148
[cosmos-shield]: https://img.shields.io/static/v1?label=&labelColor=1B1E36&color=1B1E36&message=cosmos%20ecosystem&style=for-the-badge&logo=

0 commit comments

Comments
 (0)