Request-Response Protocol
The first protocol implemented for Airnode is request–response. An Airnode serving the request–response protocol listens for requests, makes the API call specified by the request, and finally makes the response transaction back on chain.
Contracts
This sections briefly describes the structure of the request response protocol contracts. You can find more information in the source files on github.
The request–response protocol is implemented as a single permissionless contract that all Airnodes interact with, which is named AirnodeRrpV0.sol
. This base contract has the following inheritance tree that compartmentalizes the aspects of the protocol.
AirnodeRrpV0.sol
The AirnodeRrpV0.sol contract sits between a requester and the Airnode. It inherits from four additional contracts as illustrated in the diagram above:
This contract has two key responsibilities:
- It is used by requesters to make requests.
- It is used by Airnodes to fulfill requests.
However, this contract is shared for all requesters and Airnodes on a particular chain. This means that neither Airnode operators nor requesters need to deploy this contract themselves. Instead, API3 will deploy this contract once per chain and you simply connect your Airnode or requester contract to that deployed contract. See the Airnode Contract Addresses for reference.
The @api3/airnode-admin
package is a CLI tool used to interact with AirnodeRrpV0.sol
and perform administrative actions.
IAirnodeRrpV0.sol
The IAirnodeRrpV0.sol interface describes all functions and events of the AirnodeRrpV0.sol
contract which implements this interface.
This interface inherits:
AuthorizationUtilsV0.sol
The AuthorizationUtilsV0.sol contract implements Airnode Authorizer checks.
WithdrawalUtilsV0.sol
The WithdrawalUtilsV0.sol contract allows the sponsor to trigger a withdrawal request which is later fulfilled by Airnode and all sponsor wallet funds are sent back to the sponsor.
TemplateUtilsV0.sol
The TemplateUtilsV0.sol contract is used to create and store Airnode templates used to create a template request.
FLEX_END_TAG