npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@zecrey/zecrey-mobile-core-l2

v0.1.42

Published

## Account information

Downloads

48

Readme

zecrey-mobile-core-l2

Account information

let zecrey_keypair = account.keypairs.find((i) => i.type === "Zecrey");
let { publicKey, name } = zecrey_keypair;

let url = "https://..."; // L2 API base url
let enc_url = "https://..."; // decrypt L2 number API base url

1. Register Zecrey L2 account with a keypair and a name.

import { registerL2Account } from "@zecrey/zecrey-mobile-core-l2";

try {
  let name = "example.zecrey";
  await registerL2Account(name, publicKey, url);
} catch (err) {
  throw err;
  // It fails if the name is already taken, with an error message like "example.zecrey already registered".
}

2. Get Zecrey L2 account information by public key.

import { fetchAccountDetailByPublicKey } from "@zecrey/zecrey-mobile-core-l2";

let { accountName, accountIndex } = await fetchAccountDetailByPublicKey(
  publicKey,
  url
);
// It only works for active accounts, those registered and deposited assets already.
// It throws an error if there's no active account with the given key.

3. Get Zecrey L2 account status.

import { getL2AccountStatus } from "@zecrey/zecrey-mobile-core-l2";

let { isRegistered, isActive, accountName } = await getL2AccountStatus(
  publicKey,
  url
);
// It works for all accounts, including unregistered ones, registered but inactive ones, and active ones.

4. Get Zecrey L2 account index by name.

import { getAccountIndexByName } from "@zecrey/zecrey-mobile-core-l2";

let accountIndex = await getAccountIndexByName("example.zecrey", url); // 65326
// Use it to check on the payee account for L2-transfer.
// It throws an error if there's no account registered with the given name.

5. Get account's locked assets

import {
  CHAIN_ID_USED_IN_L2,
  getLockedAssetByAccountIndex,
} from "@zecrey/zecrey-mobile-core-l2";

// Get all the locked amounts of all assets of each chain of the given account.
let locked = await getLockedAssetByAccountIndex(accountIndex, url);
// Get the locked amount of asset REY from Ethereum.
let ETHEREUM_ID = CHAIN_ID_USED_IN_L2["Ethereum"];
let REY_ID = 0;
let amount = locked[ETHEREUM_ID][REY_ID]; // number without decimal
// Please remember to correct the numbers calculated with their decimal places.

6. Get account's liquidity information

import {
  getLpByAccount,
  L2AssetController,
} from "@zecrey/zecrey-mobile-core-l2";

let controller = new L2AssetController(...args, () => url);
let assets = controller.getAssets(); // information of all the L2 assets

// Get the information of all the liquidity the user added
let LPs = await getLpByAccount(accountIndex, asstes, url);
// Get the balance of one of the liquidity the user added
let bal = await getLpByAccountAndPairIndex(accountIndex, pairIndex, url); // decrypted balance string
// Get the total lp amount and total assets amount of the pair.
let info = await getPairInfo(pairIndex, url); // {asset_a_amount: 20657355, asset_b_amount: 12673266, total_lp_amount: 16180116}

7. Get account's L2 assets' information (balance encrypted)

import { getL2AssetListByAccountIndex } from "@zecrey/zecrey-mobile-core-l2";

let assets = await getL2AssetListByAccountIndex(accountIndex, url); // without decrypted balance
// Please decrypt the encrypted balance strings with DecryptManager to get balances in number.

Decrypt L2 number

All the asset amounts in Layer 2 are encrypted. Decrypt with the user's private key to get the amount in number.

import { DecryptManager } from "@zecrey/zecrey-mobile-core-l2";

// eg.

// 1. A proper way to decrypt an encrypted private key to hex string.
let getDecryptPrivateKey = async (encryptedPrivateKey) => {
  // ...
  return Promise.resolve("..."); // the decrypted private key of the Zecrey keypair
};

// 2. Proper ways to get the permitted accounts' information.
//    Please check on the user permission/access before decrypting.
let getAllAccounts = () => store.accounts;
let getCurrentAccount = () => store.currentAccount;

// 3. 'elgamalRawDec' method from the crypto lib.
let elgamalRawDec = global.elgamalRawDec;

// 4. Instance
let manager = new DecryptManager(
  getDecryptPrivateKey,
  getAllAccounts,
  getCurrentAccount,
  elgamalRawDec,
  () => enc_url
);

