Human Protocol SDK
v3.0.1
v3.0.1
  • Typescript SDK
    • Encryption
      • Encryption
      • EncryptionUtils
    • Escrow
      • EscrowClient
      • EscrowUtils
    • KVStore
      • KVStoreClient
      • KVStoreUtils
    • Staking
      • StakingClient
    • Operator
      • OperatorUtils
    • Storage
      • StorageClient
    • Statistics
      • StatisticsClient
    • Transaction
      • TransactionUtils
  • Python SDK
    • agreement
      • bootstrap
      • measures
      • utils
    • encryption
      • encryption
      • legacy_encryption
      • encryption_utils
    • escrow
      • escrow_client
      • escrow_utils
    • kvstore
      • kvstore_client
      • kvstore_utils
    • staking
      • staking_client
      • staking_utils
    • operator
      • operator_utils
    • statistics
      • statistics_client
    • storage
      • storage_client
      • storage_utils
    • transaction
      • transaction_utils
    • constants
    • filter
    • utils
  • CHANGELOG
Powered by GitBook
On this page
  • Class: StatisticsClient
  • Introduction
  • Installation
  • Code example
  • Constructors
  • Properties
  • Methods
  1. Typescript SDK
  2. Statistics

StatisticsClient

Last updated 10 months ago

• Docs


/ / StatisticsClient

Class: StatisticsClient

Introduction

This client enables to obtain statistical information from the subgraph.

Unlikely from the other SDK clients, StatisticsClient does not require signer or provider to be provided. We just need to create client object using relevant network data.

constructor(network: NetworkData)

A Signer or a Provider should be passed depending on the use case of this module:

  • Signer: when the user wants to use this model in order to send transactions caling the contract functions.

  • Provider: when the user wants to use this model in order to get information from the contracts or subgraph.

Installation

npm

npm install @human-protocol/sdk

yarn

yarn install @human-protocol/sdk

Code example

import { StatisticsClient, ChainId, NETWORKS } from '@human-protocol/sdk';

const statisticsClient = new StatisticsClient(NETWORKS[ChainId.POLYGON_AMOY]);

Constructors

new StatisticsClient()

StatisticsClient constructor

Parameters

• networkData: NetworkData

The network information required to connect to the Statistics contract

Returns

Defined in

Properties

networkData

networkData: NetworkData

Defined in


subgraphUrl

subgraphUrl: string

Defined in

Methods

getEscrowStatistics()

getEscrowStatistics(params): Promise<EscrowStatistics>

This function returns the statistical data of escrows.

Input parameters

interface IStatisticsParams {
  from?: Date;
  to?: Date;
  limit?: number;
}
type DailyEscrowsData = {
  timestamp: Date;
  escrowsTotal: number;
  escrowsPending: number;
  escrowsSolved: number;
  escrowsPaid: number;
  escrowsCancelled: number;
};

type EscrowStatistics = {
  totalEscrows: number;
  dailyEscrowsData: DailyEscrowsData[];
};

Parameters

• params: IStatisticsParams = {}

Statistics params with duration data

Returns

Promise<EscrowStatistics>

Escrow statistics data.

Code example

import { StatisticsClient, ChainId, NETWORKS } from '@human-protocol/sdk';

const statisticsClient = new StatisticsClient(NETWORKS[ChainId.POLYGON_AMOY]);

const escrowStatistics = await statisticsClient.getEscrowStatistics();
const escrowStatisticsApril = await statisticsClient.getEscrowStatistics({
   from: new Date('2021-04-01'),
   to: new Date('2021-04-30'),
});

Defined in


getHMTHolders()

getHMTHolders(params): Promise<HMTHolder[]>

This function returns the holders of the HMToken with optional filters and ordering.

Input parameters

Parameters

• params: IHMTHoldersParams = {}

HMT Holders params with filters and ordering

Returns

Promise<HMTHolder[]>

List of HMToken holders.

Code example

import { StatisticsClient, ChainId, NETWORKS } from '@human-protocol/sdk';

const statisticsClient = new StatisticsClient(NETWORKS[ChainId.POLYGON_AMOY]);

const hmtHolders = await statisticsClient.getHMTHolders({
  orderDirection: 'asc',
});

console.log('HMT holders:', hmtHolders.map((h) => ({
  ...h,
  balance: h.balance.toString(),
})));

Defined in


getHMTStatistics()

getHMTStatistics(params): Promise<HMTStatistics>

This function returns the statistical data of HMToken.

Input parameters

interface IStatisticsParams {
  from?: Date;
  to?: Date;
  limit?: number;
}
type HMTHolder = {
  address: string;
  balance: BigNumber;
}

type DailyHMTData = {
  timestamp: Date;
  totalTransactionAmount: BigNumber;
  totalTransactionCount: number;
};

