libdocs/account_response.js

/* tslint:disable:variable-name */
import forIn from "lodash/forIn";
import { Account as BaseAccount } from "stellar-base";
/**
 * Do not create this object directly, use {@link Server#loadAccount}.
 *
 * Returns information and links relating to a single account.
 * The balances section in the returned JSON will also list all the trust lines this account has set up.
 * It also contains {@link Account} object and exposes it's methods so can be used in {@link TransactionBuilder}.
 *
 * @see [Account Details](https://developers.stellar.org/api/resources/accounts/object/)
 * @param {string} response Response from horizon account endpoint.
 * @returns {AccountResponse} AccountResponse instance
 */
export class AccountResponse {
    constructor(response) {
        this._baseAccount = new BaseAccount(response.account_id, response.sequence);
        // Extract response fields
        // TODO: do it in type-safe manner.
        forIn(response, (value, key) => {
            this[key] = value;
        });
    }
    /**
     * Get Stellar account public key ex. `GB3KJPLFUYN5VL6R3GU3EGCGVCKFDSD7BEDX42HWG5BWFKB3KQGJJRMA`
     * @returns {string} accountId
     */
    accountId() {
        return this._baseAccount.accountId();
    }
    /**
     * Get the current sequence number
     * @returns {string} sequenceNumber
     */
    sequenceNumber() {
        return this._baseAccount.sequenceNumber();
    }
    /**
     * Increments sequence number in this object by one.
     * @returns {void}
     */
    incrementSequenceNumber() {
        this._baseAccount.incrementSequenceNumber();
        this.sequence = this._baseAccount.sequenceNumber();
    }
}
//# sourceMappingURL=account_response.js.map