What is a Task?
Tasks are a replacement for core adapters that is more flexible. Tasks can be composed in arbitrary order into pipelines. Pipelines consist of one or more threads of execution where tasks are executed in a well-defined order.
You can use Chainlink's built-in tasks, or you can create your own external adapters for tasks which are accessed through a
All tasks share a few common attributes:
index: when a task has more than one input (or the pipeline overall needs to support more than one final output), and the ordering of the values matters, the index parameter can be used to specify that ordering.
data_1 [type="http" method=GET url="https://chain.link/eth_usd" index=0] data_2 [type="http" method=GET url="https://chain.link/eth_dominance" index=1] multiword_abi_encode [type="eth_abi_encode" method="fulfill(uint256,uint256)"] data_1 -> multiword_abi_encode data_2 -> multiword_abi_encode
timeout: The maximum duration that the task is allowed to run before it is considered to be errored. Overrides the
maxTaskDuration value in the job spec.
Pipelines are composed of tasks arranged in a DAG (directed acyclic graph). Pipelines are expressed in DOT syntax.
Each node in the graph is a task with a user-specified ID and a set of configuration parameters and attributes:
my_fetch_task [type="http" method=GET url="https://chain.link/eth_usd"]
The edges between tasks define how data flows from one task to the next. Some tasks can have multiple inputs, such as
median. Other tasks are limited to 0 (
http) or 1 (
data_source_1 [type="http" method=GET url="https://chain.link/eth_usd"] data_source_2 [type="http" method=GET url="https://coingecko.com/eth_usd"] medianize_data [type="median"] submit_to_ea [type="bridge" name="my_bridge"] data_source_1 -> medianize_data data_source_2 -> medianize_data medianize_data -> submit_to_ea