A set of core Algorand utilities written in TypeScript and released via npm that make it easier to build, test and deploy solutions on the Algorand Blockchain, including APIs, console apps and dApps. This project is part of AlgoKit.
The goal of this library is to provide intuitive, productive utility functions that make it easier, quicker and safer to build applications on Algorand. Largely these functions provide a thin wrapper over the underlying Algorand SDK, but provide a higher level interface with sensible defaults and capabilities for common tasks that make development faster and easier.
Note: If you prefer Python there's an equivalent Python utility library.
Core principles | Installation | Usage | Config and logging | Capabilities | Reference docs
This library is designed with the following principles:
- Modularity - This library is a thin wrapper of modular building blocks over the Algorand SDK; the primitives from the underlying Algorand SDK are exposed and used wherever possible so you can opt-in to which parts of this library you want to use without having to use an all or nothing approach.
- Type-safety - This library provides strong TypeScript support with effort put into creating types that provide good type safety and intellisense.
- Productivity - This library is built to make solution developers highly productive; it has a number of mechanisms to make common code easier and terser to write
Before installing, you'll need to decide on the version you want to target. Version 7 and 8 have the same feature set, however v7 leverages algosdk@>=2.9.0<3.0, whereas v8 leverages algosdk@>=3.0.0. Your project and it's dependencies will help you decide which version to target.
Once you've decided on the target version, this library can be installed from NPM using your favourite npm client, e.g.:
To target algosdk@2 and use version 7 of AlgoKit Utils, run the below:
npm install algosdk@^2.9.0 @algorandfoundation/algokit-utils@^7.0.0
To target algosdk@3 and use the latest version of AlgoKit Utils, run the below:
npm install algosdk@^3.0.0 @algorandfoundation/algokit-utils
This library uses algosdk
as a peer dependency. Please see above to ensure you have the correct version installed in your project.
To use this library simply include the following at the top of your file:
import { AlgorandClient, Config } from '@algorandfoundation/algokit-utils'
As well as AlgorandClient
and Config
, you can use intellisense to auto-complete the various types that you can import within the {}
in your favourite Integrated Development Environment (IDE), or you can refer to the reference documentation.
Warning
Previous versions of AlgoKit Utils encouraged you to include an import that looks like this (note the subtle difference of the extra * as algokit
):
import * as algokit from '@algorandfoundation/algokit-utils'
This version will still work until at least v9, but it exposes an older, function-based interface to the functionality that is deprecated. The new way to use AlgoKit Utils is via the AlgorandClient
class, which is easier, simpler and more convenient to use and has powerful new features.
If you are migrating from the old functions to the new ones then you can follow the migration guide.
The main entrypoint to the bulk of the functionality is the AlgorandClient
class, most of the time you can get started by typing AlgorandClient.
and choosing one of the static initialisation methods to create an Algorand client, e.g.:
// Point to the network configured through environment variables or
// if no environment variables it will point to the default LocalNet
// configuration
const algorand = AlgorandClient.fromEnvironment()
// Point to default LocalNet configuration
const algorand = AlgorandClient.defaultLocalNet()
// Point to TestNet using AlgoNode free tier
const algorand = AlgorandClient.testNet()
// Point to MainNet using AlgoNode free tier
const algorand = AlgorandClient.mainNet()
// Point to a pre-created algod client
const algorand = AlgorandClient.fromClients({ algod })
// Point to pre-created algod, indexer and kmd clients
const algorand = AlgorandClient.fromClients({ algod, indexer, kmd })
// Point to custom configuration for algod
const algorand = AlgorandClient.fromConfig({ algodConfig })
// Point to custom configuration for algod, indexer and kmd
const algorand = AlgorandClient.fromConfig({ algodConfig, indexerConfig, kmdConfig })
AlgoKit Utils contains a module that helps you write automated tests against an Algorand network (usually LocalNet). These tests can run locally on a developer's machine, or on a Continuous Integration server.
To use the automated testing functionality, you can import the testing module:
import * as algotesting from '@algorandfoundation/algokit-utils/testing'
Or, you can generally get away with just importing the algorandFixture
since it exposes the rest of the functionality in a manner that is easy to integrate with an underlying test framework like Jest or vitest:
import { algorandFixture } from '@algorandfoundation/algokit-utils/testing'
To see how to use it consult the testing capability page or to see what's available look at the reference documentation.
If you want to extend or pass around any of the types the various functions take then they are all defined in isolated modules under the types
namespace. This is to provide a better intellisense experience without overwhelming you with hundreds of types. If you determine a type to import then you can import it like so:
import {<type>} from '@algorandfoundation/types/<module>'
Where <type>
would be replaced with the type and <module>
would be replaced with the module. You can use intellisense to discover the modules and types in your favourite IDE, or you can explore the types modules in the reference documentation.
To configure the AlgoKit Utils library you can make use of the Config
object, which has a configure
method that lets you configure some or all of the configuration options.
AlgoKit has an in-built logging abstraction that allows the library to issue log messages without coupling the library to a particular logging library. This means you can access the AlgoKit Utils logs within your existing logging library if you have one.
To do this you need to create a logging translator that exposes the following interface (Logger
):
export type Logger = {
error(message: string, ...optionalParams: unknown[]): void
warn(message: string, ...optionalParams: unknown[]): void
info(message: string, ...optionalParams: unknown[]): void
verbose(message: string, ...optionalParams: unknown[]): void
debug(message: string, ...optionalParams: unknown[]): void
}
Note: this interface type is directly compatible with Winston so you should be able to pass AlgoKit a Winston logger.
By default, the consoleLogger
is set as the logger, which will send log messages to the various console.*
methods for all logs apart from verbose logs. There is also a nullLogger
if you want to disable logging, or various leveled console loggers: verboseConsoleLogger
(also outputs verbose logs), infoConsoleLogger
(only outputs info, warning and error logs), warningConsoleLogger
(only outputs warning and error logs).
If you want to override the logger you can use the following:
Config.configure({ logger: myLogger })
To retrieve the current debug state you can use Config.logger
. To get a logger that is optionally set to the null logger based on a boolean flag you can use the Config.getLogger(useNullLogger)
function.
To turn on debug mode you can use the following:
Config.configure({ debug: true })
To retrieve the current debug state you can use Config.debug
.
This will turn on things like automatic tracing, more verbose logging and advanced debugging. It's likely this option will result in extra HTTP calls to algod so worth being careful when it's turned on.
If you want to temporarily turn it on you can use the withDebug
function:
Config.withDebug(() => {
// Do stuff with Config.debug set to true
})
The library helps you interact with and develop against the Algorand blockchain with a series of end-to-end capabilities as described below:
- AlgorandClient - The key entrypoint to the AlgoKit Utils functionality
- Core capabilities
- Client management - Creation of (auto-retry) algod, indexer and kmd clients against various networks resolved from environment or specified configuration, and creation of other API clients (e.g. TestNet Dispenser API and app clients)
- Account management - Creation, use, and management of accounts including mnemonic, rekeyed, multisig, transaction signer (useWallet for dApps and Atomic Transaction Composer compatible signers), idempotent KMD accounts and environment variable injected
- Algo amount handling - Reliable, explicit, and terse specification of microAlgo and Algo amounts and safe conversion between them
- Transaction management - Ability to construct, simulate and send transactions with consistent and highly configurable semantics, including configurable control of transaction notes, logging, fees, validity, signing, and sending behaviour
- Higher-order use cases
- Asset management - Creation, transfer, destroying, opting in and out and managing Algorand Standard Assets
- Typed application clients - Type-safe application clients that are generated from ARC-56 or ARC-32 application spec files and allow you to intuitively and productively interact with a deployed app, which is the recommended way of interacting with apps and builds on top of the following capabilities:
- ARC-56 / ARC-32 App client and App factory - Builds on top of the App management and App deployment capabilities (below) to provide a high productivity application client that works with ARC-56 and ARC-32 application spec defined smart contracts
- App management - Creation, updating, deleting, calling (ABI and otherwise) smart contract apps and the metadata associated with them (including state and boxes)
- App deployment - Idempotent (safely retryable) deployment of an app, including deploy-time immutability and permanence control and TEAL template substitution
- Algo transfers (payments) - Ability to easily initiate Algo transfers between accounts, including dispenser management and idempotent account funding
- Automated testing - Terse, robust automated testing primitives that work across any testing framework (including jest and vitest) to facilitate fixture management, quickly generating isolated and funded test accounts, transaction logging, indexer wait management and log capture
- Indexer lookups / searching - Type-safe indexer API wrappers (no
Record<string, any>
pain from the SDK client), including automatic pagination control
We have auto-generated reference documentation for the code.