UNPKG

@substrate/api-sidecar

Version:

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

64 lines 3.13 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 services_1 = require("../../services"); const AbstractController_1 = __importDefault(require("../AbstractController")); /** * Get version information of the Substrate runtime. * * Query: * - (Optional)`at`: Block at which to retrieve runtime version information. Block * identifier, as the block height or block hash. Defaults to most recent block. * * Returns: * - `at`: Block number and hash at which the call was made. * - `authoringVersion`: The version of the authorship interface. An authoring node * will not attempt to author blocks unless this is equal to its native runtime. * - `chainType`: Type of the chain. * - `implVersion`: Version of the implementation specification. Non-consensus-breaking * optimizations are about the only changes that could be made which would * result in only the `impl_version` changing. The `impl_version` is set to 0 * when `spec_version` is incremented. * - `specName`: Identifies the spec name for the current runtime. * - `specVersion`: Version of the runtime specification. * - `transactionVersion`: All existing dispatches are fully compatible when this * number doesn't change. This number must change when an existing dispatchable * (module ID, dispatch ID) is changed, either through an alteration in its * user-level semantics, a parameter added/removed/changed, a dispatchable * its index. * - `properties`: Arbitrary properties defined in the chain spec. */ class RuntimeSpecController extends AbstractController_1.default { constructor(api) { super(api, '/runtime/spec', new services_1.RuntimeSpecService(api)); this.getSpec = async ({ query: { at } }, res) => { const hash = await this.getHashFromAt(at); RuntimeSpecController.sanitizedSend(res, await this.service.fetchSpec(hash)); }; this.initRoutes(); } initRoutes() { this.safeMountAsyncGetHandlers([['', this.getSpec]]); } } RuntimeSpecController.controllerName = 'RuntimeSpec'; RuntimeSpecController.requiredPallets = []; exports.default = RuntimeSpecController; //# sourceMappingURL=RuntimeSpecController.js.map