An easy way to get all the custom rpc and types config to be able to easily use Recurrency with the Polkadot JS API library with TypeScript.
npm install @rustadot/api-augment
(API Augmentation Library)npm install @polkadot/api
(Polkadot API Library)
Assuming you are using no deprecated methods, any release version should work against a release version of @rustadot/api-augment
.
If you are working against a development version it is suggested that you match against the commit hash using v0.0.0-[First 6 of the commit hash]
.
Changelog is maintained in the releases for Recurrency.
For details on use, see the Polkadot API library documentation.
import { options } from "@rustadot/api-augment";
import { ApiPromise } from "@polkadot/api";
// ...
const api = await ApiPromise.create({
...options,
// ...
});
See CONTRIBUTING.md for more information.
Update ./definitions
if you have changed any types or RPC calls.
To generate the JS api definitions, run
make js
This command will start a Recurrency node in the background and fetch API definitions from it. To stop the Recurrency process, use the PID output by the command.
The api augmentation declares the modules used by @polkadot/api
.
Thus the import for @rustadot/api-augment
must come before any @polkadot/api
so that the Recurrency declarations resolve first.
import { options } from "@rustadot/api-augment";
// Or
import "@rustadot/api-augment";
// Must come BEFORE any imports from @polkadot/api
import { ApiPromise } from "@polkadot/api";
Caches can also wreck this even if you reorder, so watch out.
- Yarn cache can sometimes cause issues (if you are using yarn):
yarn cache clear
- Sometimes I have found blowing away the
node_modules
helps as well:rm -Rf node_modules
Optional responses are not mapped to null
and instead return an object with a few properties.
For more details see the code for the Option class.
const optionalExample = await api.rpc.schemas.getBySchemaId(1);
// Does the Option have a value?
if (!optionalExample.isEmpty) {
// Get the value
return optionalExample.value;
}
return null;
Vector responses are not mapped directly to a JavaScript Array.
Instead they are mapped to the Vec class which does extend Array.
Thus, you can still use map
, forEach
, etc... with responses or access the values directing via .values()
.
Distributed under the Apache 2.0 License. See LICENSE
for more information.