UNPKG

@substrate/api-sidecar

Version:

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

78 lines 3.66 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 apiRegistry_1 = require("../../../apiRegistry"); const services_1 = require("../../../services"); const AbstractController_1 = __importDefault(require("../../AbstractController")); /** * POST a serialized transaction to submit to the relay chain transaction queue. * * Post info: * - `data`: Expects a hex-encoded transaction, e.g. '{"tx": "0x..."}'. * - `headers`: Expects 'Content-Type: application/json'. * * Returns: * - Success: * - `hash`: The hash of the encoded transaction. * - Failure: * - `error`: 'Failed to parse transaction' or 'Failed to submit transaction'. In the case of the former, * Sidecar was unable to parse the transaction and never submitted it to the client. In * the case of the latter, the transaction queue rejected the transaction. * - `extrinsic`: The hex-encoded extrinsic. Only present if Sidecar fails to parse a transaction. * - `cause`: The error message from parsing or from the client. */ class RcTransactionSubmitController 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/transaction', new services_1.TransactionSubmitService(rcSpecName)); /** * Submit a serialized transaction to the transaction queue. * * @param req Sidecar TxRequest * @param res Express Response */ this.txSubmit = async ({ body: { tx } }, res) => { var _a; if (!tx) { throw { error: 'Missing field `tx` on request body.', }; } 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'); } res.send(await this.service.submitTransaction(rcApi, tx)); }; this.initRoutes(); } initRoutes() { this.router.post(this.path, RcTransactionSubmitController.catchWrap(this.txSubmit)); } } RcTransactionSubmitController.controllerName = 'RcTransactionSubmit'; RcTransactionSubmitController.requiredPallets = []; exports.default = RcTransactionSubmitController; //# sourceMappingURL=RcTransactionSubmitController.js.map