/// <reference types="node" />
/**
 * @file Misc steem type definitions.
 * @author Johan Nordberg <code@johan-nordberg.com>
 * @license
 * Copyright (c) 2017 Johan Nordberg. All Rights Reserved.
 *
 * Redistribution and use in source and binary forms, with or without modification,
 * are permitted provided that the following conditions are met:
 *
 *  1. Redistribution of source code must retain the above copyright notice, this
 *     list of conditions and the following disclaimer.
 *
 *  2. Redistribution in binary form must reproduce the above copyright notice,
 *     this list of conditions and the following disclaimer in the documentation
 *     and/or other materials provided with the distribution.
 *
 *  3. Neither the name of the copyright holder nor the names of its contributors
 *     may be used to endorse or promote products derived from this software without
 *     specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
 * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
 * OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 * You acknowledge that this software is not designed, licensed or intended for use
 * in the design, construction, operation or maintenance of any military facility.
 */
import { Account } from './account';
import { Asset, Price } from './asset';
/**
 * Large number that may be unsafe to represent natively in JavaScript.
 */
export declare type Bignum = string;
/**
 * Buffer wrapper that serializes to a hex-encoded string.
 */
export declare class HexBuffer {
    buffer: Buffer;
    constructor(buffer: Buffer);
    /**
     * Convenience to create a new HexBuffer, does not copy data if value passed is already a buffer.
     */
    static from(value: Buffer | HexBuffer | number[] | string): HexBuffer;
    toString(encoding?: string): string;
    toJSON(): string;
}
/**
 * Chain roperties that are decided by the witnesses.
 */
export interface ChainProperties {
    /**
     * This fee, paid in STEEM, is converted into VESTING SHARES for the new account. Accounts
     * without vesting shares cannot earn usage rations and therefore are powerless. This minimum
     * fee requires all accounts to have some kind of commitment to the network that includes the
     * ability to vote and make transactions.
     *
     * @note This has to be multiplied by STEEMIT ? `CREATE_ACCOUNT_WITH_STEEM_MODIFIER`
     *       (defined as 30 on the main chain) to get the minimum fee needed to create an account.
     *
     */
    account_creation_fee: string | Asset;
    /**
     * This witnesses vote for the maximum_block_size which is used by the network
     * to tune rate limiting and capacity.
     */
    maximum_block_size: number;
    /**
     * The SBD interest percentage rate decided by witnesses, expressed 0 to 10000.
     */
    sbd_interest_rate: number;
}
export interface VestingDelegation {
    /**
     * Delegation id.
     */
    id: number;
    /**
     * Account that is delegating vests to delegatee.
     */
    delegator: string;
    /**
     * Account that is receiving vests from delegator.
     */
    delegatee: string;
    /**
     * Amount of VESTS delegated.
     */
    vesting_shares: Asset | string;
    /**
     * Earliest date delegation can be removed.
     */
    min_delegation_time: string;
}
/**
 * Node state.
 */
export interface DynamicGlobalProperties {
    id: number;
    /**
     * Current block height.
     */
    head_block_number: number;
    head_block_id: string;
    /**
     * UTC Server time, e.g. 2020-01-15T00:42:00
     */
    time: string;
    /**
     * Currently elected witness.
     */
    current_witness: string;
    /**
     * The total POW accumulated, aka the sum of num_pow_witness at the time
     * new POW is added.
     */
    total_pow: number;
    /**
     * The current count of how many pending POW witnesses there are, determines
     * the difficulty of doing pow.
     */
    num_pow_witnesses: number;
    virtual_supply: Asset | string;
    current_supply: Asset | string;
    /**
     * Total asset held in confidential balances.
     */
    confidential_supply: Asset | string;
    current_sbd_supply: Asset | string;
    /**
     * Total asset held in confidential balances.
     */
    confidential_sbd_supply: Asset | string;
    total_vesting_fund_steem: Asset | string;
    total_vesting_shares: Asset | string;
    total_reward_fund_steem: Asset | string;
    /**
     * The running total of REWARD^2.
     */
    total_reward_shares2: string;
    pending_rewarded_vesting_shares: Asset | string;
    pending_rewarded_vesting_steem: Asset | string;
    /**
     * This property defines the interest rate that SBD deposits receive.
     */
    sbd_interest_rate: number;
    sbd_print_rate: number;
    /**
     *  Average block size is updated every block to be:
     *
     *     average_block_size = (99 * average_block_size + new_block_size) / 100
     *
     *  This property is used to update the current_reserve_ratio to maintain
     *  approximately 50% or less utilization of network capacity.
     */
    average_block_size: number;
    /**
     * Maximum block size is decided by the set of active witnesses which change every round.
     * Each witness posts what they think the maximum size should be as part of their witness
     * properties, the median size is chosen to be the maximum block size for the round.
     *
     * @note the minimum value for maximum_block_size is defined by the protocol to prevent the
     * network from getting stuck by witnesses attempting to set this too low.
     */
    maximum_block_size: number;
    /**
     * The current absolute slot number. Equal to the total
     * number of slots since genesis. Also equal to the total
     * number of missed slots plus head_block_number.
     */
    current_aslot: number;
    /**
     * Used to compute witness participation.
     */
    recent_slots_filled: Bignum;
    participation_count: number;
    last_irreversible_block_num: number;
    /**
     * The maximum bandwidth the blockchain can support is:
     *
     *    max_bandwidth = maximum_block_size * BANDWIDTH_AVERAGE_WINDOW_SECONDS / BLOCK_INTERVAL
     *
     * The maximum virtual bandwidth is:
     *
     *    max_bandwidth * current_reserve_ratio
     */
    max_virtual_bandwidth: Bignum;
    /**
     * Any time average_block_size <= 50% maximum_block_size this value grows by 1 until it
     * reaches MAX_RESERVE_RATIO.  Any time average_block_size is greater than
     * 50% it falls by 1%.  Upward adjustments happen once per round, downward adjustments
     * happen every block.
     */
    current_reserve_ratio: number;
    /**
     * The number of votes regenerated per day.  Any user voting slower than this rate will be
     * "wasting" voting power through spillover; any user voting faster than this rate will have
     * their votes reduced.
     */
    vote_power_reserve_rate: number;
}
/**
 * Return the vesting share price.
 */
export declare function getVestingSharePrice(props: DynamicGlobalProperties): Price;
/**
 * Returns the vests of specified account. Default: Subtract delegated & add received
 */
export declare function getVests(account: Account, subtract_delegated?: boolean, add_received?: boolean): number;
