description |
---|
Everything you need to start running a relayer |
Hyperlane relayer.md deliver interchain messages to their recipients.
Every Hyperlane message requires two transactions to be delivered, one on the origin chain to send.md the message, and one on the destination chain to receive.md the messages. Relayers are responsible for sending the second transaction.
%%{ init: {
"theme": "neutral",
"themeVariables": {
"mainBkg": "#025AA1",
"textColor": "white",
"clusterBkg": "white"
},
"themeCSS": ".edgeLabel { color: black }"
}}%%
flowchart TB
subgraph Origin
Sender
M_O[(Mailbox)]
IGP[InterchainGasPaymaster]
Sender -- "id = dispatch()" --> M_O
Sender -- "payForGas(id)\n{value: payment}" --> IGP
end
Relayer((Relayer))
M_O -. "indexing" .-> Relayer
IGP -. "paymaster" .- Relayer
subgraph Destination
M_D[(Mailbox)]
end
Relayer -- "process()" --> M_D
style Sender fill:#efab17
click IGP https://github.com/hyperlane-xyz/hyperlane-monorepo/blob/main/solidity/contracts/igps/InterchainGasPaymaster.sol
Hyperlane relayers are configured to relayer messages between one or more origin chains and destination chains. Relayers have no special permissions in Hyperlane. If relayer keys are compromised, only the tokens held by those keys are at risk.
Running a relayer requires the following:
Relayers use RPC nodes to read the origin chain(s), and deliver messages to the destination chain(s). Relayers must be configured with an RPC node for all origin and destination chains.
In order to deliver messages, relayers must be configured with a signing key for each destination chain.
The relayer uses this key to sign Mailbox.process()
transactions. The Hyperlane relayer agent currently supports configuration with AWS KMS keys that are accessed via API keys/secrets or raw hexadecimal private keys.
Relayers can compile the Rust binary themselves, or run a Docker image provided by Abacus Works. The binary can be run using your favorite cloud service.