// 5. Decrypt.
// Decrypt with the current account.
let num1 = await manager.decrypt([
  {
    enc: "I9dK8ZfIf0YQ/kn/lr9tMnSyK0eEA2/5iGxZDytkMK8vNgCJQ1Zh0LojHwVRBS5Oq5SUNMRKW6EfTpYVgRregA==",
    decimal: 4,
  },
]); // [24.3954]
// Decrypt with a selected account of the current wallet.
let num2 = await manager.decrypt(
  [
    {
      enc: "I9dK8ZfIf0YQ/kn/lr9tMnSyK0eEA2/5iGxZDytkMK8vNgCJQ1Zh0LojHwVRBS5Oq5SUNMRKW6EfTpYVgRregA==",
      decimal: 4,
    },
  ],
  "Account 1", // name of the account, whose private key is used to decrypt the balance_enc strings.
  enc_url // optional
);

// 6. It works as well if the enc string isn't an encrypted string.
let num3 = await manager.decrypt([{ enc: "100", decimal: 0 }]); // [100]

L2 Asset Controller

import { DecryptManager,  L2AssetController } from "@zecrey/zecrey-mobile-core-l2";

// 1. A proper way to get the current account's information.
let getCurrentAccount = () => store.currentAccount;

// 2. A proper way to decrypt L2 numbers.
let decryptManager = new DecryptManager(...);
let decrypt = decryptManager.decrypt;

// 3. A proper way to get the token price, using local cache or HTML requests.
let getPrice = store.PriceTracker.getPrice;

// 4. Instance
let controller = new L2AssetController(
  getCurrentAccount, decrypt, getPrice, () => url
);

// 5. Fetch or update balance of L2 assets. Please refresh when new transaction's published or account changes.
controller.fetch();

// 6. Get total asset value of the current account.
let total = controller.getTotal(); // "600.00", in USD

// 7. Get total asset value from one of the user's account.
let { privateKey } = zecrey_keypair;
let total = controller.getAssetMapByPrivateKey(privateKey).total; // "600.00", in USD

// 8. Get assets' information of the current account.
let assets = controller.getAssets();
// OR
let assets = controller.assets; // observable

// 9. Get assets' information from one of the user's account.
let { privateKey } = zecrey_keypair;
let assets = controller.getAssetMapByPrivateKey(privateKey).assets;

L2 transaction manager

It works for both internal and external L2 transaction request, and requires to valdiate the permission in both situations. For internal transactions, please make sure the user has unlocked the app and signs with the current selected account's keypair. For external ones, besides things mentioned above, please make sure the request is from a connected Dapp as well.

1. Instance.

import { DecryptManager, L2TxManager } from "@zecrey/zecrey-mobile-core-l2";

// 1. A proper way to get the Ethereum addresses of the permitted accounts, using PermissionsController, mobx store, local storage or something else.
let getPermittedAccounts = (origin) => {
  // ...
  return permitted; // ["0x09E45d6FcF322c4D93E6aFE7076601FF10BA942E"]
};

// 2. A proper way to get the current account's information.
let getCurrentAccount = () => store.currentAccount;

// 3. A proper way to decrypt L2 numbers.
let decryptManager = new DecryptManager(...);
let decrypt = decryptManager.decrypt;

// 4. A proper way to get current network.
let getNetwork = () => store.network;

// 5. Instance.
let txManager = new L2TxManager(
  getPermittedAccounts, getCurrentAccount, decrypt, getNetwork, () => url
);

// Reset and refresh when the current account changes.
txManager.L2TransactionTracker.reset();
await txManager.L2TransactionTracker.refresh();

The instance of L2TxManager will fetch the latest 50 transactions automatically when it initializes. Meanwhile, it'll refresh its transaction list when any new transaction is created after its initialization.

2. Get information of published transactions

// Get transaction details by hash. It only works for transactions send by the current account.
let tx = await txManager.getTxByHash("4d3bcfa3-c3ca-11ec-8a97-42010a940002");

// Get published transaction list of the current account.
// Note: Only contains the latest 50 transactions and newly created transaction after its initialization.
let txs = txManager.getTxs();
// OR
let txs = txManager.L2TransactionTracker.transactions; // observable

// Get transactions by chain ID.
let txsByChainId = txManager.getTxs(chainId);

// Get the number of the transactions sent by the current account.
let total = txManager.L2TransactionTracker.total; // all txs
let pending = txManager.L2TransactionTracker.countPending; // pending txs

// Fetch more transactions.
// Note: the situation here is to fetch the older transactions and add to the bottom of the list.
txManager.L2TransactionTracker.fetchMoreTxs();

// Reset and refresh when the current account changes.
txManager.L2TransactionTracker.reset();
await txManager.L2TransactionTracker.refresh();

3. Decrypt and calculate amounts in L2 transactions.

import { getL2TxAmount, getL2LPTxAmount } from "@zecrey/zecrey-mobile-core-l2";

let l2Assets = store.l2AssetsManager.getAssets(); // Data of all the L2 assets.
let decrypt = store.decryptManager.decrypt; // Method of decrypting L2 numbers.
let accountName = "bob.zecrey"; // The Zecrey account name of the current account, which is the sender of the transactions.

// 1. Amount in L2 Transfer, Withdraw, Deposit, Lock and Unlock.
let { txType, txAccounts, txFee, txAssetAId, txAssetBId, txFeeAssetId } = tx;
let amount = await getL2TxAmount(
  txType,
  txAccounts,
  txFee,
  txAssetAId,
  txFeeAssetId,
  decrypt,
  l2Assets,
  accountName
); // 12.5489

// 2. Amounts in L2 Swap, Add Liquidity and Remove Liquidity.
let amounts = await getL2LPTxAmount(
  txType,
  txAccounts,
  txFee,
  txFeeAssetId,
  txAssetAId,
  txAssetBId,
  accountName,
  l2Assets,
  decrypt
); // [0.001, 0.0101]

4. Get information of transactions to be approved.

A unapproved transaction is the transaction that requires to be confirmed or rejected. If there's any unapproved transaction, no matter the app opens or not, the user should be noticed.

let unapproved = txManager.getUnapprovedTxList();

5. Deal with transactions.

No matter where the transaction request comes from, only confirmed ones get published in the end. When the user confirms a transaction, it's signed with the private key of the Zecrey account and then sent to the backend.

// 1. Create an internal transaction request.
let origin = "zecrey"; // internal origin
let { id } = await txManager.addUnapprovedL2Tx(txParams, origin);

// 3. Confirm it.
let proof = await txManager.signL2Tx(txId, decryptedPrivateKey);
let hash = await txManager.publish(txId, proof);

// 4. Or reject it
txManager.rejectL2Tx(id);

6. Params to create transaction

  1. Transfer
import { L2_TRANSACTION_TYPE } from "@zecrey/zecrey-mobile-core-l2";

// 1. It has to contain 1~2 payees.
// 2. Transfer amount could be 0.
// 3. Payee's name doesn't contains the '.zecrey' suffix.
// 4. The 2 payees cannot be the same.
// 5. Every payee's Zecrey account has to be active.
// 6. Sender must have enough balance to transfer and pay for the gas.
// 7. Sender's balance has to match the data in backend.
// 8. Sender can't be payee.

let params = {
  action: L2_TRANSACTION_TYPE.TRANSFER, // 4
  from: "bob.zecrey", // sender account name
  args: {
    assetId: 0,
    assetDecimal: 4,
    payees: [{ address: "alice", amount: "0.0001" }], // send 0.0001 to alice.zecrey
    memo: "",
    balance: 24.0718, // sender's balance of the asset to transfer
  },
};

let { id } = await txManager.addUnapprovedL2Tx({ ...params }, origin);
  1. Unlock
import { L2_TRANSACTION_TYPE } from "@zecrey/zecrey-mobile-core-l2";

// 1. Sender's balance of the gas fee asset has to match the data in backend.
// 2. It will unlock all the token of the target asset locked on the selected chain.
// 3. The balances used in params have to match the data in the Backend.

let params = {
  action: L2_TRANSACTION_TYPE.UNLOCK, // 3
  from: "bob.zecrey", // sender account name
  args: {
    // unlock all the ETH locked from Etheruem, and pay the gas fee with REY
    assetId: 1,
    chainId: 0, // ID of the chain that the asset locked from
    gasFeeAssetId: 0,
    gasFeeAssetDecimal: 4,
    gasFeeAssetBalance: 1.4501,
  },
};

let { id } = await txManager.addUnapprovedL2Tx({ ...params }, origin);
  1. Swap

The ratio to swap token changes by the balances in the liquidity pool. Please make sure the swap amounts are not out of date.

import {
  getSwapAmount,
  L2_TRANSACTION_TYPE,
} from "@zecrey/zecrey-mobile-core-l2";

// 1. The account must have enough balance to pay for the swap and gas fee.
// 2. The gas asset could be the same with the swap-from asset or the swap-to asset.
// 3. Gas asset could be any L2 asset.
// 4. The balances used in params have to match the data in the Backend.
// 5. Slippage is a percentage number, in which 0.5 means 0.5%.

let assetREY = store.l2Assets.find((i) => i.assetId === 0); // asset that swap in
let assetETH = store.l2Assets.find((i) => i.assetId === 1); // asset that swap out

// Calculate swap amounts
// Get 'out' amount by the 'in' amount
let amountIn = 0.01;
let swapToAmount = await getSwapAmount(
  pairIndex,
  assetREY.assetId,
  assetREY.decimal,
  amountIn,
  true,
  url // optional
); // 3, without decimal places
// OR
// Get 'in' amount requires by the 'out' amount
let amountOut = 0.0003;
let swapToAmount = await getSwapAmount(
  pairIndex,
  assetREY.assetId,
  assetREY.decimal,
  amountOut,
  false,
  url // optional
); // 100, without decimal places

// Please remember to correct the numbers calculated with their decimal places.

let params = {
  action: L2_TRANSACTION_TYPE.SWAP, // 5
  from: "bob.zecrey", // sender account name
  args: {
    // swap with 0.01 REY for 0.0003 ETH, and pay the gas fee with REY
    pairIndex: 0,
    swapFromAssetId: assetREY.assetId,
    swapFromAssetDecimal: assetREY.decimal,
    swapFromAssetBalance: assetREY.balance,
    swapFromAmount: 0.01,
    swapToAssetId: assetETH.assetId,
    swapToAssetDecimal: assetETH.decimal,
    swapToAmount: 0.0003,
    gasFeeAssetId: assetREY.assetId,
    gasFeeAssetDecimal: assetREY.decimal,
    gasFeeAssetBalance: assetREY.balance,
    slippage: 0.5, // percentage, means 0.5%
  },
};

let { id } = await txManager.addUnapprovedL2Tx({ ...params }, origin);
  1. Add liquidity
import { L2_TRANSACTION_TYPE } from "@zecrey/zecrey-mobile-core-l2";

// 1. The account must have enough balance to pay for the assets and gas fee
// 2. The assets' ratio has to match the ratio in pool.
// 3. The pool ratio changes by every swap transaction.
// 4. Asset amounts are strings.
// 5. Neither amount could be 0.
// 6. REY-ETH and ETH-REY are the same.
// 7. The balances used in params have to match the data in the Backend.
// 8. Gas asset could be any L2 asset.

let assetREY = store.l2Assets.find((i) => i.assetId === 0);
let assetETH = store.l2Assets.find((i) => i.assetId === 1);
let params = {
  action: L2_TRANSACTION_TYPE.ADD_LIQUIDITY, // 6
  from: "bob.zecrey", // sender account name
  args: {
    // add liquidity with 0.01 REY and 0.0004 ETH, and pay the gas fee with REY
    pairIndex: 0,
    asset1Id: assetREY.assetId,
    asset1Decimal: assetREY.decimal,
    asset1Balance: assetREY.balance,
    asset1Amount: 0.01,
    asset2Id: assetETH.assetId,
    asset2Decimal: assetETH.decimal,
    asset2Balance: assetETH.balance,
    asset2Amount: 0.0004,
    gasFeeAssetId: assetREY.assetId,
    gasFeeAssetDecimal: assetREY.decimal,
    gasFeeAssetBalance: assetREY.balance,
  },
};
// Note: the amounts added have to match the current ratio of the liquidity token pair

let { id } = await txManager.addUnapprovedL2Tx({ ...params }, origin);
  1. Remove liquidity
import { L2_TRANSACTION_TYPE } from "@zecrey/zecrey-mobile-core-l2";

// 1. The account must have enough balance to burn the LP token, and pay for the gas fee.
// 2. Amount to remove is a string, and it cannot be zero.
// 3. Slippage is a percentage number, in which 0.5 means 0.5%.
// 4. REY-ETH and ETH-REY are the same.
// 5. The balances used in params have to match the data in the Backend.
// 6. Gas asset could be any L2 asset.

let assetREY = store.l2Assets.find((i) => i.assetId === 0);
let assetETH = store.l2Assets.find((i) => i.assetId === 1);
let params = {
  action: L2_TRANSACTION_TYPE.REMOVE_LIQUIDITY, // 7
  from: "bob.zecrey", // sender account name
  args: {
    // remove 0.0007 LP token, whose token pair contains REY and ETH, and pay the gas fee with REY
    pairIndex: 0,
    lpDecimal: 4,
    lpBalance: 0.349, // sender's balance of the lp token
    removeAmount: 0.0007,
    slippage: 0.5, // percentage, means 0.5%
    assetAId: assetREY.assetId,
    assetADecimal: assetREY.decimal,
    assetABalance: assetREY.balance,
    assetBId: assetETH.assetId,
    assetBDecimal: assetETH.decimal,
    assetBBalance: assetETH.balance,
    gasFeeAssetId: assetREY.assetId,
    gasFeeAssetDecimal: assetREY.decimal,
    gasFeeAssetBalance: assetREY.balance,
  },
};

let { id } = await txManager.addUnapprovedL2Tx({ ...params }, origin);
  1. Withdraw
import { L2_TRANSACTION_TYPE } from "@zecrey/zecrey-mobile-core-l2";

// 1. Withdraw amount has to be less than the user's asset balance, and it cannot be zero.
// 2. Withdraw amount has to be less than the total asset amount in the given chain.
// 3. The balances used in params have to match the data in the Backend.

let assetREY = store.l2Assets.find((i) => i.assetId === 0);
let assetETH = store.l2Assets.find((i) => i.assetId === 1);
let params = {
  action: L2_TRANSACTION_TYPE.WITHDRAW, // 8
  from: "bob.zecrey", // sender account name
  args: {
    // withdraw 0.12 ETH to the address "0x09E45d6FcF322c4D93E6aFE7076601FF10BA942E" on Ethereum, and pay the gas fee with REY
    targetAddress: "0x09E45d6FcF322c4D93E6aFE7076601FF10BA942E", // L1 address, which will receive the token withdrawn
    chainId: 0, // the chain, to which the token withdrawn
    assetId: assetETH.assetId,
    assetDecimal: assetETH.decimal,
    assetBalance: assetETH.balance,
    gasFeeAssetId: assetREY.assetId,
    gasFeeAssetDecimal: assetREY.decimal,
    gasFeeAssetBalance: assetREY.balance,
    amount: 0.12,
  },
};

let { id } = await txManager.addUnapprovedL2Tx({ ...params }, origin);

Calculate gas fee charged in L2 transaction

import { getGasFee, getWithdrawGasFee } from "@zecrey/zecrey-mobile-core-l2";

// Get the gas fee amount for L2 transfer, swap, and unlock assets, as well as the transactions of managing liquidity.
let fee = await getGasFee(gasFeeAssetId, url); // 0.0001, contains decimal places

// Get the gas fee amount required for L2 withdraw assets.
let withdrawAmount = 10000; // If asest decimal places is 4, it means to remove 1.0000 token.
let fee = await getWithdrawGasFee(
  gasFeeAssetId,
  withdrawAssetId,
  withdrawAmount, // Note: decimal places removed.
  url // optional
); // 3.7953, contains decimal places

Locked asset information

import {
  getLockedAssetInfo,
  getLockedAprByChainId,
  getLockedAmountByAssetId,
} from "@zecrey/zecrey-mobile-core-l2";

// Get status of all the locked assets of each chain.
let info = await getLockedAssetInfo(url);
let aprs = info.map((i) => i.apr); // unit: 1/10000

// Get locking apr of assets on the given chain
let data = await getLockedAprByChainId(chainId, url);

// Get the total locked amount of the given asset on every chain
let data = await getLockedAmountByAssetId(assetId, url);

Liquidity token pair information

import {
  getPairList,
  getLpValue,
  getAssetsInLP,
  getMatchedLPAssets,
  getPairByAssetIds,
} from "@zecrey/zecrey-mobile-core-l2";

// Get all the token pairs supported.
let LPs = await getPairList(url);

// Calculate the assets amount to receive if the given amount of lp token is removed.
let data = await getLpValue(pairIndex, removeAmount, lpDecimal, url);

// Get ratio of the liquidity token pair.
let { asset1PerAsset2, asset2PerAsset1 } = await getPairRatio(
  pairIndex,
  asset1Id,
  url
);

let controller = new L2AssetController(...args);
let assets = controller.getAssets(); // information of all the L2 assets
// Get all the L2 assets can be found in a liquidity token pair.
let assetsInPair = getAssetsInLP(LPs, assets);
// Get all the L2 assets that a liquidity made up by it and the given asset can be found.
let assetsMatched = getMatchedLPAssets(givenAssetId, LPs, assets);

// Get Liquidity pair by asset IDs.
let LP = await getPairByAssetIds(assetAId, assetBId, LPs, url);

Withdraw limit

The liquidity is provided by locking assets that allows users to withdraw asset to L1.

import { getWithdrawLimit } from "@zecrey/zecrey-mobile-core-l2";

let limit = await getWithdrawLimit(assetId, chainId, url); // 95409, without decimal places
// Please correct the number with the asset decimal.

Chains to withdraw

import { getWithdrawChainInfo } from "@zecrey/zecrey-mobile-core-l2";

// Get all the supported L1 chains, to which assets can be withdrawn.
let info = await getWithdrawChainInfo(url);

let chains = info.find((i) => i.asset_id === assetId);
// Get all the chain Ids that the given asset can be withdrawn.
let chainIds = chains?.chains_info?.map((i) => i.chain_id) || [];

Constant

// 1. Chain ID on L2
import {
  CHAIN_ID_USED_IN_L2,
  MAINNET_CHAIN_ID,
} from "@zecrey/zecrey-mobile-core-l2";
// Get L2 chainId of Ethereum
let chainIdOnL2 = CHAIN_ID_USED_IN_L2[BLOCKCHAIN.ETHEREUM]; // use chain name on L1
// OR
let chainIdOnL1 = MAINNET_CHAIN_ID;
let chainIdOnL2 = CHAIN_ID_USED_IN_L2[chainIdOnL1]; // use chain ID on L1

// 2. Chain info on L1
import { getOriginalChainInfoByChainIdOnL2 } from "@zecrey/zecrey-mobile-core-l2";
// Get id and name of Ethereum on L1
let { chainId, chainName } = getOriginalChainInfoByChainIdOnL2(0, "testnet"); // {chainId: '0x4', chainName: 'Ethereum'}

// 3. L2 transaction types
import {
  L2_TRANSACTION_TYPE,
  L2_TRANSACTION_TYPE_STRING,
  L2_TRANSACTION_TYPE_MAP,
} from "@zecrey/zecrey-mobile-core-l2";

API

POST /api/v1/crypto/getEncCollisionBatches

Request Params

| Name | Type | Size | Comment | | ---------------- | -------- | ---- | ------------------------- | | enc_data_batches | []string | | raw encryption data array |

Response Struct

{
    "status": int, // status for the request
    "msg": string, // response message
    "err":{ //err struct
    	"err_type": int, // err type
    	"err_msg": string, // error msg
	  },
    "result": [{ //result struct
      "enc_data": string
  		"colision_result": int // result
    }]
}

GET /api/v1/info/getLayer2BasicInfo

Request Params

null

Response Struct

{
    "status": int, // status for the request 0 succeed 1 fail
    "msg": string, // response message
    "err": { //err struct
    	"err_type": int, // err type
    	"err_msg": string, // error msg
	  },
    "result": { // result struct

    }
}

POST /api/v1/tx/sendTx

Request Params

| Name | Type | Comment | | ------- | ------ | ------------------------------------------------- | | tx_type | int | tx type | | tx_info | string | JSON string including tx_type, tx_data(raw_data), |

Response Struct

{
    "status": int, // status for the request
    "msg": string, // response message
    "err": { // struct
    	"err_type": int, // err type
    	"err_msg": string, // error msg
	  },
    "result": {
    	"tx_id": string, // tx id string
    }
}
result struct

| Name | Type | Size | Comment | | ------------------------ | ------------ | ----- | ------------------------ | | block_committed | int | int64 | committed blocks count | | block_verified | int | int64 | verified blocks count | | total_transactions_count | int | int64 | total transactions count | | contract_addresses | string array | | string array |

GET /api/v1/tx/getTxsListByAccountIndex

Request Params

| Name | Type | Size | Comment | | ------------- | ---- | ------ | ------------- | | account_index | int | uint32 | account index | | offset | int | uint32 | page index | | limit | int | uint32 | page size |

Response Struct

{
    "status": int, // status for the request
    "msg": string, // response message
    "err":{ // err struct
    	"err_type": int, // err type
    	"err_msg": string, // error msg
	  },
    "result": {
      	"limit": int,
      	"offset": int,
      	"total": int, // total size
        "txs": [{}], // txs
    }
}
txs struct

| Name | Type | Size | Comment | | ---------------- | -------- | -------------------------------------------- | ----------------------------------- | | tx_hash | string | 32 | tx hash | | tx_type | int | uint(Range: 1 - 64) | tx type | | gas_fee | int | int64 | transaction fee | | gas_fee_asset_id | int | uint | tx fee asset id | | tx_status | int | | Tx status | | block_height | int | | block height | | block_status | int | | block status of corresponding block | | block_id | int | | block id of corresponding block | | asset_a_id | int | uint32 | asset a id | | asset_b_id | int | uint32 | asset b id | | tx_amount | int | only counts when tx_type is withdraw/deposit | tx amount | | tx_participants | []string | Example: {"a.zecrey","b.zecrey", "c.zecrey"} | tx participants | | native_address | string | only counts when tx_type is withdraw_type | receiver address | | chain_id | int | uint32 | chain id | | created_at | int64 | timestamp | transaction create time | | memo | string | | transaction memo |

GET /api/v1/tx/getTxsListByAccountIndexAndTxType

Request Params

| Name | Type | Size | Comment | | ------------- | ---- | ------ | ------------- | | account_index | int | uint32 | account index | | tx_type | int | uint8 | tx type | | offset | int | uint32 | page index | | limit | int | uint32 | page size |

tx_type option

| Number | Comment | | ------ | -------------- | | 1 | L2Transfer | | 2 | Liquidity | | 3 | L2Swap | | 4 | WithdrawAssets | | 5 | EncryptAssets |

Response Struct

{
    "status": int, // status for the request
    "msg": string, // response message
    "err":{ // err struct
    	"err_type": int, // err type
    	"err_msg": string, // error msg
	  },
    "result": {
      	"limit": int,
      	"offset": int,
      	"total": int, // total size
        "txs": [{}], // txs
    }
}
txs struct

| Name | Type | Size | Comment | | ---------------- | -------- | -------------------------------------------- | ----------------------------------- | | tx_hash | string | 32 | tx hash | | tx_type | int | uint(Range: 1 - 64) | tx type | | gas_fee | int | int64 | transaction fee | | gas_fee_asset_id | int | uint | tx fee asset id | | tx_status | int | | Tx status | | block_height | int | | block height | | block_status | int | | block status of corresponding block | | block_id | int | | block id of corresponding block | | asset_a_id | int | uint32 | asset a id | | asset_b_id | int | uint32 | asset b id | | tx_amount | int | only counts when tx_type is withdraw/deposit | tx amount | | tx_participants | []string | Example: {"a.zecrey","b.zecrey", "c.zecrey"} | tx participants | | native_address | string | only counts when tx_type is withdraw_type | receiver address | | chain_id | int | uint32 | chain id | | created_at | int64 | timestamp | transaction create time | | memo | string | | transaction memo |

GET /api/v1/tx/getTxByHash

Request Params

| Name | Type | Comment | | ------- | ------ | ---------------- | | tx_hash | string | transaction hash |

Response Struct

{
    "status": int, // status for the request
    "msg": string, // response message
    "err": { // struct
    	"err_type": int, // err type
    	"err_msg": string, // error msg
	  },
    "result": { //struct
        "tx_hash": string, // tx hash
        "tx_type":int, // tx type
        "tx_asset_a_id": int, // asset a id
        "tx_asset_b_id": int, // asset b id
        "tx_details": [{ // []struct
          "asset_id": int,
          "asset_type": int,
        	"account_index": int, // account index
        	"account_name": string, // account name
        	"account_balance": string, // account balance enc before this tx
        	"account_delta": string, // delta amount encryption info
    		}],
        "tx_amount": int, // tx amount
        "native_address": string, // receiver address
        "chain_id": int, //chain id
        "tx_status": int, // tx status
        "gas_fee_asset_id": int, // fee asset id
        "gas_fee": int, // transaction fee
        "block_height": int, // layer-2 block height
        "block_status": int, // block status
        "created_at": int64, // create time
        "block_id": int, // block id
        "memo": string, // memo
    }
}

Generate proof

proveWithdraw

let proof = await ZecreyLibModules.proveWithdraw(JSON.stringify(segment));

only one input: JSON format string

type WithdrawSegmentFormat struct {
	// account index
	AccountIndex int    `json:"account_index"`
	// encryption of the balance
	C            string `json:"c"`
	// public key
	Pk           string `json:"pk"`
	// balance
	B            int64  `json:"b"`
	// withdraw amount
	BStar        int64  `json:"b_star"`
	// private key
	Sk           string `json:"sk"`
	// asset id
	AssetId      int    `json:"asset_id"`
	// chain id
	ChainId      int    `json:"chain_id"`
	// receive address
	ReceiveAddr  string `json:"receive_addr"`
	// fee part
	// encryption of balance of the gas fee asset
	C_fee         string `json:"c_fee"`
	// balance of gas fee asset
	B_fee         int64  `json:"b_fee"`
	// gas fee asset id
	GasFeeAssetId int    `json:"gas_fee_asset_id"`
	// gas fee
	GasFee        int64  `json:"gas_fee"`
}

proveUnlock

let proof = await ZecreyLibModules.proveUnlock(JSON.stringify(segment));

only one input: JSON format string

type UnlockSegmentFormat struct {
	// chain id
	ChainId      int    `json:"chain_id"`
	// account index
	AccountIndex int    `json:"account_index"`
	// asset id
	AssetId      int    `json:"asset_id"`
	// balance
	Balance      int64  `json:"balance"`
	// unlock amount
	DeltaAmount  int64  `json:"delta_amount"`
	// private key
	Sk           string `json:"sk"`
	// fee part
	// encryption of the balance of the gas fee
	C_fee         string `json:"c_fee"`
	// gas fee balance
	B_fee         int64  `json:"b_fee"`
	// gas fee asset id
	GasFeeAssetId int    `json:"gas_fee_asset_id"`
	// gas fee
	GasFee        int64  `json:"gas_fee"`
}

proveTransfer

| Name | Type | Comment | | ------- | ------ | ------------------- | | assetId | int | unique asset id | | gasFee | int | transaction gas fee | | memo | string | memo |

let proof = await ZecreyLibModules.proveTransfer(
  assetId,
  gasFee,
  memo,
  JSON.stringify([senderSegment, payee1Segment, payee2Segment])
);

JSON format string

// TransferSegmentFormat Format is used to accept JSON string
type TransferSenderSegmentFormat struct {
	// account index
	AccountIndex int `json:"account_index"`
	// ElGamalEnc
	BalanceEnc string `json:"balance_enc"`
	// Balance
	Balance int64 `json:"Balance"`
	// public key
	Pk string `json:"pk"`
	// bDelta
	BDelta int64 `json:"b_delta"`
	// secret key
	Sk string `json:"Sk"`
}
type TransferPayeeSegmentFormat struct {
	// account index
	AccountIndex int `json:"account_index"`
	// ElGamalEnc
	BalanceEnc string `json:"balance_enc"`
	// public key
	Pk string `json:"pk"`
	// bDelta
	BDelta int64 `json:"b_delta"`
}

proveSwap

let proof = await ZecreyLibModules.proveSwap(JSON.stringify(segment));

