Safient Claims SDK
JavaScript SDK to manage and interact with the safe claims on Safient protocol.
Package Installation
  npm install safient-claims
Before Initialization
// If not injected web3 provider, create a jsonRpcProvider
const { JsonRpcProvider } = require('@ethersproject/providers');
const provider = new JsonRpcProvider('http://localhost:8545');
// Get signer and chainId from provider
(async () => {
  const signer = await provider.getSigner();
  const providerNetwork = await provider.getNetwork();
  const chainId = providerNetwork.chainId;
})();
Initialization
import { SafientClaims } from 'safient-claims';
const sc = new SafientClaims(signer, chainId);
Arbitrator
sc.arbitrator.getArbitrationFee
SafientMain
sc.safientMain.createSafe
sc.safientMain.createClaim
sc.safientMain.submitEvidence
sc.safientMain.depositSafeFunds
sc.safientMain.recoverSafeFunds
sc.safientMain.setTotalClaimsAllowed
sc.safientMain.getTotalNumberOfSafes
sc.safientMain.getTotalNumberOfClaims
sc.safientMain.getAllSafes
sc.safientMain.getAllClaims
sc.safientMain.getSafeBySafeId
sc.safientMain.getClaimByClaimId
sc.safientMain.getClaimsOnSafeBySafeId
sc.safientMain.getClaimStatus
sc.safientMain.getTotalClaimsAllowed
sc.safientMain.getSafientMainContractBalance
Usage
Arbitrator
Get Arbitration Fee
const getArbitrationFee = async () => {
  try {
    const fee = await sc.arbitrator.getArbitrationFee();
    console.log(fee);
  } catch (e) {
    console.log(e.message);
  }
};
| Returns | Type | Description | 
|---|
| Arbitration fee | number | Arbitration fee in ETH | 
SafientMain
Create Safe
const createSafe = async (inheritorAddress, metaevidenceURI, value) => {
  try {
    const tx = await sc.safientMain.createSafe(inheritorAddress, metaevidenceURI, value);
    console.log(tx);
  } catch (e) {
    console.log(e.message);
  }
};
| Parameter | Type | Description | 
|---|
| inheritorAddress | string | Required. Address of the beneficiary who can claim to inherit this safe | 
| metaevidenceURI | string | Required. IPFS URI pointing to the metaevidence related to arbitration details | 
| value | string | Required. Safe maintanence fee in Gwei, minimum arbitration fee required | 
| Returns | Type | Description | 
|---|
| Transaction Response | object | Includes all properties of a transaction | 
Create Claim
const createClaim = async (safeId, evidenceURI) => {
  try {
    const tx = await sc.safientMain.createClaim(safeId, evidenceURI);
    console.log(tx);
  } catch (e) {
    console.log(e.message);
  }
};
| Parameter | Type | Description | 
|---|
| safeId | number | Required. Id of the safe | 
| evidenceURI | string | Required. IPFS URI pointing to the evidence submitted by the claim creator | 
| Returns | Type | Description | 
|---|
| Transaction Response | object | Includes all properties of a transaction | 
Submit Evidence
const submitEvidence = async (disputeId, evidenceURI) => {
  try {
    const tx = await sc.safientMain.submitEvidence(disputeId, evidenceURI);
    console.log(tx);
  } catch (e) {
    console.log(e.message);
  }
};
| Parameter | Type | Description | 
|---|
| disputeId | number | Required. Id of the dispute representing the claim | 
| evidenceURI | string | Required. IPFS URI pointing to the evidence submitted by the claim creator | 
| Returns | Type | Description | 
|---|
| Transaction Response | object | Includes all properties of a transaction | 
Deposit Safe Funds
const depositSafeFunds = async (safeId, value) => {
  try {
    const tx = await sc.safientMain.depositSafeFunds(safeId, value);
    console.log(tx);
  } catch (e) {
    console.log(e.message);
  }
};
| Parameter | Type | Description | 
|---|
| safeId | number | Required. Id of the safe | 
| value | string | Required. Funds in Gwei | 
| Returns | Type | Description | 
|---|
| Transaction Response | object | Includes all properties of a transaction | 
Recover Safe Funds
Only safe's current owner can execute this
const recoverSafeFunds = async (safeId) => {
  try {
    const tx = await sc.safientMain.recoverSafeFunds(safeId);
    console.log(tx);
  } catch (e) {
    console.log(e.message);
  }
};
| Parameter | Type | Description | 
|---|
| safeId | number | Required. Id of the safe | 
| Returns | Type | Description | 
|---|
| Transaction Response | object | Includes all properties of a transaction | 
Set Total Claims Allowed
Only SafientMain contract deployer can execute this
const setTotalClaimsAllowed = async (claimsAllowed) => {
  try {
    const tx = await sc.safientMain.setTotalClaimsAllowed(claimsAllowed);
    console.log(tx);
  } catch (e) {
    console.log(e.message);
  }
};
| Parameter | Type | Description | 
|---|
| claimsAllowed | number | Required. Number of total claims allowed | 
| Returns | Type | Description | 
|---|
| Transaction Response | object | Includes all properties of a transaction | 
Get Total Number Of Safes
const getTotalNumberOfSafes = async () => {
  try {
    const numOfSafes = await sc.safientMain.getTotalNumberOfSafes();
    console.log(numOfSafes);
  } catch (e) {
    console.log(e.message);
  }
};
| Returns | Type | Description | 
|---|
| Total no. of safes | number | Total number of safes created on SafientMain | 
Get Total Number Of Claims
const getTotalNumberOfClaims = async () => {
  try {
    const numOfClaims = await sc.safientMain.getTotalNumberOfClaims();
    console.log(numOfClaims);
  } catch (e) {
    console.log(e.message);
  }
};
| Returns | Type | Description | 
|---|
| Total no. of claims | number | Total number of claims created on SafientMain | 
Get All Safes
const getAllSafes = async () => {
  try {
    const safes = await sc.safientMain.getAllSafes();
    console.log(safes);
  } catch (e) {
    console.log(e.message);
  }
};
| Returns | Type | Description | 
|---|
| Array of safes | Safe[] | Array of all the safes created on SafientMain | 
Type Safe
| Property | Type | Description | 
|---|
| safeId | BigNumber | Id of the safe | 
| safeCreatedBy | string | Address of the safe creator | 
| safeCurrentOwner | string | Address of the current safe owner | 
| safeInheritor | string | Address of the safe inheritor (beneficiary) | 
| metaEvidenceId | Bigumber | Id used to uniquely identify a piece of meta-evidence | 
| claimsCount | Bigumber | Number of claims made on this safe | 
| safeFunds | Bigumber | Total safe funds in Gwei | 
Get All Claims
const getAllClaims = async () => {
  try {
    const claims = await sc.safientMain.getAllClaims();
    console.log(claims);
  } catch (e) {
    console.log(e.message);
  }
};
| Returns | Type | Description | 
|---|
| Array of claims | Claim[] | Array of all the claims created on SafientMain | 
Type Claim
| Property | Type | Description | 
|---|
| safeId | BigNumber | Id of the safe | 
| disputeId | BigNumber | Id of the dispute representing the claim | 
| claimedBy | string | Address of the claim creator | 
| metaEvidenceId | BigNumber | Id used to uniquely identify a piece of meta-evidence | 
| evidenceGroupId | Bigumber | Id used to identify a group of evidence related to a dispute | 
| status | number | Claim status represented by 0, 1, 2 or 3 | 
| result | string | Claim result represented by Passed, Failed or Refused To Arbitrate | 
Get Safe By Safe Id
const getSafeBySafeId = async (safeId) => {
  try {
    const safe = await sc.safientMain.getSafeBySafeId(safeId);
    console.log(safe);
  } catch (e) {
    console.log(e.message);
  }
};
| Parameter | Type | Description | 
|---|
| safeId | number | Required. Id of the safe | 
| Returns | Type | Description | 
|---|
| Safe | Safe | Safe containing safe data | 
Get Claim By Claim Id
const getClaimByClaimId = async (claimId) => {
  try {
    const claim = await sc.safientMain.getClaimByClaimId(claimId);
    console.log(claim);
  } catch (e) {
    console.log(e.message);
  }
};
| Parameter | Type | Description | 
|---|
| claimId | number | Required. Id of the claim | 
| Returns | Type | Description | 
|---|
| Claim | Claim | Claim containing claim data | 
Get All Claims On A Safe By Safe Id
const getClaimsOnSafeBySafeId = async (safeId) => {
  try {
    const claims = await sc.safientMain.getClaimsOnSafeBySafeId(safeId);
    console.log(claims);
  } catch (e) {
    console.log(e.message);
  }
};
| Parameter | Type | Description | 
|---|
| safeId | number | Required. Id of the safe | 
| Returns | Type | Description | 
|---|
| Array of claims | Claim[] | Array of all the claims on a safe | 
Get Claim Status
const getClaimStatus = async (claimId) => {
  try {
    const claimStatus = await sc.safientMain.getClaimStatus(safeId);
    console.log(claimStatus);
  } catch (e) {
    console.log(e.message);
  }
};
| Parameter | Type | Description | 
|---|
| claimId | number | Required. Id of the claim | 
| Returns | Type | Description | 
|---|
| claim status | string | Claim status represented by Active, Passed, Failed or Refused To Arbitrate | 
Get Total No. Of Claims Allowed On A Safe
const getTotalClaimsAllowed = async () => {
  try {
    const claimsAllowed = await sc.safientMain.getTotalClaimsAllowed();
    console.log(claimsAllowed);
  } catch (e) {
    console.log(e.message);
  }
};
| Returns | Type | Description | 
|---|
| Total no. of claims allowed | number | Total no. of claims allowed on a safe | 
Get SafientMain Contract Total Balance
const getSafientMainContractBalance = async () => {
  try {
    const balance = await sc.safientMain.getSafientMainContractBalance();
    console.log(balance);
  } catch (e) {
    console.log(e.message);
  }
};
| Returns | Type | Description | 
|---|
| SafientMain contract balance | number | Total balance of SafientMain contract |