type HMTStatistics = {
  totalTransferAmount: BigNumber;
  totalTransferCount: BigNumber;
  totalHolders: number;
  holders: HMTHolder[];
  dailyHMTData: DailyHMTData[];
};

Parameters

• params: IStatisticsParams = {}

Statistics params with duration data

Returns

Promise<HMTStatistics>

HMToken statistics data.

Code example

import { StatisticsClient, ChainId, NETWORKS } from '@human-protocol/sdk';

const statisticsClient = new StatisticsClient(NETWORKS[ChainId.POLYGON_AMOY]);

const hmtStatistics = await statisticsClient.getHMTStatistics();

console.log('HMT statistics:', {
  ...hmtStatistics,
  totalTransferAmount: hmtStatistics.totalTransferAmount.toString(),
  holders: hmtStatistics.holders.map((h) => ({
    ...h,
    balance: h.balance.toString(),
  })),
  dailyHMTData: hmtStatistics.dailyHMTData.map((d) => ({
    ...d,
    totalTransactionAmount: d.totalTransactionAmount.toString(),
  })),
});

const hmtStatisticsRange = await statisticsClient.getHMTStatistics({
  from: new Date(2023, 4, 8),
  to: new Date(2023, 5, 8),
});

console.log('HMT statistics from 5/8 - 6/8:', {
  ...hmtStatisticsRange,
  totalTransferAmount: hmtStatisticsRange.totalTransferAmount.toString(),
  holders: hmtStatisticsRange.holders.map((h) => ({
    ...h,
    balance: h.balance.toString(),
  })),
  dailyHMTData: hmtStatisticsRange.dailyHMTData.map((d) => ({
    ...d,
    totalTransactionAmount: d.totalTransactionAmount.toString(),
  })),
});

Defined in


getPaymentStatistics()

getPaymentStatistics(params): Promise<PaymentStatistics>

This function returns the statistical data of payments.

Input parameters

interface IStatisticsParams {
  from?: Date;
  to?: Date;
  limit?: number;
}
type DailyPaymentData = {
  timestamp: Date;
  totalAmountPaid: BigNumber;
  totalCount: number;
  averageAmountPerWorker: BigNumber;
};

type PaymentStatistics = {
  dailyPaymentsData: DailyPaymentData[];
};

Parameters

• params: IStatisticsParams = {}

Statistics params with duration data

Returns

Promise<PaymentStatistics>

Payment statistics data.

Code example

import { StatisticsClient, ChainId, NETWORKS } from '@human-protocol/sdk';

const statisticsClient = new StatisticsClient(NETWORKS[ChainId.POLYGON_AMOY]);

console.log(
  'Payment statistics:',
  (await statisticsClient.getPaymentStatistics()).dailyPaymentsData.map(
    (p) => ({
      ...p,
      totalAmountPaid: p.totalAmountPaid.toString(),
      averageAmountPerJob: p.averageAmountPerJob.toString(),
      averageAmountPerWorker: p.averageAmountPerWorker.toString(),
    })
  )
);

console.log(
  'Payment statistics from 5/8 - 6/8:',
  (
    await statisticsClient.getPaymentStatistics({
      from: new Date(2023, 4, 8),
      to: new Date(2023, 5, 8),
    })
  ).dailyPaymentsData.map((p) => ({
    ...p,
    totalAmountPaid: p.totalAmountPaid.toString(),
    averageAmountPerJob: p.averageAmountPerJob.toString(),
    averageAmountPerWorker: p.averageAmountPerWorker.toString(),
  }))
);

Defined in


getWorkerStatistics()

getWorkerStatistics(params): Promise<WorkerStatistics>

This function returns the statistical data of workers.

Input parameters

interface IStatisticsParams {
  from?: Date;
  to?: Date;
  limit?: number;
}
type DailyWorkerData = {
  timestamp: Date;
  activeWorkers: number;
};

type WorkerStatistics = {
  dailyWorkersData: DailyWorkerData[];
};

Parameters

• params: IStatisticsParams = {}

Statistics params with duration data

Returns

Promise<WorkerStatistics>

Worker statistics data.

Code example

import { StatisticsClient, ChainId, NETWORKS } from '@human-protocol/sdk';

const statisticsClient = new StatisticsClient(NETWORKS[ChainId.POLYGON_AMOY]);

const workerStatistics = await statisticsClient.getWorkerStatistics();
const workerStatisticsApril = await statisticsClient.getWorkerStatistics({
   from: new Date('2021-04-01'),
   to: new Date('2021-04-30'),
});

Defined in

new StatisticsClient(networkData):

@human-protocol/sdk
@human-protocol/sdk
statistics
StatisticsClient
StatisticsClient
statistics.ts:70
statistics.ts:62
statistics.ts:63
statistics.ts:124
statistics.ts:466
statistics.ts:397
statistics.ts:288
statistics.ts:199