2022-09-21 10:41:36 -04:00
|
|
|
import { PaymentAccountForm, PaymentAccountFormField } from "../protobuf/pb_pb";
|
2022-05-04 21:30:48 -04:00
|
|
|
/**
|
|
|
|
* Collection of utilities for working with Haveno.
|
|
|
|
*/
|
|
|
|
export default class HavenoUtils {
|
|
|
|
static logLevel: number;
|
|
|
|
static months: string[];
|
|
|
|
static lastLogTimeMs: number;
|
2023-05-02 10:40:22 -04:00
|
|
|
static AU_PER_XMR: bigint;
|
2022-05-04 21:30:48 -04:00
|
|
|
/**
|
|
|
|
* Set the log level with 0 being least verbose.
|
|
|
|
*
|
|
|
|
* @param {int} level - the log level
|
|
|
|
*/
|
|
|
|
static setLogLevel(level: number): Promise<void>;
|
|
|
|
/**
|
|
|
|
* Get the log level.
|
|
|
|
*
|
|
|
|
* @return {int} the current log level
|
|
|
|
*/
|
|
|
|
static getLogLevel(): number;
|
|
|
|
/**
|
|
|
|
* Log a message. // TODO (woodser): switch to log library?
|
|
|
|
*
|
|
|
|
* @param {int} level - log level of the message
|
|
|
|
* @param {string} msg - message to log
|
|
|
|
*/
|
|
|
|
static log(level: number, msg: string): void;
|
|
|
|
/**
|
|
|
|
* Format a timestamp as e.g. Jul-07 hh:mm:ss:ms. // TODO: move to GenUtils?
|
|
|
|
*
|
|
|
|
* @param {number} timestamp - the timestamp in milliseconds to format
|
|
|
|
* @return {string} the formatted timestamp
|
|
|
|
*/
|
|
|
|
static formatTimestamp(timestamp: number): string;
|
|
|
|
/**
|
|
|
|
* Kill the given process.
|
|
|
|
*
|
2023-10-12 16:45:44 -04:00
|
|
|
* TODO (woodser): move this to monero-ts GenUtils.ts as common utility
|
2022-05-04 21:30:48 -04:00
|
|
|
*
|
|
|
|
* @param {Process} process - the nodejs child process to child
|
|
|
|
* @param {String} signal - the kill signal, e.g. SIGTERM, SIGKILL, SIGINT (default)
|
|
|
|
*/
|
|
|
|
static kill(process: any, signal?: string): Promise<void>;
|
2023-02-27 10:23:01 -05:00
|
|
|
/**
|
|
|
|
* Wait for the duration.
|
|
|
|
*
|
|
|
|
* @param {number} durationMs - the duration to wait for in milliseconds
|
|
|
|
*/
|
|
|
|
static waitFor(durationMs: number): Promise<unknown>;
|
2023-04-26 11:43:48 -04:00
|
|
|
/**
|
|
|
|
* Divide one bigint by another.
|
|
|
|
*
|
|
|
|
* @param {bigint} a dividend
|
|
|
|
* @param {bigint} b divisor
|
|
|
|
* @returns {number} the result
|
|
|
|
*/
|
|
|
|
static divideBI(a: bigint, b: bigint): number;
|
2023-09-15 09:13:48 -04:00
|
|
|
/**
|
|
|
|
* Calculate the difference from a first bigint to a second, as a percentage (float).
|
|
|
|
*
|
|
|
|
* @param {bigint} a first bigint to get the difference from
|
|
|
|
* @param {bigint} b second bigint to get the difference from
|
|
|
|
* @returns {number} the percentage difference as a float
|
|
|
|
*/
|
|
|
|
static percentageDiff(a: bigint, b: bigint): number;
|
|
|
|
/**
|
|
|
|
* Return the absolute value of the given bigint.
|
|
|
|
*
|
|
|
|
* @param {bigint} a the bigint to get the absolute value of
|
|
|
|
* @returns {bigint} the absolute value of the given bigint
|
|
|
|
*/
|
|
|
|
static abs(a: bigint): bigint;
|
2023-05-02 10:40:22 -04:00
|
|
|
/**
|
|
|
|
* Convert XMR to atomic units.
|
|
|
|
*
|
2023-10-02 08:16:54 -04:00
|
|
|
* @param {number | string} amountXmr - amount in XMR to convert to atomic units
|
|
|
|
* @return {bigint} amount in atomic units
|
2023-05-02 10:40:22 -04:00
|
|
|
*/
|
2023-05-30 18:08:04 -04:00
|
|
|
static xmrToAtomicUnits(amountXmr: number | string): bigint;
|
2023-05-02 10:40:22 -04:00
|
|
|
/**
|
|
|
|
* Convert atomic units to XMR.
|
|
|
|
*
|
2023-10-02 08:16:54 -04:00
|
|
|
* @param {bigint | string} amountAtomicUnits - amount in atomic units to convert to XMR
|
2023-05-02 10:40:22 -04:00
|
|
|
* @return {number} amount in XMR
|
|
|
|
*/
|
2023-10-02 08:16:54 -04:00
|
|
|
static atomicUnitsToXmr(amountAtomicUnits: bigint | string): number;
|
2023-09-15 09:13:48 -04:00
|
|
|
/**
|
|
|
|
* Get a validated payment method id from a string or form id.
|
|
|
|
*
|
|
|
|
* @param {string | PaymentAccountForm.FormId} id - identifies the payment method
|
|
|
|
* @returns {string} the payment method id
|
|
|
|
*/
|
|
|
|
static getPaymentMethodId(id: string | PaymentAccountForm.FormId): string;
|
|
|
|
/**
|
|
|
|
* Stringify a payment account form.
|
|
|
|
*
|
|
|
|
* @param form - form to stringify
|
|
|
|
* @return {string} the stringified form
|
|
|
|
*/
|
|
|
|
static formToString(form: PaymentAccountForm): string;
|
2023-11-02 06:21:46 -04:00
|
|
|
/**
|
|
|
|
* Determine if a form has a field.
|
|
|
|
*
|
|
|
|
* @param {PaymentAccountForm} form - form to check
|
|
|
|
* @param {PaymentAccountFormField.FieldId} fieldId - id of the field to check for
|
|
|
|
* @return {boolean} true if the form has the field, false otherwise
|
|
|
|
*/
|
|
|
|
static hasFormField(form: PaymentAccountForm, fieldId: PaymentAccountFormField.FieldId): boolean;
|
2023-09-15 09:13:48 -04:00
|
|
|
/**
|
|
|
|
* Get a form field value.
|
|
|
|
*
|
|
|
|
* @param {PaymentAccountForm} form - form to get the field value from
|
|
|
|
* @param {PaymentAccountFormField.FieldId} fieldId - id of the field to get the value from
|
|
|
|
* @return {string} the form field value
|
|
|
|
*/
|
|
|
|
static getFormValue(form: PaymentAccountForm, fieldId: PaymentAccountFormField.FieldId): string;
|
|
|
|
/**
|
|
|
|
* Set a form field value.
|
|
|
|
*
|
2023-11-02 06:21:46 -04:00
|
|
|
* @param {PaymentAccountForm} form - form to get the field from
|
2023-09-15 09:13:48 -04:00
|
|
|
* @param {PaymentAccountFormField.FieldId} fieldId - id of the field to set the value of
|
|
|
|
* @param {string} value - field value to set
|
|
|
|
* @return {string} the form field value
|
|
|
|
*/
|
2023-11-02 06:21:46 -04:00
|
|
|
static setFormValue(form: PaymentAccountForm, fieldId: PaymentAccountFormField.FieldId, value: string): void;
|
2022-05-04 21:30:48 -04:00
|
|
|
}
|