Overview
Making the data work for you
In The Neighborhood, our goal is to meet the data where it’s at (in its raw form) and you wherever you might find yourself (with a db, webhook, etc).
Transformations are how we bridge that gap. These are simple (or complex) JavaScript functions that run throughout the distributed network. We call this Just In Time Indexing.
Here’s a simple example. This function simply takes in a new EVM block and returns its number
and an ISO formatted timestamp
.
Here’s a more complex example counting the number of times each Solana account is found in a block:
Helper Functions
To aid in transformations, we’ve begun open sourcing common utility functions and templates. You can view all of this on GitHub and as an npm package.
Pull requests are welcome! We need the community’s help for bugs, new templates, and commonly used utilities.
Here’s a list of the available functions as they can be used within transformations:
templates.token_transfers(block)
: pass in an entire block (EVM or not) and get back all of the token transfers within itutils.evmAddressToChecksum(address)
: convert an EVM address to its checksum formutils.evmChainToId(chain)
: convert an EVM chain name to achainId
; tryblock._network
to get the current chain nameutils.evmDecodeLog(log, signatures[])
: try decoding an EVM log against a list of event signaturesutils.evmDecodeLogWithMetadata(log, signatures[])
: same asevmDecodeLog
, but also return the name of the matching eventutils.evmMethodSignatureToHex(signature)
: convert an EVM event signature (e.g. from an ABI) to its topic0, hexadecimal form
Available Packages
Although transformations are run in a sandboxed environment, we inject a select few npm packages that can also be used. These include: