UNPKG

@substrate/api-sidecar

Version:

REST service that makes it easy to interact with blockchain nodes built using Substrate's FRAME framework.

113 lines 5.65 kB
"use strict"; // 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 middleware_1 = require("../../middleware"); const services_1 = require("../../services"); const AbstractController_1 = __importDefault(require("../AbstractController")); /** * GET asset information for a single pool asset. * * Paths: * - `assetId`: The identifier of the pool asset. * * Query: * - (Optional)`at`: Block at which to retrieve runtime version information at. Block * identifier, as the block height or block hash. Defaults to most recent block. * * `/pallets/pool-assets/:assetId/asset-info` * Returns: * - `at`: Block number and hash at which the call was made. * - `poolAssetInfo`: All details concering a pool asset. * - `owner`: Owner of the assets privileges. * - `issuer`: The `AccountId` able to mint tokens. * - `admin`: The `AccountId` can that thaw tokens, force transfers and burn token from * any account. * - `freezer`: The `AccountId` that can freeze tokens. * - `supply`: The total supply across accounts. * - `deposit`: The balance deposited for this. This pays for the data stored. * - `minBalance`: The ED for virtual accounts. * - `isSufficient`: If `true`, then any account with this asset is given a provider reference. Otherwise, it * requires a consumer reference. * - `accounts`: The total number of accounts. * - `sufficients`: The total number of accounts for which is placed a self-sufficient reference. * - `approvals`: The total number of approvals. * - `status`: The status of the asset. * - `poolAssetMetadata`: All metadata concerning a pool asset. * - `deposit`: The balance deposited for this metadata. This pays for the data * stored in this struct. * - `name`: The user friendly name of this pool asset. * - `symbol`: The ticker symbol for this pool asset. * - `decimals`: The number of decimals this pool asset uses to represent one unit. * - `isFrozen`: Whether the pool asset metadata may be changed by a non Force origin. * * Substrate References: * - PoolAssets Pallet: instance of Assets Pallet https://crates.parity.io/pallet_assets/index.html * - `AssetMetadata`: https://crates.parity.io/pallet_assets/struct.AssetMetadata.html * - `AssetDetails`: https://crates.parity.io/pallet_assets/struct.AssetDetails.html */ class PalletsPoolAssetsController extends AbstractController_1.default { constructor(api) { super(api, '/pallets/pool-assets/:assetId', new services_1.PalletsPoolAssetsService(api)); this.getPoolAssetById = async ({ params: { assetId }, query: { at, useRcBlock } }, res) => { /** * Verify our param `assetId` is an integer represented as a string, and return * it as an integer */ const index = this.parseNumberOrThrow(assetId, '`assetId` path param is not a number'); if (useRcBlock === 'true') { const rcAtResults = await this.getHashFromRcAt(at); // Return empty array if no Asset Hub blocks found if (rcAtResults.length === 0) { PalletsPoolAssetsController.sanitizedSend(res, []); return; } // Process each Asset Hub block found const results = []; for (const { ahHash, rcBlockHash, rcBlockNumber } of rcAtResults) { const result = await this.service.fetchPoolAssetById(ahHash, index); const apiAt = await this.api.at(ahHash); const ahTimestamp = await apiAt.query.timestamp.now(); const enhancedResult = { ...result, rcBlockHash: rcBlockHash.toString(), rcBlockNumber, ahTimestamp: ahTimestamp.toString(), }; results.push(enhancedResult); } PalletsPoolAssetsController.sanitizedSend(res, results); } else { const hash = await this.getHashFromAt(at); const result = await this.service.fetchPoolAssetById(hash, index); PalletsPoolAssetsController.sanitizedSend(res, result); } }; this.initRoutes(); } initRoutes() { this.router.use(this.path, middleware_1.validateUseRcBlock); this.safeMountAsyncGetHandlers([['/asset-info', this.getPoolAssetById]]); } } PalletsPoolAssetsController.controllerName = 'PalletsPoolAssets'; PalletsPoolAssetsController.requiredPallets = [['PoolAssets']]; exports.default = PalletsPoolAssetsController; //# sourceMappingURL=PalletsPoolAssetsController.js.map