only one input: JSON format string

/*
	SwapSegmentFormat: format version of SwapSegment
*/
type SwapSegmentFormat struct {
	// pair index
	PairIndex    int    `json:"pair_index"`
	// account index
	AccountIndex int    `json:"account_index"`
	// encryption of the balance of asset A
	C_uA         string `json:"c_u_a"`
	// user public key
	Pk_u         string `json:"pk_u"`
	// system treasury account public key
	Pk_treasury  string `json:"pk_treasury"`
	// asset a id
	AssetAId     int    `json:"asset_a_id"`
	// asset b id
	AssetBId     int    `json:"asset_b_id"`
	// swap amount for asset a
	B_A_Delta    int64  `json:"b_a_delta"`
	// balance for asset a
	B_u_A        int64  `json:"b_u_a"`
	// equal to B * (1 - slippage), B gets from the layer-2
	MinB_B_Delta int64  `json:"min_b_b_delta"`
	// fee rate, gets from layer-2
	FeeRate      int    `json:"fee_rate"`
	// treasury rate gets from layer-2
	TreasuryRate int    `json:"treasury_rate"`
	// private key
	Sk_u         string `json:"sk_u"`
	// fee part
	C_fee         string `json:"c_fee"`
	B_fee         int64  `json:"b_fee"`
	GasFeeAssetId int    `json:"gas_fee_asset_id"`
	GasFee        int64  `json:"gas_fee"`
}

proveAddLiquidity

let proof = await ZecreyLibModules.proveAddLiquidity(JSON.stringify(segment));

only one input: JSON format string

type AddLiquiditySegmentFormat struct {
	PairIndex    int    `json:"pair_index"`
	AccountIndex int    `json:"account_index"`
	C_uA         string `json:"c_u_a"`
	C_uB         string `json:"c_u_b"`
	Pk_pool      string `json:"pk_pool"`
	Pk_u         string `json:"pk_u"`
	AssetAId     int    `json:"asset_a_id"`
	AssetBId     int    `json:"asset_b_id"`
	B_uA         int64  `json:"b_u_a"`
	B_uB         int64  `json:"b_u_b"`
	B_A_Delta    int64  `json:"b_a_delta"`
	B_B_Delta    int64  `json:"b_b_delta"`
	Sk_u         string `json:"sk_u"`
	// fee part
	C_fee         string `json:"c_fee"`
	B_fee         int64  `json:"b_fee"`
	GasFeeAssetId int    `json:"gas_fee_asset_id"`
	GasFee        int64  `json:"gas_fee"`
}

proveRemoveLiquidity

let proof = await ZecreyLibModules.proveRemoveLiquidity(
  JSON.stringify(segment)
);
type RemoveLiquiditySegmentFormat struct {
	PairIndex    int    `json:"pair_index"`
	AccountIndex int    `json:"account_index"`
	C_u_LP       string `json:"c_u_lp"`
	Pk_u         string `json:"pk_u"`
	B_LP         int64  `json:"b_lp"`
	Delta_LP     int64  `json:"delta_lp"`
	MinB_A_Delta int64  `json:"min_b_a_delta"`
	MinB_B_Delta int64  `json:"min_b_b_delta"`
	AssetAId     int    `json:"asset_a_id"`
	AssetBId     int    `json:"asset_b_id"`
	Sk_u         string `json:"sk_u"`
	// fee part
	C_fee         string `json:"c_fee"`
	B_fee         int64  `json:"b_fee"`
	GasFeeAssetId int    `json:"gas_fee_asset_id"`
	GasFee        int64  `json:"gas_fee"`
}

Error Types

| Name | Value | | -------------------------------- | -------------------------------- | | Success | success | | ErrUnmarshal | ErrUnmarshal | | ErrInvalidWithdrawParams | ErrInvalidWithdrawParams | | ErrParseEnc | ErrParseEnc | | ErrParsePoint | ErrParsePoint | | ErrParseBigInt | ErrParseBigInt | | ErrInvalidWithdrawRelationParams | ErrInvalidWithdrawRelationParams | | ErrProveWithdraw | ErrProveWithdraw | | ErrMarshalTx | ErrMarshalTx | | ErrInvalidTransferParams | ErrInvalidTransferParams | | ErrInvalidTransferRelationParams | ErrInvalidTransferRelationParams | | ErrProveTransfer | ErrProveTransfer | | ErrL2SkParams | ErrL2SkParams | | ErrInvalidEncParams | ErrInvalidEncParams | | ErrElGamalEnc | ErrElGamalEnc | | ErrInvalidDecParams | ErrInvalidDecParams | | ErrElGamalDec | ErrElGamalDec | | ErrInvalidSwapParams | ErrInvalidSwapParams | | ErrInvalidSwapRelationParams | ErrInvalidSwapRelationParams |