Overview
Functions enable you to quickly build, deploy, and use serverless functions without the need to manage infrastructure. Your Functions can be used as destinations for your Streams, and can also be activate via API.
Functions Features
- API Ready: Your functions are automatically exposed as an API, ready to be called from your front-end or other services.
- Performance at Scale: Our globally balanced, auto-scaling infrastructure ensures smooth operation, even at peak loads.
- Blockchain Optimized: Use your function as a destination for Streams, and it will automatically activate when new data is piped in from your Stream. You can also activate your function via API and optionally specify a specific blockchain dataset to access within your function during the activation.
- Storage Access: Access and manage your Storage data seamlessly within your function.
- Cost Effective: Pay for only what you use, with no upfront costs or long-term commitments.
Want to see Functions in action? Check out our Functions Library for sample code and walkthroughs.
Feature Availability and Cost
Functions beta is available on all QuickNode rate plans. We offer dedicated support and custom integrations for teams with unique requirements. Contact our team for more information.
You can create an unlimited number of functions to meet your needs, however it is important to remember that the minimum activation time for any function is 100ms. For a full breakdown of the Functions features by plan, visit the pricing page.
Understanding GB-sec and Billing
GB-sec (Gigabyte-seconds) is an industry-standard metric we have adopted to measure and bill for Functions usage. It represents the amount of compute resources consumed by your function over time.
How GB-sec is Calculated:
- Memory Usage: The amount of memory allocated to your function (256MB).
- Execution Time: The duration your function runs, with a minimum of 100ms per activation.
If your function completes in less than 100ms, it will be billed for 100ms.
Example Calculations:
A function configured with a 256MB memory allocation that runs for 50ms (rounded to 100ms minimum):
GB-sec = (256/1024 GB) * (0.1 seconds) = 0.025 GB-sec
- A function configured with a 256MB memory allocation that runs for 2 seconds:
GB-sec = (256/1024 GB) * (2 seconds) = 0.5 GB-sec
By understanding GB-sec, you can optimize your functions for both performance and cost-effectiveness. Consider execution time to make the most of your included GB-sec and minimize additional charges.
Access
Access Functions through the QuickNode Developer Portal.
Functions Activation
Functions can be activated in 3 ways:
- Test activations: Your function can be activated manually within the function editor inside the QuickNode Developer Portal.
- Streams activation: You can choose your function as a destination for a Stream, and it will be activated automatically when data is delivered. Learn more about functions as a destination for Streams.
- API activation: On the overview screen within the QuickNode Developer Portal for your function, you will find the unique API endpoint for your function. You can call this endpoint directly to activate your function. Learn more about the datasets available for API activations.
Supported Chains
Functions activated by API requests can automatically access blockchain data from any of the supported chains and networks mentioned below. For teams with unique requirements, contact our team for more information. Otherwise, our self-serve experience has you covered on the following chains:
Chain | Mainnet | Testnets |
---|---|---|
Arbitrum | ✅ | Sepolia |
Arbitrum Nova | ✅ | |
Avalanche C-Chain | ✅ | Fuji |
Base | ✅ | Sepolia |
Bera | Coming soon | bArtio |
Blast | ✅ | Sepolia |
BNB Smart Chain | ✅ | Testnet |
Celo | ✅ | |
Cyber | ✅ | Sepolia |
Ethereum | ✅ | Holesky, Sepolia |
Fantom | ✅ | |
Fraxtal | ✅ | |
Gnosis | ✅ | |
Immutable zkEVM | ✅ | Testnet |
Mantle | ✅ | Sepolia |
Mode | ✅ | |
Optimism | ✅ | Sepolia |
Polygon | ✅ | Amoy |
Polygon zkEVM | ✅ | |
Scroll | ✅ | Testnet |
Solana | ✅ | Devnet, Testnet |
TRON | ✅ | |
zkSync | ✅ | Sepolia |
Xai | ✅ | Sepolia |
Zora | ✅ |
Function Configuration
- Function name: The name of the function.
- Runtime: Node.js v20 is available.
- Description: You can add a description to your function. It supports markdown.
- Timeout limit: How long your function can run before timing out. The range is 5 to 60 seconds.
Function Editor
You can code your function in the functions code editor.
Code View
Write code that will execute when data is delivered by Streams, or when you activate your function via API.
Within the editor, you can test your function against blockchain datasets and view activation results.
Within the code view, your function can access all the packages that are part of the selected runtime.
Using Key-Value Store with Functions
Key-Value Store can be accessed and managed seamlessly within a function. You can create new lists and key-value sets, add and remove items from your lists, update key-value sets, retrieve set value, and check if data matches an item on your list. To learn more about Key-Value Store, please visit the Key-Value Store documentation.
Available Key-Value Store features within functions
Lists
qnUpsertList
: Creates or updates a new list in Key-Value Store.qnGetList
: Retrieves all items from a specific list in Key-Value Store.qnGetAllLists
: Retrieves all lists in Key-Value Store.qnAddListItem
: Adds an item to a specific list in Key-Value Store.qnRemoveListItem
: Removes an item from a specific list in Key-Value Store.qnContainsListItem
: Checks if an item exists in a specific list in Key-Value Store.qnDeleteList
: Deletes a specific list in Key-Value Store.
Sets
qnAddSet
: Creates a key-value set in Key-Value Store.qnBulkSets
: Creates and removes bulk key-value sets in Key-Value Store.qnDeleteSet
: Deletes a key-value set from Key-Value Store.qnGetSet
: Retrieves the value of a specific key from Key-Value Store.qnListAllSets
: List all keys for sets in Key-Value Store.
Example function code for Key-Value Store
The function code below demonstrates how Key-Value Store lists and sets can be used within your function.
async function main(params) {
const results = {}
try {
// Test qnGetAllLists
results.qnGetAllLists = await qnLib.qnGetAllLists()
// Test qnDeleteList
results.qnDeleteList = await qnLib.qnDeleteList('testList')
// Test qnAddListItem
results.qnAddListItem = await qnLib.qnAddListItem('testList', 'testItem')
// Test qnContainsListItem
results.qnContainsListItem_before_remove = await qnLib.qnContainsListItem(
'testList',
'testItem'
)
// Test qnRemoveListItem
results.qnRemoveListItem = await qnLib.qnRemoveListItem(
'testList',
'testItem'
)
// Test qnContainsListItem
results.qnContainsListItem_after_remove = await qnLib.qnContainsListItem(
'testList',
'testItem'
)
// Test qnGetList
results.qnGetList = await qnLib.qnGetList('testList')
// Test qnUpsertList
results.qnUpsertList = await qnLib.qnUpsertList('testList', {
add_items: ['item1'],
remove_items: ['item2'],
})
// Test qnDeleteSet
results.qnDeleteSet = await qnLib.qnDeleteSet('testSet')
// Test qnAddSet
results.qnAddSet = await qnLib.qnAddSet('testSet', 'testValue')
// Test qnGetSet
results.qnGetSet = await qnLib.qnGetSet('testSet')
// Test qnListAllSets
results.qnListAllSets = await qnLib.qnListAllSets()
// Test qnBulkSets
results.qnBulkSets = await qnLib.qnBulkSets({
add_sets: { key1: 'value1' },
delete_sets: ['key2'],
})
} catch (error) {
console.error('Error during method tests:', error)
}
// Return the results
return {
message: 'Method test results',
results: results,
}
}
The function main
must be async
if you are accessing Key-Value Store within your function.
Functions Dashboard
Within the QuickNode developer portal, you can view details about your functions, including metrics, history, and logs. You can also edit and test your functions.
Each function generates a unique rest API endpoint that can be used to activate the function via API.
We ❤️ Feedback!
If you have any feedback or questions about this documentation, let us know. We'd love to hear from you!