Skip to main content

Masa SDK

/ Exports

Installation

yarn
yarn add @masa-finance/masa-sdk --save

npm
npm i @masa-finance/masa-sdk --save

Usage

Browser:

import { Masa } from "@masa-finance/masa-sdk";
import { providers } from "ethers";

// with metamask
const provider = new providers.Web3Provider(window.ethereum);
const signer = provider.getSigner();

// by default Masa SDK will assume the provider points to ethereum mainnet and
// will load contracts accordingly. If you plan to connect to a different network
// the networkName must be specified i.e. like this: networkName: "goerli"

export const masa = new Masa({
signer,
// networkName: "goerli",
});

Node:

import { Masa } from "@masa-finance/masa-sdk";
import { providers, Wallet } from "ethers";

const provider = new providers.JsonRpcProvider("your blockchain rpc endpoint");
const wallet = new Wallet("your private key", provider);

// by default Masa SDK will assume the provider points to ethereum mainnet and
// will load contracts accordingly. If you plan to connect to a different network
// the networkName must be specified i.e. like this: networkName: "goerli"

export const masa = new Masa({
signer: wallet,
// networkName: "goerli",
});

Interface

For a detailed interface description see Masa

Configuration

KeyTypeDescriptionDefault Value
cookiestringCookie value. Don't set this manually unless you know what you do!
walletethers.Signer or ethers.WalletThe Wallet instance to use when interacting with the Blockchain."wallet with a random private key"
apiUrlstringThe API Endpoint of the Masa Infrastructure for dev, test, beta and production."https://dev.middleware.masa.finance/"
environmentstringThe environment to use dev, test, beta, production."dev"
networkstringThe network name ie. "goerli"."goerli"
arweave.hoststringThe arweave host to use for loading metadata."arweave.net"
arweave.portnumberThe arweave port to use for loading metadata.443
arweave.protocolstringThe arweave protocol to use for loading metadata."https"
arweave.loggingbooleanTurn arweave logging on or off.false
new Masa({
// cookie value for connecting with the backend
cookie: "my fancy cookie",
// wallet object is always mandatory
wallet,
// api endpoint to the masa infrastructure
apiUrl: "https://middleware.masa.finance",
// masa environment dev, test, beta, prod
environment: "prod",
// network name to use goerli, mainnet
network: "goerli",
// arweave endpoint to use
arweave: {
host: "arweave.net",
port: 443,
protocol: "https",
logging: false,
},
});