@hiero-ledger/sdk
Version:
239 lines (213 loc) • 6.53 kB
JavaScript
// SPDX-License-Identifier: Apache-2.0
import Query, { QUERY_REGISTRY } from "../query/Query.js";
import AccountId from "./AccountId.js";
import ContractId from "../contract/ContractId.js";
import AccountBalance from "./AccountBalance.js";
/**
* @namespace proto
* @typedef {import("@hiero-ledger/proto").proto.IQuery} HieroProto.proto.IQuery
* @typedef {import("@hiero-ledger/proto").proto.IQueryHeader} HieroProto.proto.IQueryHeader
* @typedef {import("@hiero-ledger/proto").proto.IResponse} HieroProto.proto.IResponse
* @typedef {import("@hiero-ledger/proto").proto.IResponseHeader} HieroProto.proto.IResponseHeader
* @typedef {import("@hiero-ledger/proto").proto.ICryptoGetAccountBalanceQuery} HieroProto.proto.ICryptoGetAccountBalanceQuery
* @typedef {import("@hiero-ledger/proto").proto.ICryptoGetAccountBalanceResponse} HieroProto.proto.ICryptoGetAccountBalanceResponse
*/
/**
* @typedef {import("../channel/Channel.js").default} Channel
* @typedef {import("../client/Client.js").default<*, *>} Client
*/
/**
* Get the balance of a Hedera™ crypto-currency account.
*
* This returns only the balance, so its a smaller and faster reply
* than AccountInfoQuery.
*
* This query is free.
*
* @augments {Query<AccountBalance>}
*/
export default class AccountBalanceQuery extends Query {
/**
* @param {object} [props]
* @param {AccountId | string} [props.accountId]
* @param {ContractId | string} [props.contractId]
*/
constructor(props = {}) {
super();
/**
* @type {?AccountId}
* @private
*/
this._accountId = null;
/**
* @type {?ContractId}
* @private
*/
this._contractId = null;
if (props.accountId != null) {
this.setAccountId(props.accountId);
}
if (props.contractId != null) {
this.setContractId(props.contractId);
}
}
/**
* @internal
* @param {HieroProto.proto.IQuery} query
* @returns {AccountBalanceQuery}
*/
static _fromProtobuf(query) {
const balance =
/** @type {HieroProto.proto.ICryptoGetAccountBalanceQuery} */ (
query.cryptogetAccountBalance
);
return new AccountBalanceQuery({
accountId:
balance.accountID != null
? AccountId._fromProtobuf(balance.accountID)
: undefined,
contractId:
balance.contractID != null
? ContractId._fromProtobuf(balance.contractID)
: undefined,
});
}
/**
* @returns {?AccountId}
*/
get accountId() {
return this._accountId;
}
/**
* Set the account ID for which the balance is being requested.
*
* This is mutually exclusive with `setContractId`.
*
* @param {AccountId | string} accountId
* @returns {this}
*/
setAccountId(accountId) {
this._accountId =
typeof accountId === "string"
? AccountId.fromString(accountId)
: accountId.clone();
return this;
}
/**
* @returns {?ContractId}
*/
get contractId() {
return this._contractId;
}
/**
* Set the contract ID for which the balance is being requested.
*
* This is mutually exclusive with `setAccountId`.
*
* @param {ContractId | string} contractId
* @returns {this}
*/
setContractId(contractId) {
this._contractId =
typeof contractId === "string"
? ContractId.fromString(contractId)
: contractId.clone();
return this;
}
/**
* @protected
* @override
* @returns {boolean}
*/
_isPaymentRequired() {
return false;
}
/**
* @param {Client} client
*/
_validateChecksums(client) {
if (this._accountId != null) {
this._accountId.validateChecksum(client);
}
if (this._contractId != null) {
this._contractId.validateChecksum(client);
}
}
/**
* @override
* @internal
* @param {Channel} channel
* @param {HieroProto.proto.IQuery} request
* @returns {Promise<HieroProto.proto.IResponse>}
*/
_execute(channel, request) {
return channel.crypto.cryptoGetBalance(request);
}
/**
* @override
* @override
* @internal
* @param {HieroProto.proto.IResponse} response
* @returns {HieroProto.proto.IResponseHeader}
*/
_mapResponseHeader(response) {
const cryptogetAccountBalance =
/** @type {HieroProto.proto.ICryptoGetAccountBalanceResponse} */ (
response.cryptogetAccountBalance
);
return /** @type {HieroProto.proto.IResponseHeader} */ (
cryptogetAccountBalance.header
);
}
/**
* @override
* @override
* @internal
* @param {HieroProto.proto.IResponse} response
* @param {AccountId} nodeAccountId
* @param {HieroProto.proto.IQuery} request
* @returns {Promise<AccountBalance>}
*/
// eslint-disable-next-line @typescript-eslint/no-unused-vars
_mapResponse(response, nodeAccountId, request) {
const cryptogetAccountBalance =
/** @type {HieroProto.proto.ICryptoGetAccountBalanceResponse} */ (
response.cryptogetAccountBalance
);
return Promise.resolve(
AccountBalance._fromProtobuf(cryptogetAccountBalance),
);
}
/**
* @override
* @internal
* @param {HieroProto.proto.IQueryHeader} header
* @returns {HieroProto.proto.IQuery}
*/
_onMakeRequest(header) {
return {
cryptogetAccountBalance: {
header,
accountID:
this._accountId != null
? this._accountId._toProtobuf()
: null,
contractID:
this._contractId != null
? this._contractId._toProtobuf()
: null,
},
};
}
/**
* @returns {string}
*/
_getLogId() {
return `AccountBalanceQuery:${this._timestamp.toString()}`;
}
}
QUERY_REGISTRY.set(
"cryptogetAccountBalance",
// eslint-disable-next-line @typescript-eslint/unbound-method
AccountBalanceQuery._fromProtobuf,
);