@metrixnames/mnslib
v2.2.3
Published
Library for interacting with the Metrix Name Service
Downloads
130
Readme
mnslib
mnslib is an update/port of ensjs made to work for the Metrix Name Service and MetrixCoin blockchain. The metrilib dependency is used to interact with the MetrixCoin blockchain.
Documentation
Installation
npm install --save @metrixcoin/metrilib @metrixnames/mnslib
Example Usage
import { APIProvider } from '@metrixcoin/metrilib';
import { MNS, Name, getMNSAddress } from '@metrixnames/mnslib';
const network = 'TestNet'; // can be 'MainNet' or 'TestNet'
// const mrpc = new MetrixRPCNode(
// null,
// 'http://localhost:33841',
// 'rpcuser',
// 'rpcpass'
// );
// const sender = 'maTQfd4w7mqCzGL32RgBFMYY9ehCmjLEGf'; // sending address which the wallet controls the keys for
// const provider = new RPCProvider(network, mrpc, sender); // create a read/write provider using a local wallet daemon (usually used server side)
// const provider = new Web3Provider(network); // create a read/write provider using web3 (MetriMask) (always used client side)
const provider = new APIProvider(network); // create a readonly provider using the explorer API (usually used client side)
const mns = new MNS(network, provider, getMNSAddress(network));
const name: Name = mns.name('burn.mrx'); // return a Name object which can be used to make record queries
const address = await name.getAddress('MRX'); // return a standard MetrixCoin address slip44:326
// ex: M7uAERuQW2AotfyLDyewFGcLUDtAYu9v5V
const resAddress = await name.getResolverAddr(); // an EVM address of the resolver for the name
const resolver: Resolver = mns.resolver(resAddress); // a Resolver object which can be used to query names from this specific resolver
const owner = resolver.name('burn.mrx').getOwner(); // an EVM address of an EOA (Hexified MRX) or contract
// ex: 0x0000000000000000000000000000000000000000