@substrate/api-sidecar
Version:
REST service that makes it easy to interact with blockchain nodes built using Substrate's FRAME framework.
73 lines • 3.41 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 http_errors_1 = require("http-errors");
const services_1 = require("../../services");
const AbstractController_1 = __importDefault(require("../AbstractController"));
/**
* Dry run a transaction.
*
* Returns:
* - `at`:
* - `hash`: The block's hash.
* - `height`: The block's height.
* - `result`:
* - Successfull dry run:
* - `actualWeight`: The actual weight of the transaction.
* - `paysFee`: The fee to be paid.
* - Failed dry run:
* - error reason.
* - Dry run not possible to run:
* - `isUnimplemented`: The dry run is not implemented.
* - `isVersionedConversionFailed`: The versioned conversion failed.
* - `type`: 'Unimplemented' | 'VersionedConversionFailed';.
*
* References:
* - `DispatchError`: https://docs.rs/sp-runtime/39.0.1/sp_runtime/enum.DispatchError.html
* - `PostDispatchInfo`: https://docs.rs/frame-support/38.0.0/frame_support/dispatch/struct.PostDispatchInfo.html
* - `Error Type`: https://paritytech.github.io/polkadot-sdk/master/xcm_runtime_apis/dry_run/enum.Error.html
*
* Note: If you get the error `-32601: Method not found` it means that the node sidecar
* is connected to does not expose the `system_dryRun` RPC. One way to resolve this
* issue is to pass the `--rpc-external` flag to that node.
*/
class TransactionDryRunController extends AbstractController_1.default {
constructor(api) {
super(api, '/transaction/dry-run', new services_1.TransactionDryRunService(api));
this.dryRunTransaction = async ({ body: { tx, at, senderAddress, xcmVersion } }, res) => {
if (!tx) {
throw new http_errors_1.BadRequest('Missing field `tx` on request body.');
}
if (!senderAddress) {
throw new http_errors_1.BadRequest('Missing field `senderAddress` on request body.');
}
const hash = await this.getHashFromAt(at);
TransactionDryRunController.sanitizedSend(res, await this.service.dryRuntExtrinsic(this.api, senderAddress, tx, hash, xcmVersion));
};
this.initRoutes();
}
initRoutes() {
this.router.post(this.path, TransactionDryRunController.catchWrap(this.dryRunTransaction));
}
}
TransactionDryRunController.controllerName = 'TransactionDryRun';
TransactionDryRunController.requiredPallets = [];
exports.default = TransactionDryRunController;
//# sourceMappingURL=TransactionDryRunController.js.map