WebAssembly (Wasm) bindings for TypeScript/JavaScript to the IOTA SDK library.
The IOTA SDK library also offers dedicated Node.js bindings. The differences with this package are outlined below.
NOTE: Use the Node.js bindings if you can. The Wasm bindings are more portable and exist to support browser environments.
Wasm bindings | Node.js bindings | |
---|---|---|
Environment | Node.js, browsers | Node.js |
Installation | - | Rust, Cargo required* |
Performance | ✔️ | ✔️✔️ |
Ledger Nano | ❌ | ✔️ |
Rocksdb | ❌ | ✔️ |
Stronghold | ❌ | ✔️ |
- The Node.js bindings only need to be compiled during
npm install
if a pre-compiled binary is not available for your platform.
- One of the following Node.js versions: '16.x', '18.x';
wasm-bindgen
(cargo install wasm-bindgen-cli
);
To install the library from your package manager of choice, you only need to run the following:
npm i @iota/sdk-wasm
yarn add @iota/sdk-wasm
The library loads the compiled Wasm file with an HTTP GET request, so the iota_sdk_wasm_bg.wasm
file must be copied to
the root of the distribution folder.
A bundler such as webpack or rollup is recommended.
-
Install
rollup-plugin-copy
:npm install rollup-plugin-copy --save-dev
-
Add the plugin to your
rollup.config.js
:// Include the copy plugin. import copy from 'rollup-plugin-copy' // ... // Add the copy plugin to the `plugins` array: copy({ targets: [{ src: 'node_modules/@iota/sdk-wasm/web/wasm/iota_sdk_wasm_bg.wasm', dest: 'public', rename: 'iota_sdk_wasm_bg.wasm' }] })
-
Install
copy-webpack-plugin
:npm install copy-webpack-plugin --save-dev
-
Add the plugin to your
webpack.config.js
:// Include the copy plugin. const CopyWebPlugin = require('copy-webpack-plugin'); // ... experiments: { // futureDefaults: true, // includes asyncWebAssembly, topLevelAwait etc. asyncWebAssembly: true } // Add the copy plugin to the `plugins` array: plugins: [ new CopyWebPlugin({ patterns: [ { from: 'node_modules/@iota/sdk-wasm/web/wasm/iota_sdk_wasm_bg.wasm', to: 'iota_sdk_wasm_bg.wasm' } ] }), // other plugins... ]
The following example creates a Client
instance connected to
the Shimmer Testnet, and retrieves the node's information by
calling Client.getInfo()
,
and then print the node's information.
const {Client, initLogger} = require('@iota/sdk-wasm/node');
async function run() {
initLogger();
const client = new Client({
nodes: ['https://api.testnet.shimmer.network'],
localPow: true,
});
try {
const nodeInfo = await client.getInfo();
console.log('Node info: ', nodeInfo);
} catch (error) {
console.error('Error: ', error);
}
}
run().then(() => process.exit());
import init, {Client, initLogger} from "@iota/sdk-wasm/web";
init().then(async () => {
initLogger();
const client = new Client({
nodes: ['https://api.testnet.shimmer.network'],
localPow: true,
});
const nodeInfo = await client.getInfo();
console.log('Node info: ', nodeInfo);
}).catch(console.error);
// Default path to load is "iota_sdk_wasm_bg.wasm",
// but you can override it by passing a path explicitly.
//
// init("./static/iota_sdk_wasm_bg.wasm").then(...)
The following example will create a
new Wallet
Account
that connects to the Shimmer Testnet using the
StrongholdSecretManager
by calling
the Wallet.createAccount(data)
function.
const { Wallet, CoinType } = require('@iota/sdk-wasm/node');
async function run() {
try {
const wallet = new Wallet({
storagePath: './my-database',
coinType: CoinType.Shimmer,
clientOptions: {
nodes: ['https://api.testnet.shimmer.network'],
},
secretManager: {
mnemonic: "my development mnemonic",
},
});
const account = await wallet.createAccount({
alias: 'Alice',
});
const addresses = await account.addresses();
console.log(addresses);
} catch (err) { console.error }
}
run().then(() => process.exit());
import init, {Wallet, CoinType} from "@iota/sdk-wasm/web";
init().then(async () => {
const wallet = new Wallet({
storagePath: './my-database',
coinType: CoinType.Shimmer,
clientOptions: {
nodes: ['https://api.testnet.shimmer.network'],
},
secretManager: {
mnemonic: "my development mnemonic",
},
});
const account = await wallet.createAccount({
alias: 'Alice',
});
const addresses = await account.addresses();
console.log(addresses);
}).catch(console.error);
// Default path to load is "iota_sdk_wasm_bg.wasm",
// but you can override it by passing a path explicitly.
//
// init("./static/iota_sdk_wasm_bg.wasm").then(...)
If you are using the Wasm binding, you use the Node.js API reference in the IOTA Wiki.