The ao
Scheduler Utils provides an abstraction for retrieving the location of an ao
Process' Scheduler,
and checking whether a wallet is a valid ao
Scheduler
This sdk will run in a browser or server environment.
This module can be used on the server, as well as the browser:
import { locate, validate, raw } from "@permaweb/ao-scheduler-utils";
const { locate, validate, raw } = require("@permaweb/ao-scheduler-utils");
The duration of this document will use ESM
for examples
Locate the ao
Scheduler assigned to an ao
Process.
import { locate } from "@permaweb/ao-scheduler-utils";
let { url, address } = await locate('<process-id>');
If you already know the Scheduler
used by the process, you can provide it as a second parameter to locate
as schedulerHint
:
import { locate } from "@permaweb/ao-scheduler-utils";
let { url, address } = await locate('<process-id>', 'scheduler-owner-id');
This will skip querying the gateway for the process, in order to obtain it's Scheduler
tag, and instead will directly query for the Scheduler-Location
record.
This is useful when a process has just been spawned, so might not be indexed by the gateway yet.
Check whether the wallet address is a valid ao
Scheduler
import { validate } from "@permaweb/ao-scheduler-utils";
const isValid = validate('<wallet-address>')
Return the url in the Scheduler-Location
record for the given wallet address
import { raw } from "@permaweb/ao-scheduler-utils";
const { url } = raw('<wallet-address>')
The library maintains an internal in-memory LRU cache of Scheduler-Location
Url
s, caching each for their
specified Time-To-Live
. If a Scheduler-Location
exists in the cache, it's value will be returned, instead
of fetching the record on chain.
The default size of the cache is 100
. If you'd like a smaller or larger cache, you can set the size using connect
If you would like to use config other than the defaults, you can
specify those coonfigurations by providing their values connect
. You can currently specify
- The
GRAPHQL_URL
- The In-Memory
cacheSize
- Following Redirects
followRedirects
, a boolean that optimizes scheduler routing iftrue
GRAPHQL_MAX_RETRIES
, the maximum amount of retries for failed gateway queriesGRAPHQL_RETRY_BACKOFF
, the initial delay for a gateway query retry. Doubled for each successive retry
If you'd like to use no In-Memory Cache, and load the record from chain every time, then set the
cacheSize
to0
import { connect } from "@permaweb/ao-scheduler-utils";
const { validate, locate, raw } = connect({
GRAPHQL_URL: "...",
cacheSize: 1000,
followRedirects: true,
GRAPHQL_MAX_RETRIES: 0,
GRAPHQL_RETRY_BACKOFF: 300
});
If any configuration value is not provided, a default will be used. In this sense, invoking
connect()
with no parameters or an empty object is functionally equivalent to
using the top-lvl exports of the library:
import {
locate,
validate,
raw,
connect
} from "@permaweb/ao-scheduler-utils";
// These are functionally equivalent
connect() == { validate, locate, raw }
This module's APIs will reject with certain Error
s for certain sad-paths:
TransactionNotFoundError
- the transaction id provided can not be found on the gateway. It'sname
property will beTransactionNotFound
SchedulerTagNotFoundError
- aScheduler
tag was not found on the provided process transaction id. It'sname
property will beSchedulerTagNotFound
InvalidSchedulerLocationError
- theScheduler-Location
record retrieved does not adhere to theao
Scheduler-Location
specification. It'sname
property will beInvalidSchedulerLocation
:- It does not have a
Url
tag - It does not have a
Time-To-Live
tag
- It does not have a
You can check for these errors in your code, and handle according to your use-case:
import { locate, TransactionNotFoundError } from "@permaweb/ao-scheduler-utils";
await locate('<process-id>')
.catch((err) => {
if (err instanceof TransactionNotFoundError) // using instanceof
if (err.name === 'TransactionNotFound') // use a static string
throw err // bubble unknown error
})