Architecture Overview#
Architecture#
Wormhole has several noteworthy components. Before discussing each component in depth, this page will provide an overview of how the major pieces fit together.
The diagram outlines the end-to-end flow of cross-chain communication through Wormhole's architecture:
- Source chain - a source contract emits a message by interacting with the Wormhole Core Contract on the source chain, which publishes the message in the blockchain's transaction logs
- Guardian Network - Guardians validate these messages and sign them to produce Verifiable Action Approvals (VAAs)
- Relayers - off-chain relayers or applications fetch the VAA and relay it to the target chain
-
Target chain - on the target chain, the message is consumed by the appropriate contract. This contract interacts with the Wormhole Core Contract to verify the VAA and execute the intended cross-chain operation. The flow from the relayer to the target chain involves an entry point contract, which could vary based on the use case:
- In some applications, the target contract acts as the entry point and performs verification via the Core Contract
- In products like the Token Bridge, the Token Bridge contract itself interacts with the Core Contract
On-Chain Components#
- Emitter - a contract that calls the publish message method on the Core Contract. The Core Contract will write an event to the transaction logs with details about the emitter and sequence number to identify the message. This may be your xDapp or an existing ecosystem protocol
- Wormhole Core Contract - primary contract, this is the contract which the Guardians observe and which fundamentally allows for cross-chain communication
- Transaction logs - blockchain-specific logs that allow the Guardians to observe messages emitted by the Core Contract
Off-Chain Components#
- Guardian Network - validators that exist in their own P2P network. Guardians observe and validate the messages emitted by the Core Contract on each supported chain to produce VAAs (signed messages)
- Guardian - one of 19 validators in the Guardian Network that contributes to the VAA multisig
- Spy - a daemon that subscribes to messages published within the Guardian Network. A Spy can observe and forward network traffic, which helps scale up VAA distribution
- API - a REST server to retrieve details for a VAA or the Guardian Network
- VAAs - Verifiable Action Approvals (VAAs) are the signed attestation of an observed message from the Wormhole Core Contract
- Relayer - any off-chain process that relays a VAA to the target chain
- Wormhole relayers - a decentralized relayer network that delivers messages that are requested on-chain via the Wormhole relayer contract
- Custom relayers - relayers that only handle VAAs for a specific protocol or cross-chain application. They can execute custom logic off-chain, reducing gas costs and increasing cross-chain compatibility. Currently, cross-chain application developers are responsible for developing and hosting custom relayers