@firmachain/firma-js
Version:
The Official FirmaChain Javascript SDK written in Typescript
144 lines (115 loc) • 3.86 kB
Markdown
# firma-js
[](https://badge.fury.io/js/%40firmachain%2Ffirma-js)
[](https://github.com/firmachain/firma-js/releases)
[](https://github.com/firmachain/firma-js/blob/master/LICENSE)

The Javascript & TypeScript SDK for FirmaChain
Firma-js is a SDK for writing applications based on javascript & typescript. You can use it client web app or Node.js. This SDK is created inspired by cosmjs and several sdk. All functions of the FirmaChain can be accessed at the service level.
## Features
Most cosmos sdk features are supported
- Wallet / Bank
- Nft / Contract
- Ipfs / Gov
- Staking / Distribution
- Feegrant ...and so one
</br>
## Install
You can install `firma-js` using [NPM](https://www.npmjs.com/package/@firmachain/firma-js)
```
yarn add @firmachain/firma-js
```
or
```
npm i @firmachain/firma-js
```
## Usage
### Initializing SDK
```js
import { FirmaSDK } from "@firmachain/firma-js"
import { FirmaConfig } from "@firmachain/firma-js"
// use preset config : testnet
const firma = new FirmaSDK(FirmaConfig.TestNetConfig);
// use preset config : mainnet
const firma = new FirmaSDK(FirmaConfig.MainNetConfig);
// or use custom set
let chainConfig = {
chainID: "colosseum-1",
rpcAddress: "https://lcd-mainnet.firmachain.dev:26657",
restApiAddress: "https://lcd-mainnet.firmachain.dev:1317",
ipfsNodeAddress: "https://ipfs-dev.firmachain.dev",
ipfsNodePort: 5001,
ipfsWebApiAddress: "https://ipfs-dev.firmachain.dev",
hdPath: "m/44'/7777777'/",
prefix: "firma",
denom: "ufct",
defaultFee: 30000,
defaultGas: 300000,
isShowLog: false,
}
const firma = new FirmaSDK(chainConfig);
```
### Create wallet account
```js
// create new wallet
const newWallet = await firma.Wallet.newWallet();
// generateMnemonic
const mnemonic = await firma.Wallet.generateMnemonic();
const index = 0;
// or from mnemonic
const wallet = await firma.Wallet.fromMnemonic(mnemonic, index);
console.log(await wallet.getAddress());
```
### Import account by private key
```js
const privateKey = wallet.getPrivateKey();
const wallet1 = await firma.Wallet.fromPrivateKey(privateKey);
```
### Get chaion status (include height, time etc)
```js
const result = await firma.Chain.getChainStatus();
console.log(result);
```
### Get FIRMA balance of specific account
```js
const address = await wallet.getAddress();
const balance = await firma.Bank.getBalance(address);
console.log("balance: " + balance);
```
### Get transaction by hash
```js
const txHash = "0xC5509A32CF57798F8C3185DFAF03BD2D09DFC04FE842283ECA9298F5F60E340F";
const result = await firma.Chain.getTransactionByHash(txHash);
console.log(result);
```
### Bank send - create tx and broadcast
```js
const fctAmount = 10;
let result = await firma.Bank.send(wallet, address, fctAmount);
```
### Bank send - extended version
```js
const fctAmount = 10;
let result = await firma.Bank.send(wallet, address, fctAmount, { memo: "", fee: 30000, gas: 300000 });
```
### Calculate gas
```js
let gas = await firma.Bank.getGasEstimationSend(wallet, address, fctAmount);
```
### Mint NFT
```js
const tokenURI = "https://ipfs-firma-devnet.firmachain.org/ipfs/QmYsezxzunake9EmyoU4HsWKEyHQLgE3syTEpTSQEhNChA";
let result = await firma.Nft.mint(wallet, tokenURI);
```
### Transfer NFT
```js
const tokenId = 1;
let result = await firma.Nft.transfer(wallet, address, tokenId);
```
### Burn NFT
```js
const tokenId = 1;
let result = await firma.Nft.burn(wallet, tokenId);
```
You can see everything usage of firma-js on the test folder.
</br>
https://github.com/FirmaChain/firma-js/tree/main/test