-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit fa0e96a
Showing
426 changed files
with
38,989 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
name: "release-docs" | ||
on: | ||
push: | ||
branches: | ||
- release-* | ||
- main | ||
pull_request: | ||
merge_group: | ||
types: [checks_requested] | ||
|
||
permissions: | ||
pull-requests: write | ||
|
||
env: | ||
NIX_VERSION: nix-2.13.2 | ||
NIXPKGS_CHANNEL: nixos-22.11 | ||
CACHIX_COMPRESSION_LEVEL: 16 | ||
CACHIX_JOBS: 8 | ||
CACHIX_COMPRESSION_METHOD: zstd | ||
CACHIX_NAME: composable | ||
|
||
jobs: | ||
deploy-docs: | ||
name: "deploy-docs" | ||
runs-on: ubuntu-latest | ||
concurrency: | ||
group: ${{ github.workflow }}-deploy-docs-${{ github.event.pull_request.title }} | ||
cancel-in-progress: true | ||
steps: | ||
- name: Set up Nix | ||
if: ${{ github.event_name == 'push' || (inputs.github_event_name == 'pull_request' && inputs.github_event_pull_request_head_repo_id == 383289760) }} | ||
uses: cachix/install-nix-action@daddc62a2e67d1decb56e028c9fa68344b9b7c2a # v18 | ||
with: | ||
install_url: https://releases.nixos.org/nix/${{ env.NIX_VERSION }}/install | ||
nix_path: nixpkgs=channel:${{ env.NIXPKGS_CHANNEL }} | ||
extra_nix_config: | | ||
sandbox = relaxed | ||
narinfo-cache-negative-ttl = 0 | ||
system-features = kvm | ||
- name: Set up Cachix | ||
if: ${{ github.event_name == 'push' || (inputs.github_event_name == 'pull_request' && inputs.github_event_pull_request_head_repo_id == 383289760) }} | ||
uses: cachix/cachix-action@298387a7aea14d6564aa5d6ead79272878339c8b # v12 | ||
with: | ||
authToken: "${{ secrets.CACHIX_AUTH_TOKEN }}" | ||
name: ${{ env.CACHIX_NAME }} | ||
- name: Add tools needed for non-nix steps | ||
if: ${{ github.event_name == 'push' || (inputs.github_event_name == 'pull_request' && inputs.github_event_pull_request_head_repo_id == 383289760) }} | ||
run: | | ||
nix-channel --add https://nixos.org/channels/${{ env.NIXPKGS_CHANNEL }} nixpkgs | ||
nix-channel --update | ||
nix-env -iA nixpkgs.cachix nixpkgs.nodejs nixpkgs.git nixpkgs.git-lfs | ||
- uses: actions/checkout@v3 | ||
if: ${{ github.event_name == 'push' || (inputs.github_event_name == 'pull_request' && inputs.github_event_pull_request_head_repo_id == 383289760) }} | ||
with: | ||
lfs: true | ||
ref: ${{ github.event.pull_request.head.sha }} | ||
persist-credentials: false | ||
- name: Build docs | ||
if: ${{ github.event_name == 'push' || (inputs.github_event_name == 'pull_request' && inputs.github_event_pull_request_head_repo_id == 383289760) }} | ||
uses: "./.github/templates/watch-exec" | ||
with: | ||
command: nix -- build .#docs-static | ||
working-directory: ./docs | ||
|
||
- name: Deploy docs | ||
if: ${{ github.event_name == 'push' || (inputs.github_event_name == 'pull_request' && inputs.github_event_pull_request_head_repo_id == 383289760) }} | ||
uses: FirebaseExtended/action-hosting-deploy@0f248036885ae672f78587669fa2923f0ef6cac2 | ||
with: | ||
firebaseServiceAccount: ${{ secrets.FIREBASE_SERVICE_ACCOUNT_DOCS_COMPOSABLE_FINANCE }} | ||
projectId: composable-docs | ||
entrypoint: docs/ | ||
# this must go same release flow as FE, not from main | ||
channelId: ${{ github.event_name == 'push' && github.ref_name == 'main' && 'live' }} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
### Installation | ||
|
||
``` | ||
$ yarn | ||
``` | ||
|
||
### Local Development | ||
|
||
``` | ||
$ yarn start | ||
``` | ||
|
||
This command starts a local development server and opens up a browser window. Most changes are reflected live without having to restart the server. | ||
|
||
### Build | ||
|
||
``` | ||
$ yarn build | ||
``` | ||
|
||
This command generates static content into the `build` directory and can be served using any static contents hosting service. | ||
|
||
### Deployment | ||
|
||
Using SSH: | ||
|
||
``` | ||
$ USE_SSH=true yarn deploy | ||
``` | ||
|
||
Not using SSH: | ||
|
||
``` | ||
$ GIT_USER=<Your GitHub username> yarn deploy | ||
``` | ||
|
||
If you are using GitHub pages for hosting, this command is a convenient way to build the website and push to the `gh-pages` branch. | ||
|
||
|
||
## Via Nix | ||
|
||
## Serving a hot-reloading version of these docs | ||
|
||
To serve a hot-reloading version of these docs, simply run: | ||
|
||
```bash | ||
nix run ".#docs-dev" | ||
``` | ||
|
||
And open [http://localhost:3000](http://localhost:3000/) in your browser. | ||
|
||
Then, edit the sources in `docs/`, and see them update live in your browser! | ||
|
||
## Building a static copy | ||
|
||
If you want to build a static copy of these docs, run: | ||
|
||
```bash | ||
nix build ".#docs-static" | ||
``` | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
module.exports = { | ||
presets: [require.resolve('@docusaurus/core/lib/babel/preset')], | ||
}; |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
# Definitions | ||
|
||
### Actively Validated Services (AVSes) | ||
A project or protocol that needs distributed validation and acquires said validation via restaking. Examples of AVSes are middleware services, layer 2 networks, bridges, data layers, and dApps. | ||
|
||
### Composable Virtual Machine (CVM) | ||
An orchestration language and execution runtime for cross-chain program execution and intents settlement that operates, specifically over IBC. | ||
|
||
### Cross-Domain Maximal Extractible Value (MEV) | ||
The maximum value that can be captured from arbitrage transactions executed in a specified order across multiple domains. See: Maximal Extractible Value. | ||
|
||
### Cryptoeconomic Security | ||
A model for securing a network via economic incentives and cryptography. | ||
|
||
### Generalized Restaking | ||
A mechanism for restaking an asset from a starting location on any chain, such that the cryptoeconomic security provided can be used by Actively Validated Services on any other chain. See: Actively Validated Services, Cryptoeconomic Security, and Restaking. | ||
|
||
### Inter-Blockchain Communication (IBC) Protocol | ||
A cross-chain messaging protocol for trust-minimized communication between different blockchains; website here. | ||
|
||
### Light Clients | ||
Lightweight, trustless mechanisms for verifying the state of the counterparty blockchain; these are essential for IBC communication. | ||
|
||
### Maximal Extractible Value (MEV) | ||
The maximal value extractable between one or more blocks, given any arbitrary re-ordering, insertion or censorship of pending or existing transactions (as defined by Obadia et al., 2021). | ||
|
||
### Multichain-Agnostic Normalized Trust-Minimized Intent Settlement (MANTIS) | ||
A vertically integrated, optimized intents settlement framework with expression, execution, and settlement. | ||
|
||
### Operators | ||
Entities responsible for executing off-chain software logic restaked from an AVS. See: Actively Validated Services. | ||
|
||
### Restaking | ||
A new primitive in crypto-economic security that enables the rehypothecation of a token on the consensus layer. | ||
|
||
### Sync Committee | ||
A committee of 512 validators that is randomly selected every sync committee period (~1 day). While a validator is part of the currently active sync committee, they are expected to continually sign the block header that is the new head of the chain at each slot. | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,113 @@ | ||
# What is the IBC Protocol? | ||
|
||
Before delving into an understanding of the IBC protocol, it's crucial to comprehend why choosing IBC is important and why the existing bridging solutions won't suffice to bring DeFi to the masses. | ||
|
||
## Issues in cross-chain infrastructure | ||
|
||
The main objective of bridging infrastructure is to integrate the different blockchain asset and data markets to unify the fragmentation of liquidity. This integration is similar to how stock exchanges are connected through electronic trading to enable the transfer of capital. However, bridges are currently facing significant safety issues due to the reliance on various trust assumptions that custodial and multi-sig-based bridges carry. | ||
|
||
Over $2 billion has been lost due to hacks, with many of the most significant attacks occurring across multiple chains, where cross-chain bridges and CEX hot wallets accounted for over 52% of the total stolen funds in crypto. A trusted bridge is a connection between two blockchain networks that relies on a third party to facilitate the transfer of assets between the two networks. This third party is responsible for ensuring the security and reliability of the bridge, and users must trust this party to handle their transactions properly. | ||
|
||
If security is not prioritized, these risks will become even more widespread. | ||
|
||
During the market cycle of 2020-2021, as new ecosystems gained prominence, numerous bridging protocols emerged to address the growing need for liquidity. Most, if not all, of these bridges were built on optimistic, fraud-sensitive architectures, relying on trusted third parties, oracles, and multi-signatures. In addition to facilitating asset transfers, some of these bridges also supported message passing, which could serve as a foundational element for cross-chain applications. However, these bridges have proven to pose security risks to DeFi and are challenging to build protocols on top of due to the limited features offered by message passing. | ||
|
||
In a trusted bridging setup, we identify the following actors: | ||
|
||
- Relayer: pays for execution on the destination chain. | ||
- Oracle: provides authorized mint and burn access to the contracts on origin and destination side. | ||
- User: a contract, protocol or actual user directly interacting with the bridge. | ||
|
||
In this generic architecture, we choose to keep the relayer and oracle as separate actors, although in many actual implementations, these are the same entity. | ||
|
||
Designs used in Wormhole, Axelar and centralized exchanges use one or more accounts to determine the state of the origin chain, destination chain, and based on that co-sign a message to mint/unlock funds on the destination side. | ||
|
||
### Pessimistic & Optimistic bridges | ||
**Pessimistic bridges** require the oracle to pre-validate withdrawals, assuming that relayers will commit fraud as soon as they can. | ||
|
||
The oracle assumes multiple responsibilities here: | ||
|
||
1. It ensures that the event data is correct. | ||
2. It ensures that the event data is final. | ||
|
||
For many chains, including Ethereum, the second responsibility cannot yet be ensured, and thus the oracle service is taking on a large risk. Usually this is reduced by waiting for a number of confirmations (blocks built on top of the current block). | ||
|
||
From the on-chain perspective, funds are managed assuming that the oracle is honest about both responsibilities. Fraud, hacks or misconfigurations can lead to the oracle's authority being used to incorrectly release funds, as occured in Wormhole. | ||
|
||
Different protocols attempt to reduce this risk by sharding the private key using multi party computation (MPC), or simply using a multisig. | ||
|
||
For a secure bridging operation, the transaction time $t$ is given by: | ||
|
||
$$ t := t_{finality} + t_{submission} $$ | ||
|
||
where $t_{finality}$ is the average duration for block finality, and $t_{submission}$ the length of time of block inclusion on the destination side. | ||
|
||
**Optimistic bridges** assume that the relayer is usually honest, and fraud rarely occurs. The relayer/oracle algorithm is relatively identical to the algorithm. On the contract side however, the mint/unlock action is delayed, ensuring that fishermen have sufficient time to dispute the message. | ||
|
||
Message acceptance is incredibly simple, for example: | ||
|
||
``` | ||
\begin{algorithm}[H] | ||
\SetAlgoLined | ||
\BlankLine | ||
\If{message is from relayer}{ | ||
store(message) | ||
} | ||
\caption{Message acceptance protocol for optimistic trusted bridges} | ||
\end{algorithm} | ||
``` | ||
|
||
However, actually enacting the message, which leads to mints and unlocks, there is a time delay, referred to as the dispute window. | ||
``` | ||
\begin{algorithm}[H] | ||
\SetAlgoLined | ||
\BlankLine | ||
\If{message received time is above wait threshold}{ | ||
If{message is undisputed} { | ||
enact(message) | ||
} | ||
} | ||
\caption{Unlock protocol for optimistic trusted bridges} | ||
\end{algorithm} | ||
``` | ||
Optimistic bridging trades in some advantages over pessimistic bridging, such as faster transaction times, in favour for more decentralized security. | ||
|
||
For a secure bridging operation, the transaction time $t$ is given by: | ||
|
||
$$ t := t_{finality} + t_{submission} + t_{dispute window} $$ | ||
|
||
where $t_{finality}$ is the average duration for block finality, $t_{submission}$ the length of time of block inclusion on the destination side, and $t_{dispute window}$ the amount of time that the relayed transaction may be disputed on the destination side. | ||
|
||
Relayers can choose to combine $t_{finality}$ and $t_ {dispute window}$, at the risk of needing to dispute their own submissions. This improves UX but brings in a significant risk to the relayer, and in practise is not performed. | ||
|
||
### Economic Risks in Trusted Bridging | ||
|
||
Bridging introduces security risks, both technically and economically. A wrapped token essentially represents a debt obligation between the bridging protocol and the token holder. This guarantees that upon redemption of the wrapped token, the original token will be returned. The value of the wrapped token is determined by the underlying asset value minus the risk associated with the bridging protocol failing to fulfill the debt. Presently, the market often misprices wrapped tokens, valuing them at the same level as the underlying asset. Consequently, when a trusted bridge fails to honor the debt, such as in the event of a hack resulting in the loss of the underlying asset, the economic impact is significant. | ||
|
||
For protocols dependent on a trusted bridge, addressing this underlying economic risk involves pricing wrapped tokens differently. While this approach helps mitigate economic consequences, it adversely affects liquidity and user experience. Furthermore, it diminishes the utility of cross-chain protocols, as the actual cost of utilizing a trusted bridge includes both the fee and the premium on wrapped tokens. | ||
|
||
The IBC protocol solves the issue of secure cross-chain communication, but it was originally only implemented for Cosmos SDK chain. The problem is that it needs to be implemented on non-Cosmos SDK chains. | ||
|
||
**Picasso fixes this.** | ||
|
||
## IBC Protocol - a trust-minimized standard for cross-ecosystem communication | ||
|
||
In pursuit of its core mission, significant strides have been made in developing trust-minimised bridges to facilitate decentralised and non-custodial cross-chain transactions powered by Picasso. The approach involves pioneering the extension of the IBC protocol and thus establish the framework as the industry standard for cross-ecosystem communication. Picasso's innovation is not limited to Cosmos but rather actively leveraging and extending the IBC protocol beyond Cosmos, pushing its boundaries beyond its original scope. | ||
|
||
The IBC protocol is an open-source and permissionless protocol designed to facilitate the authentication and transport of data, including message passing, tokens, NFTs, and more, between two networks and the applications within them. IBC is adaptable and can be implemented across different blockchains, networks, or state machines. Its requirements are not restrictive in terms of the type of consensus algorithm, allowing it to connect various types of blockchains, such as those based on Cosmos typically powered by Tendermint/CometBFT, Ethereum-like networks, and Solana as well. | ||
|
||
:::info | ||
The IBC protocol is maintained by the [Interchain Foundation](https://interchain.io/) and currently boasts three mainstream implementations: one written in [Golang](https://github.com/cosmos/ibc-go), another in [Rust](https://github.com/cosmos/ibc-go) and the third in Solidity. Currently, Picasso is the only mainnet chain operating with the Rust and Solidity implementations in production. | ||
::: | ||
|
||
Introduced in 2019, IBC was integrated into the Cosmos SDK in 2021. Presently, over 107 chains are interconnected, with IBC facilitating a volume of more than 5 billion USD as of December 2023, and [over 5 million token](https://mapofzones.com/home?columnKey=ibcVolume&period=24h) transfers between IBC-connected chains. These statistics underscore IBC's resilience over time and its ability to adapt and evolve its protocol to meet the needs of users and application chains. Its widespread adoption and continued relevance within the Cosmos ecosystem have also garnered attention in the broader crypto community. | ||
|
||
IBC supports asset transfers (fungible tokens, non-fungible tokens), generic message passing, cross-chain contract calls, cross-chain fee payments, interchain collateralization and more in a trustless manner. The trustless condition of IBC is due to the fact it is: | ||
|
||
- built upon light clients that communicate with each other and updates the state of a counterparty chain. These are lightweight versions of blockchain nodes that can verify specific information on counterparty chains without downloading the entire blockchain history. This allows for trustless verification of data and state on external blockchains. | ||
- typically used by Proof of Stake (PoS) blockchains which provide a high level of security, reducing the need to trust a single entity or centralized authority | ||
- utilising on-chain verification of transactions and messages. This means that the counterparty chain can independently validate the correctness of incoming messages and transactions using its own consensus rules, eliminating the need to trust external sources | ||
- able to upgrade the state of a chain through sending finality proofs, other types of transactions and packets that can be verified | ||
- employs mechanisms to prevent double-spending of assets across blockchains | ||
|
||
For a more detailed technical explanation, please refer to the [IBC section](../technology/ibc.md). |
Oops, something went wrong.