@substrate/api-sidecar
Version:
REST service that makes it easy to interact with blockchain nodes built using Substrate's FRAME framework.
113 lines • 6.16 kB
JavaScript
;
// Copyright 2017-2025 Parity Technologies (UK) Ltd.
// This file is part of Substrate API Sidecar.
//
// Substrate API Sidecar is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const apiRegistry_1 = require("../../../apiRegistry");
const middleware_1 = require("../../../middleware");
const services_1 = require("../../../services");
const AbstractController_1 = __importDefault(require("../../AbstractController"));
/**
* GET staking information for an address on the relay chain.
*
* Paths:
* - `address`: The _Stash_ address for staking.
*
* Query:
* - (Optional)`at`: Block at which to retrieve staking information at. Block
* identifier, as the block height or block hash. Defaults to most recent block.
* - (Optional) `includeClaimedRewards`: Controls whether or not the `claimedRewards`
* field is included in the response. Defaults to `true`.
* If set to `false`:
* - the field `claimedRewards` will be omitted from the response and
* - all internal calculations for claimed rewards in `AccountsStakingInfoService`
* will be skipped, potentially speeding up the response time.
*
* Returns:
* - `at`: Block number and hash at which the call was made.
* - `rewardDestination`: The account to which rewards will be paid. Can be 'Staked' (Stash
* account, adding to the amount at stake), 'Stash' (Stash address, not adding to the amount at
* stake), 'Controller' (Controller address), or 'Account(AccountId)' (address identified by AccountId).
* - `controller`: Controller address for the given Stash.
* - `numSlashingSpans`: Number of slashing spans on Stash account; `null` if provided address is
* not a Controller.
* - `staking`: The staking ledger. Empty object if provided address is not a Controller.
* - `stash`: The stash account whose balance is actually locked and at stake.
* - `total`: The total amount of the stash's balance that we are currently accounting for.
* Simply `active + unlocking`.
* - `active`: The total amount of the stash's balance that will be at stake in any forthcoming
* eras.
* - `unlocking`: Any balance that is becoming free, which may eventually be transferred out of
* the stash (assuming it doesn't get slashed first). Represented as an array of objects, each
* with an `era` at which `value` will be unlocked.
* - `claimedRewards`: Array of eras for which the stakers behind a validator have claimed
* rewards. Only updated for _validators._
*
* Note: Runtime versions of Kusama less than 1062 will either have `lastReward` in place of
* `claimedRewards`, or no field at all. This is related to changes in reward distribution. See:
* - Lazy Payouts: https://github.com/paritytech/substrate/pull/4474
* - Simple Payouts: https://github.com/paritytech/substrate/pull/5406
*
* Substrate Reference:
* - Staking Pallet: https://crates.parity.io/pallet_staking/index.html
* - `RewardDestination`: https://crates.parity.io/pallet_staking/enum.RewardDestination.html
* - `Bonded`: https://crates.parity.io/pallet_staking/struct.Bonded.html
* - `StakingLedger`: https://crates.parity.io/pallet_staking/struct.StakingLedger.html
*/
class RcAccountsStakingInfoController extends AbstractController_1.default {
constructor(_api) {
var _a;
const rcApiSpecName = (_a = apiRegistry_1.ApiPromiseRegistry.getSpecNameByType('relay')) === null || _a === void 0 ? void 0 : _a.values();
const rcSpecName = rcApiSpecName ? Array.from(rcApiSpecName)[0] : undefined;
if (!rcSpecName) {
throw new Error('Relay chain API spec name is not defined.');
}
super(rcSpecName, '/rc/accounts/:address/staking-info', new services_1.AccountsStakingInfoService(rcSpecName));
/**
* Get the latest account staking summary of `address` on the relay chain.
*
* @param req Express Request
* @param res Express Response
*/
this.getAccountStakingInfo = async ({ params: { address }, query: { at, includeClaimedRewards } }, res) => {
var _a;
const rcApi = (_a = apiRegistry_1.ApiPromiseRegistry.getApiByType('relay')[0]) === null || _a === void 0 ? void 0 : _a.api;
if (!rcApi) {
throw new Error('Relay chain API not found, please use SAS_SUBSTRATE_MULTI_CHAIN_URL env variable');
}
const includeClaimedRewardsArg = includeClaimedRewards !== 'false';
const hash = await this.getHashFromAt(at, { api: rcApi });
const result = await this.service.fetchAccountStakingInfo(hash, includeClaimedRewardsArg, address);
RcAccountsStakingInfoController.sanitizedSend(res, result);
};
this.initRoutes();
}
initRoutes() {
this.router.use(this.path, middleware_1.validateAddress, (0, middleware_1.validateBoolean)(['includeClaimedRewards']));
this.safeMountAsyncGetHandlers([['', this.getAccountStakingInfo]]);
}
}
RcAccountsStakingInfoController.controllerName = 'RcAccountsStakingInfo';
RcAccountsStakingInfoController.requiredPallets = [
['Staking', 'System'],
['ParachainStaking', 'ParachainSystem'],
['ParachainStaking', 'System'],
['Staking', 'ParachainSystem'],
];
exports.default = RcAccountsStakingInfoController;
//# sourceMappingURL=RcAccountsStakingInfoController.js.map