@substrate/api-sidecar 20.2.2 → 20.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +9 -0
- package/build/package.json +25 -13
- package/build/src/SidecarConfig.js +1 -0
- package/build/src/SidecarConfig.js.map +1 -1
- package/build/src/Specs.js +10 -0
- package/build/src/Specs.js.map +1 -1
- package/build/src/apiRegistry/index.d.ts +28 -0
- package/build/src/apiRegistry/index.js +133 -0
- package/build/src/apiRegistry/index.js.map +1 -0
- package/build/src/chains-config/assetHubWestendControllers.js +8 -1
- package/build/src/chains-config/assetHubWestendControllers.js.map +1 -1
- package/build/src/chains-config/index.d.ts +5 -5
- package/build/src/chains-config/index.js +18 -13
- package/build/src/chains-config/index.js.map +1 -1
- package/build/src/chains-config/polymeshControllers.js +10 -1
- package/build/src/chains-config/polymeshControllers.js.map +1 -1
- package/build/src/controllers/AbstractController.d.ts +6 -2
- package/build/src/controllers/AbstractController.js +16 -2
- package/build/src/controllers/AbstractController.js.map +1 -1
- package/build/src/controllers/AbstractControllers.spec.js +16 -5
- package/build/src/controllers/AbstractControllers.spec.js.map +1 -1
- package/build/src/controllers/accounts/AccountsAssetsController.d.ts +1 -2
- package/build/src/controllers/accounts/AccountsAssetsController.js.map +1 -1
- package/build/src/controllers/accounts/AccountsBalanceInfoController.d.ts +1 -2
- package/build/src/controllers/accounts/AccountsBalanceInfoController.js.map +1 -1
- package/build/src/controllers/accounts/AccountsCompareController.d.ts +1 -2
- package/build/src/controllers/accounts/AccountsCompareController.js.map +1 -1
- package/build/src/controllers/accounts/AccountsConvertController.d.ts +1 -2
- package/build/src/controllers/accounts/AccountsConvertController.js.map +1 -1
- package/build/src/controllers/accounts/AccountsPoolAssetsController.d.ts +1 -2
- package/build/src/controllers/accounts/AccountsPoolAssetsController.js.map +1 -1
- package/build/src/controllers/accounts/AccountsProxyInfoController.d.ts +1 -2
- package/build/src/controllers/accounts/AccountsProxyInfoController.js.map +1 -1
- package/build/src/controllers/accounts/AccountsStakingInfoController.d.ts +3 -2
- package/build/src/controllers/accounts/AccountsStakingInfoController.js +10 -2
- package/build/src/controllers/accounts/AccountsStakingInfoController.js.map +1 -1
- package/build/src/controllers/accounts/AccountsStakingPayoutsController.d.ts +4 -2
- package/build/src/controllers/accounts/AccountsStakingPayoutsController.js +55 -67
- package/build/src/controllers/accounts/AccountsStakingPayoutsController.js.map +1 -1
- package/build/src/controllers/accounts/AccountsValidateController.d.ts +1 -2
- package/build/src/controllers/accounts/AccountsValidateController.js.map +1 -1
- package/build/src/controllers/accounts/AccountsVestingInfoController.d.ts +1 -2
- package/build/src/controllers/accounts/AccountsVestingInfoController.js +6 -1
- package/build/src/controllers/accounts/AccountsVestingInfoController.js.map +1 -1
- package/build/src/controllers/blocks/BlocksController.d.ts +1 -2
- package/build/src/controllers/blocks/BlocksController.js.map +1 -1
- package/build/src/controllers/blocks/BlocksExtrinsicsController.d.ts +1 -2
- package/build/src/controllers/blocks/BlocksExtrinsicsController.js.map +1 -1
- package/build/src/controllers/blocks/BlocksRawExtrinsicsController.d.ts +1 -2
- package/build/src/controllers/blocks/BlocksRawExtrinsicsController.js.map +1 -1
- package/build/src/controllers/blocks/BlocksTraceController.d.ts +1 -2
- package/build/src/controllers/blocks/BlocksTraceController.js.map +1 -1
- package/build/src/controllers/contracts/ContractsInkController.d.ts +1 -2
- package/build/src/controllers/contracts/ContractsInkController.js +1 -2
- package/build/src/controllers/contracts/ContractsInkController.js.map +1 -1
- package/build/src/controllers/controllerInjection.spec.js +8 -6
- package/build/src/controllers/controllerInjection.spec.js.map +1 -1
- package/build/src/controllers/coretime/CoretimeChainController.d.ts +1 -2
- package/build/src/controllers/coretime/CoretimeChainController.js.map +1 -1
- package/build/src/controllers/coretime/CoretimeGenericController.d.ts +1 -2
- package/build/src/controllers/coretime/CoretimeGenericController.js.map +1 -1
- package/build/src/controllers/node/NodeNetworkController.d.ts +1 -2
- package/build/src/controllers/node/NodeNetworkController.js.map +1 -1
- package/build/src/controllers/node/NodeTransactionPoolController.d.ts +1 -2
- package/build/src/controllers/node/NodeTransactionPoolController.js.map +1 -1
- package/build/src/controllers/node/NodeVersionController.d.ts +1 -2
- package/build/src/controllers/node/NodeVersionController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsAssetConversionController.d.ts +1 -2
- package/build/src/controllers/pallets/PalletsAssetConversionController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsAssetsController.d.ts +1 -2
- package/build/src/controllers/pallets/PalletsAssetsController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsConstsController.d.ts +1 -2
- package/build/src/controllers/pallets/PalletsConstsController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsDispatchablesController.d.ts +1 -2
- package/build/src/controllers/pallets/PalletsDispatchablesController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsErrorsController.d.ts +1 -2
- package/build/src/controllers/pallets/PalletsErrorsController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsEventsController.d.ts +1 -2
- package/build/src/controllers/pallets/PalletsEventsController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsForeignAssetsController.d.ts +1 -2
- package/build/src/controllers/pallets/PalletsForeignAssetsController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsNominationPoolsController.d.ts +1 -2
- package/build/src/controllers/pallets/PalletsNominationPoolsController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsOnGoingReferendaController.d.ts +1 -2
- package/build/src/controllers/pallets/PalletsOnGoingReferendaController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsPoolAssetsController.d.ts +1 -2
- package/build/src/controllers/pallets/PalletsPoolAssetsController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsStakingProgressController.d.ts +2 -3
- package/build/src/controllers/pallets/PalletsStakingProgressController.js +6 -1
- package/build/src/controllers/pallets/PalletsStakingProgressController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsStakingValidatorsController.d.ts +1 -2
- package/build/src/controllers/pallets/PalletsStakingValidatorsController.js.map +1 -1
- package/build/src/controllers/pallets/PalletsStorageController.d.ts +1 -2
- package/build/src/controllers/pallets/PalletsStorageController.js.map +1 -1
- package/build/src/controllers/paras/ParasController.d.ts +1 -2
- package/build/src/controllers/paras/ParasController.js.map +1 -1
- package/build/src/controllers/runtime/RuntimeCodeController.d.ts +1 -2
- package/build/src/controllers/runtime/RuntimeCodeController.js.map +1 -1
- package/build/src/controllers/runtime/RuntimeMetadataController.d.ts +1 -2
- package/build/src/controllers/runtime/RuntimeMetadataController.js +2 -2
- package/build/src/controllers/runtime/RuntimeMetadataController.js.map +1 -1
- package/build/src/controllers/runtime/RuntimeSpecController.d.ts +1 -2
- package/build/src/controllers/runtime/RuntimeSpecController.js.map +1 -1
- package/build/src/controllers/transaction/TransactionDryRunController.d.ts +1 -2
- package/build/src/controllers/transaction/TransactionDryRunController.js +3 -3
- package/build/src/controllers/transaction/TransactionDryRunController.js.map +1 -1
- package/build/src/controllers/transaction/TransactionFeeEstimateController.d.ts +1 -2
- package/build/src/controllers/transaction/TransactionFeeEstimateController.js.map +1 -1
- package/build/src/controllers/transaction/TransactionMaterialController.d.ts +1 -2
- package/build/src/controllers/transaction/TransactionMaterialController.js.map +1 -1
- package/build/src/controllers/transaction/TransactionSubmitController.d.ts +1 -2
- package/build/src/controllers/transaction/TransactionSubmitController.js.map +1 -1
- package/build/src/main.js +62 -23
- package/build/src/main.js.map +1 -1
- package/build/src/services/AHM.spec.d.ts +0 -0
- package/build/src/services/AHM.spec.js +5 -0
- package/build/src/services/AHM.spec.js.map +1 -0
- package/build/src/services/AbstractPalletsService.d.ts +2 -2
- package/build/src/services/AbstractPalletsService.js.map +1 -1
- package/build/src/services/AbstractService.d.ts +6 -2
- package/build/src/services/AbstractService.js +16 -2
- package/build/src/services/AbstractService.js.map +1 -1
- package/build/src/services/AbstractService.spec.js +7 -1
- package/build/src/services/AbstractService.spec.js.map +1 -1
- package/build/src/services/accounts/AccountsAssetsService.spec.js +7 -1
- package/build/src/services/accounts/AccountsAssetsService.spec.js.map +1 -1
- package/build/src/services/accounts/AccountsBalanceInfoService.spec.js +19 -4
- package/build/src/services/accounts/AccountsBalanceInfoService.spec.js.map +1 -1
- package/build/src/services/accounts/AccountsCompareService.js +1 -1
- package/build/src/services/accounts/AccountsCompareService.js.map +1 -1
- package/build/src/services/accounts/AccountsCompareService.spec.js +7 -1
- package/build/src/services/accounts/AccountsCompareService.spec.js.map +1 -1
- package/build/src/services/accounts/AccountsConvertService.spec.js +5 -1
- package/build/src/services/accounts/AccountsConvertService.spec.js.map +1 -1
- package/build/src/services/accounts/AccountsPoolAssetsService.spec.js +5 -1
- package/build/src/services/accounts/AccountsPoolAssetsService.spec.js.map +1 -1
- package/build/src/services/accounts/AccountsProxyInfoService.spec.js +7 -1
- package/build/src/services/accounts/AccountsProxyInfoService.spec.js.map +1 -1
- package/build/src/services/accounts/AccountsStakingInfoService.d.ts +45 -2
- package/build/src/services/accounts/AccountsStakingInfoService.js +138 -3
- package/build/src/services/accounts/AccountsStakingInfoService.js.map +1 -1
- package/build/src/services/accounts/AccountsStakingInfoService.spec.js +339 -5
- package/build/src/services/accounts/AccountsStakingInfoService.spec.js.map +1 -1
- package/build/src/services/accounts/AccountsStakingPayoutsService.js +7 -4
- package/build/src/services/accounts/AccountsStakingPayoutsService.js.map +1 -1
- package/build/src/services/accounts/AccountsStakingPayoutsService.spec.js +339 -23
- package/build/src/services/accounts/AccountsStakingPayoutsService.spec.js.map +1 -1
- package/build/src/services/accounts/AccountsValidateService.spec.js +7 -1
- package/build/src/services/accounts/AccountsValidateService.spec.js.map +1 -1
- package/build/src/services/accounts/AccountsVestingInfoService.spec.js +7 -1
- package/build/src/services/accounts/AccountsVestingInfoService.spec.js.map +1 -1
- package/build/src/services/blocks/BlocksService.d.ts +1 -2
- package/build/src/services/blocks/BlocksService.js +1 -2
- package/build/src/services/blocks/BlocksService.js.map +1 -1
- package/build/src/services/blocks/BlocksService.spec.js +19 -6
- package/build/src/services/blocks/BlocksService.spec.js.map +1 -1
- package/build/src/services/blocks/BlocksTraceService.js +7 -5
- package/build/src/services/blocks/BlocksTraceService.js.map +1 -1
- package/build/src/services/blocks/BlocksTraceService.spec.js +3 -1
- package/build/src/services/blocks/BlocksTraceService.spec.js.map +1 -1
- package/build/src/services/contracts/ContractsInkService.spec.js +5 -1
- package/build/src/services/contracts/ContractsInkService.spec.js.map +1 -1
- package/build/src/services/coretime/CoretimeService.js.map +1 -1
- package/build/src/services/coretime/CoretimeService.spec.js +39 -2
- package/build/src/services/coretime/CoretimeService.spec.js.map +1 -1
- package/build/src/services/node/NodeNetworkService.js +6 -5
- package/build/src/services/node/NodeNetworkService.js.map +1 -1
- package/build/src/services/node/NodeNetworkService.spec.js +5 -1
- package/build/src/services/node/NodeNetworkService.spec.js.map +1 -1
- package/build/src/services/node/NodeTransactionPoolService.spec.js +5 -1
- package/build/src/services/node/NodeTransactionPoolService.spec.js.map +1 -1
- package/build/src/services/node/NodeVersionService.js +4 -3
- package/build/src/services/node/NodeVersionService.js.map +1 -1
- package/build/src/services/node/NodeVersionService.spec.js +3 -1
- package/build/src/services/node/NodeVersionService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsAssetConversionService.d.ts +1 -2
- package/build/src/services/pallets/PalletsAssetConversionService.js.map +1 -1
- package/build/src/services/pallets/PalletsAssetConversionService.spec.js +7 -1
- package/build/src/services/pallets/PalletsAssetConversionService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsAssetsService.d.ts +1 -2
- package/build/src/services/pallets/PalletsAssetsService.js.map +1 -1
- package/build/src/services/pallets/PalletsAssetsService.spec.js +5 -1
- package/build/src/services/pallets/PalletsAssetsService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsConstantsService.js +4 -2
- package/build/src/services/pallets/PalletsConstantsService.js.map +1 -1
- package/build/src/services/pallets/PalletsConstantsService.spec.js +5 -1
- package/build/src/services/pallets/PalletsConstantsService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsDispatchablesService.js +5 -3
- package/build/src/services/pallets/PalletsDispatchablesService.js.map +1 -1
- package/build/src/services/pallets/PalletsDispatchablesService.spec.js +5 -1
- package/build/src/services/pallets/PalletsDispatchablesService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsErrorsService.js +4 -2
- package/build/src/services/pallets/PalletsErrorsService.js.map +1 -1
- package/build/src/services/pallets/PalletsErrorsService.spec.js +5 -1
- package/build/src/services/pallets/PalletsErrorsService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsEventsService.js +4 -2
- package/build/src/services/pallets/PalletsEventsService.js.map +1 -1
- package/build/src/services/pallets/PalletsEventsService.spec.js +5 -1
- package/build/src/services/pallets/PalletsEventsService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsForeignAssetsService.d.ts +1 -2
- package/build/src/services/pallets/PalletsForeignAssetsService.js.map +1 -1
- package/build/src/services/pallets/PalletsForeignAssetsService.spec.js +5 -2
- package/build/src/services/pallets/PalletsForeignAssetsService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsNominationPoolsService.d.ts +1 -2
- package/build/src/services/pallets/PalletsNominationPoolsService.js.map +1 -1
- package/build/src/services/pallets/PalletsNominationPoolsService.spec.js +5 -1
- package/build/src/services/pallets/PalletsNominationPoolsService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsOnGoingReferendaService.spec.js +5 -2
- package/build/src/services/pallets/PalletsOnGoingReferendaService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsPoolAssetsService.d.ts +1 -2
- package/build/src/services/pallets/PalletsPoolAssetsService.js.map +1 -1
- package/build/src/services/pallets/PalletsPoolAssetsService.spec.js +5 -1
- package/build/src/services/pallets/PalletsPoolAssetsService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsStakingProgressService.js +51 -15
- package/build/src/services/pallets/PalletsStakingProgressService.js.map +1 -1
- package/build/src/services/pallets/PalletsStakingProgressService.spec.js +315 -10
- package/build/src/services/pallets/PalletsStakingProgressService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsStakingValidatorsService.d.ts +7 -0
- package/build/src/services/pallets/PalletsStakingValidatorsService.js +35 -6
- package/build/src/services/pallets/PalletsStakingValidatorsService.js.map +1 -1
- package/build/src/services/pallets/PalletsStakingValidatorsService.spec.js +96 -2
- package/build/src/services/pallets/PalletsStakingValidatorsService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsStorageService.js +4 -2
- package/build/src/services/pallets/PalletsStorageService.js.map +1 -1
- package/build/src/services/pallets/PalletsStorageService.spec.js +5 -1
- package/build/src/services/pallets/PalletsStorageService.spec.js.map +1 -1
- package/build/src/services/paras/ParasService.js +5 -5
- package/build/src/services/paras/ParasService.js.map +1 -1
- package/build/src/services/paras/ParasService.spec.js +7 -1
- package/build/src/services/paras/ParasService.spec.js.map +1 -1
- package/build/src/services/runtime/RuntimeCodeService.spec.js +5 -1
- package/build/src/services/runtime/RuntimeCodeService.spec.js.map +1 -1
- package/build/src/services/runtime/RuntimeMetadataService.js.map +1 -1
- package/build/src/services/runtime/RuntimeMetadataService.spec.js +5 -3
- package/build/src/services/runtime/RuntimeMetadataService.spec.js.map +1 -1
- package/build/src/services/runtime/RuntimeSpecService.js +5 -4
- package/build/src/services/runtime/RuntimeSpecService.js.map +1 -1
- package/build/src/services/runtime/RuntimeSpecService.spec.js +5 -1
- package/build/src/services/runtime/RuntimeSpecService.spec.js.map +1 -1
- package/build/src/services/transaction/TransactionDryRunService.d.ts +1 -1
- package/build/src/services/transaction/TransactionDryRunService.js +30 -2
- package/build/src/services/transaction/TransactionDryRunService.js.map +1 -1
- package/build/src/services/transaction/TransactionDryRunService.spec.js +47 -10
- package/build/src/services/transaction/TransactionDryRunService.spec.js.map +1 -1
- package/build/src/services/transaction/TransactionFeeEstimateService.spec.js +7 -2
- package/build/src/services/transaction/TransactionFeeEstimateService.spec.js.map +1 -1
- package/build/src/services/transaction/TransactionMaterialService.spec.js +9 -3
- package/build/src/services/transaction/TransactionMaterialService.spec.js.map +1 -1
- package/build/src/services/transaction/TransactionSubmitService.spec.js +7 -1
- package/build/src/services/transaction/TransactionSubmitService.spec.js.map +1 -1
- package/build/src/types/requests.d.ts +1 -0
- package/build/src/types/responses/PalletConstantsItem.d.ts +2 -2
- package/build/src/types/sidecar-config/CONFIG.d.ts +1 -0
- package/build/src/types/sidecar-config/CONFIG.js +1 -0
- package/build/src/types/sidecar-config/CONFIG.js.map +1 -1
- package/build/src/types/sidecar-config/SidecarConfig.d.ts +4 -0
- package/build/src/util/MultiKeyBiMap.d.ts +8 -0
- package/build/src/util/MultiKeyBiMap.js +42 -0
- package/build/src/util/MultiKeyBiMap.js.map +1 -0
- package/package.json +25 -13
|
@@ -18,12 +18,16 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
18
18
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
19
19
|
};
|
|
20
20
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
21
|
+
const apiRegistry_1 = require("../../apiRegistry");
|
|
21
22
|
const sanitizeNumbers_1 = require("../../sanitize/sanitizeNumbers");
|
|
22
23
|
const mock_1 = require("../test-helpers/mock");
|
|
23
24
|
const spec_json_1 = __importDefault(require("../test-helpers/responses/runtime/spec.json"));
|
|
24
25
|
const RuntimeSpecService_1 = require("./RuntimeSpecService");
|
|
25
|
-
const runtimeSpecService = new RuntimeSpecService_1.RuntimeSpecService(
|
|
26
|
+
const runtimeSpecService = new RuntimeSpecService_1.RuntimeSpecService('mock');
|
|
26
27
|
describe('RuntimeSpecService', () => {
|
|
28
|
+
beforeAll(() => {
|
|
29
|
+
jest.spyOn(apiRegistry_1.ApiPromiseRegistry, 'getApi').mockImplementation(() => mock_1.defaultMockApi);
|
|
30
|
+
});
|
|
27
31
|
describe('fetchSpec', () => {
|
|
28
32
|
it('works when ApiPromise works', async () => {
|
|
29
33
|
expect((0, sanitizeNumbers_1.sanitizeNumbers)(await runtimeSpecService.fetchSpec(mock_1.blockHash789629))).toStrictEqual(spec_json_1.default);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RuntimeSpecService.spec.js","sourceRoot":"","sources":["../../../../src/services/runtime/RuntimeSpecService.spec.ts"],"names":[],"mappings":";AAAA,oDAAoD;AACpD,8CAA8C;AAC9C,EAAE;AACF,gFAAgF;AAChF,uEAAuE;AACvE,oEAAoE;AACpE,sCAAsC;AACtC,EAAE;AACF,kEAAkE;AAClE,iEAAiE;AACjE,gEAAgE;AAChE,+CAA+C;AAC/C,EAAE;AACF,oEAAoE;AACpE,wEAAwE;;;;;AAExE,oEAAiE;AACjE,+CAAuE;AACvE,4FAAmE;AACnE,6DAA0D;AAE1D,MAAM,kBAAkB,GAAG,IAAI,uCAAkB,CAAC,
|
|
1
|
+
{"version":3,"file":"RuntimeSpecService.spec.js","sourceRoot":"","sources":["../../../../src/services/runtime/RuntimeSpecService.spec.ts"],"names":[],"mappings":";AAAA,oDAAoD;AACpD,8CAA8C;AAC9C,EAAE;AACF,gFAAgF;AAChF,uEAAuE;AACvE,oEAAoE;AACpE,sCAAsC;AACtC,EAAE;AACF,kEAAkE;AAClE,iEAAiE;AACjE,gEAAgE;AAChE,+CAA+C;AAC/C,EAAE;AACF,oEAAoE;AACpE,wEAAwE;;;;;AAExE,mDAAuD;AACvD,oEAAiE;AACjE,+CAAuE;AACvE,4FAAmE;AACnE,6DAA0D;AAE1D,MAAM,kBAAkB,GAAG,IAAI,uCAAkB,CAAC,MAAM,CAAC,CAAC;AAE1D,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IACnC,SAAS,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,KAAK,CAAC,gCAAkB,EAAE,QAAQ,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE,CAAC,qBAAc,CAAC,CAAC;IACnF,CAAC,CAAC,CAAC;IACH,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;QAC1B,EAAE,CAAC,6BAA6B,EAAE,KAAK,IAAI,EAAE;YAC5C,MAAM,CAAC,IAAA,iCAAe,EAAC,MAAM,kBAAkB,CAAC,SAAS,CAAC,sBAAe,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,mBAAQ,CAAC,CAAC;QACtG,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -7,5 +7,5 @@ export type SignedOriginCaller = {
|
|
|
7
7
|
};
|
|
8
8
|
};
|
|
9
9
|
export declare class TransactionDryRunService extends AbstractService {
|
|
10
|
-
dryRuntExtrinsic(senderAddress: string, transaction: `0x${string}`, hash?: BlockHash): Promise<ITransactionDryRun>;
|
|
10
|
+
dryRuntExtrinsic(senderAddress: string, transaction: `0x${string}`, hash?: BlockHash, xcmVersion?: number | undefined): Promise<ITransactionDryRun>;
|
|
11
11
|
}
|
|
@@ -16,12 +16,38 @@
|
|
|
16
16
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
18
|
exports.TransactionDryRunService = void 0;
|
|
19
|
+
const http_errors_1 = require("http-errors");
|
|
19
20
|
const responses_1 = require("../../types/responses");
|
|
20
21
|
const AbstractService_1 = require("../AbstractService");
|
|
22
|
+
const index_1 = require("../index");
|
|
21
23
|
const extractCauseAndStack_1 = require("./extractCauseAndStack");
|
|
22
24
|
class TransactionDryRunService extends AbstractService_1.AbstractService {
|
|
23
|
-
async dryRuntExtrinsic(senderAddress, transaction, hash) {
|
|
25
|
+
async dryRuntExtrinsic(senderAddress, transaction, hash, xcmVersion) {
|
|
24
26
|
const { api } = this;
|
|
27
|
+
const metadataService = new index_1.RuntimeMetadataService(this.specName);
|
|
28
|
+
if (xcmVersion == undefined && hash) {
|
|
29
|
+
const metadataVersions = await metadataService.fetchMetadataVersions(hash);
|
|
30
|
+
const latestStableMetadataVersion = metadataVersions.reduce((max, current) => {
|
|
31
|
+
const metadata = Number(current);
|
|
32
|
+
if (isNaN(metadata)) {
|
|
33
|
+
return max;
|
|
34
|
+
}
|
|
35
|
+
return Math.max(max, metadata);
|
|
36
|
+
}, 0);
|
|
37
|
+
const metadata = await metadataService.fetchMetadataVersioned(api, latestStableMetadataVersion);
|
|
38
|
+
const dryRunApi = metadata.asLatest.apis.find((api) => api.name.toString() === 'DryRunApi');
|
|
39
|
+
if (!dryRunApi) {
|
|
40
|
+
throw new http_errors_1.BadRequest('DryRunApi not found in metadata.');
|
|
41
|
+
}
|
|
42
|
+
const dryRunCall = dryRunApi.methods.find((method) => method.name.toString() === 'dry_run_call');
|
|
43
|
+
if (!dryRunCall) {
|
|
44
|
+
throw new http_errors_1.BadRequest('dryRunCall not found in metadata.');
|
|
45
|
+
}
|
|
46
|
+
const xcmsVersion = dryRunCall.inputs.find((param) => param.name.toString() === 'result_xcms_version');
|
|
47
|
+
if (xcmsVersion) {
|
|
48
|
+
throw new http_errors_1.BadRequest('Missing field `xcmVersion` on request body.');
|
|
49
|
+
}
|
|
50
|
+
}
|
|
25
51
|
try {
|
|
26
52
|
const originCaller = {
|
|
27
53
|
System: {
|
|
@@ -29,7 +55,9 @@ class TransactionDryRunService extends AbstractService_1.AbstractService {
|
|
|
29
55
|
},
|
|
30
56
|
};
|
|
31
57
|
const [dryRunResponse, { number }] = await Promise.all([
|
|
32
|
-
|
|
58
|
+
xcmVersion === undefined
|
|
59
|
+
? api.call.dryRunApi.dryRunCall(originCaller, transaction)
|
|
60
|
+
: api.call.dryRunApi.dryRunCall(originCaller, transaction, xcmVersion),
|
|
33
61
|
hash ? api.rpc.chain.getHeader(hash) : { number: null },
|
|
34
62
|
]);
|
|
35
63
|
const response = dryRunResponse;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TransactionDryRunService.js","sourceRoot":"","sources":["../../../../src/services/transaction/TransactionDryRunService.ts"],"names":[],"mappings":";AAAA,oDAAoD;AACpD,8CAA8C;AAC9C,EAAE;AACF,gFAAgF;AAChF,uEAAuE;AACvE,oEAAoE;AACpE,sCAAsC;AACtC,EAAE;AACF,kEAAkE;AAClE,iEAAiE;AACjE,gEAAgE;AAChE,+CAA+C;AAC/C,EAAE;AACF,oEAAoE;AACpE,wEAAwE;;;
|
|
1
|
+
{"version":3,"file":"TransactionDryRunService.js","sourceRoot":"","sources":["../../../../src/services/transaction/TransactionDryRunService.ts"],"names":[],"mappings":";AAAA,oDAAoD;AACpD,8CAA8C;AAC9C,EAAE;AACF,gFAAgF;AAChF,uEAAuE;AACvE,oEAAoE;AACpE,sCAAsC;AACtC,EAAE;AACF,kEAAkE;AAClE,iEAAiE;AACjE,gEAAgE;AAChE,+CAA+C;AAC/C,EAAE;AACF,oEAAoE;AACpE,wEAAwE;;;AAIxE,6CAAyC;AAEzC,qDAAqG;AACrG,wDAAqD;AACrD,oCAAkD;AAClD,iEAA8D;AAQ9D,MAAa,wBAAyB,SAAQ,iCAAe;IAC5D,KAAK,CAAC,gBAAgB,CACrB,aAAqB,EACrB,WAA0B,EAC1B,IAAgB,EAChB,UAA+B;QAE/B,MAAM,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;QAErB,MAAM,eAAe,GAAG,IAAI,8BAAsB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAElE,IAAI,UAAU,IAAI,SAAS,IAAI,IAAI,EAAE,CAAC;YACrC,MAAM,gBAAgB,GAAG,MAAM,eAAe,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;YAE3E,MAAM,2BAA2B,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE;gBAC5E,MAAM,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;gBACjC,IAAI,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;oBACrB,OAAO,GAAG,CAAC;gBACZ,CAAC;gBACD,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;YAChC,CAAC,EAAE,CAAC,CAAC,CAAC;YAEN,MAAM,QAAQ,GAAG,MAAM,eAAe,CAAC,sBAAsB,CAAC,GAAG,EAAE,2BAA2B,CAAC,CAAC;YAEhG,MAAM,SAAS,GAAG,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,WAAW,CAAC,CAAC;YAC5F,IAAI,CAAC,SAAS,EAAE,CAAC;gBAChB,MAAM,IAAI,wBAAU,CAAC,kCAAkC,CAAC,CAAC;YAC1D,CAAC;YAED,MAAM,UAAU,GAAG,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,cAAc,CAAC,CAAC;YACjG,IAAI,CAAC,UAAU,EAAE,CAAC;gBACjB,MAAM,IAAI,wBAAU,CAAC,mCAAmC,CAAC,CAAC;YAC3D,CAAC;YACD,MAAM,WAAW,GAAG,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,qBAAqB,CAAC,CAAC;YAEvG,IAAI,WAAW,EAAE,CAAC;gBACjB,MAAM,IAAI,wBAAU,CAAC,6CAA6C,CAAC,CAAC;YACrE,CAAC;QACF,CAAC;QAED,IAAI,CAAC;YACJ,MAAM,YAAY,GAAuB;gBACxC,MAAM,EAAE;oBACP,MAAM,EAAE,aAAa;iBACrB;aACD,CAAC;YAEF,MAAM,CAAC,cAAc,EAAE,EAAE,MAAM,EAAE,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;gBACtD,UAAU,KAAK,SAAS;oBACvB,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,YAAY,EAAE,WAAW,CAAC;oBAC1D,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,YAAY,EAAE,WAAW,EAAE,UAAU,CAAC;gBACvE,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE;aACvD,CAAC,CAAC;YAEH,MAAM,QAAQ,GAAG,cAA8D,CAAC;YAEhF,OAAO;gBACN,EAAE,EAAE;oBACH,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;oBACtB,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG;iBACnD;gBACD,MAAM,EAAE;oBACP,UAAU,EAAE,QAAQ,CAAC,IAAI;wBACxB,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI;4BACnC,CAAC,CAAC,iCAAqB,CAAC,eAAe;4BACvC,CAAC,CAAC,iCAAqB,CAAC,aAAa;wBACtC,CAAC,CAAC,6BAAiB,CAAC,OAAO;oBAC5B,MAAM,EAAE,QAAQ,CAAC,IAAI;wBACpB,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI;4BACnC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI;4BACpC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK;wBACtC,CAAC,CAAC,QAAQ,CAAC,KAAK;iBACjB;aACD,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACd,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,IAAA,2CAAoB,EAAC,GAAG,CAAC,CAAC;YAEnD,MAAM;gBACL,EAAE,EAAE;oBACH,IAAI;iBACJ;gBACD,IAAI,EAAE,GAAG;gBACT,KAAK,EAAE,+BAA+B;gBACtC,WAAW;gBACX,KAAK;gBACL,KAAK;aACL,CAAC;QACH,CAAC;IACF,CAAC;CACD;AAzFD,4DAyFC"}
|
|
@@ -17,23 +17,57 @@
|
|
|
17
17
|
// You should have received a copy of the GNU General Public License
|
|
18
18
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
19
19
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
20
|
+
const apiRegistry_1 = require("../../apiRegistry");
|
|
21
|
+
const polkadotV15Metadata_1 = require("../../test-helpers/metadata/polkadotV15Metadata");
|
|
22
|
+
const registries_1 = require("../../test-helpers/registries");
|
|
20
23
|
const responses_1 = require("../../types/responses");
|
|
21
24
|
const mock_1 = require("../test-helpers/mock");
|
|
22
25
|
const mockDryRunCall_1 = require("../test-helpers/mock/mockDryRunCall");
|
|
23
26
|
const mockDryRunError_1 = require("../test-helpers/mock/mockDryRunError");
|
|
27
|
+
const mockKusamaApiBlock26187139_1 = require("../test-helpers/mock/mockKusamaApiBlock26187139");
|
|
24
28
|
const TransactionDryRunService_1 = require("./TransactionDryRunService");
|
|
25
|
-
const
|
|
26
|
-
|
|
29
|
+
const mockMetadataAtVersion = () =>
|
|
30
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
|
|
31
|
+
Promise.resolve().then(() => {
|
|
32
|
+
return registries_1.polkadotRegistryV15.createType('Option<OpaqueMetadata>', polkadotV15Metadata_1.polkadotMetadataRpcV15);
|
|
33
|
+
});
|
|
34
|
+
const mockMetadataVersions = jest.fn().mockResolvedValue({
|
|
35
|
+
toHuman: jest.fn().mockReturnValue(['14', '15', '4,294,967,295']), // or whatever versions you want
|
|
36
|
+
});
|
|
37
|
+
const runtimeDryRun = registries_1.polkadotRegistryV15.createType('Result<CallDryRunEffects, XcmDryRunApiError>', mockDryRunCall_1.mockDryRunCallResult);
|
|
38
|
+
const runtimeDryRunError = registries_1.polkadotRegistryV15.createType('Result<CallDryRunEffects, XcmDryRunApiError>', mockDryRunError_1.mockDryRunCallError);
|
|
39
|
+
const mockDryRunCall = () => Promise.resolve().then(() => runtimeDryRun);
|
|
40
|
+
const mockDryRunError = () => Promise.resolve().then(() => runtimeDryRunError);
|
|
41
|
+
const mockHistoricApi = {
|
|
27
42
|
call: {
|
|
28
43
|
dryRunApi: {
|
|
29
|
-
dryRunCall:
|
|
44
|
+
dryRunCall: mockDryRunCall,
|
|
45
|
+
},
|
|
46
|
+
metadata: {
|
|
47
|
+
metadataVersions: mockMetadataVersions,
|
|
48
|
+
metadataAtVersion: mockMetadataAtVersion,
|
|
30
49
|
},
|
|
31
50
|
},
|
|
51
|
+
registry: registries_1.polkadotRegistryV15,
|
|
52
|
+
};
|
|
53
|
+
const mockApi = {
|
|
54
|
+
...mockHistoricApi,
|
|
55
|
+
rpc: {
|
|
56
|
+
chain: {
|
|
57
|
+
getHeader: () => Promise.resolve(mock_1.blockHash22887036),
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
at: (_hash) => mockHistoricApi,
|
|
32
61
|
};
|
|
33
62
|
describe('TransactionDryRunService', () => {
|
|
63
|
+
beforeAll(() => {
|
|
64
|
+
jest.spyOn(apiRegistry_1.ApiPromiseRegistry, 'getApi').mockImplementation(() => {
|
|
65
|
+
return mockApi;
|
|
66
|
+
});
|
|
67
|
+
});
|
|
34
68
|
const sendersAddress = '5HBuLJz9LdkUNseUEL6DLeVkx2bqEi6pQr8Ea7fS4bzx7i7E';
|
|
35
69
|
it('Should correctly execute a dry run for a submittable executable', async () => {
|
|
36
|
-
const executionResult = await new TransactionDryRunService_1.TransactionDryRunService(
|
|
70
|
+
const executionResult = await new TransactionDryRunService_1.TransactionDryRunService('mock').dryRuntExtrinsic(sendersAddress, '0xfc041f0801010100411f0100010100c224aad9c6f3bbd784120e9fceee5bfd22a62c69144ee673f76d6a34d280de160104000002043205040091010000000000', mock_1.blockHash22887036, 4);
|
|
37
71
|
expect(executionResult === null || executionResult === void 0 ? void 0 : executionResult.at.hash).toEqual(mock_1.blockHash22887036);
|
|
38
72
|
const resData = executionResult === null || executionResult === void 0 ? void 0 : executionResult.result.result;
|
|
39
73
|
expect(executionResult === null || executionResult === void 0 ? void 0 : executionResult.result.resultType).toEqual(responses_1.TransactionResultType.DispatchOutcome);
|
|
@@ -41,28 +75,31 @@ describe('TransactionDryRunService', () => {
|
|
|
41
75
|
});
|
|
42
76
|
it('should correctly execute a dry run for a payload extrinsic', async () => {
|
|
43
77
|
const payloadTx = '0xf81f0801010100411f0100010100c224aad9c6f3bbd784120e9fceee5bfd22a62c69144ee673f76d6a34d280de16010400000204320504009101000000000045022800010000e0510f00040000000000000000000000000000000000000000000000000000000000000000000000be2554aa8a0151eb4d706308c47d16996af391e4c5e499c7cbef24259b7d4503';
|
|
44
|
-
const executionResult = await new TransactionDryRunService_1.TransactionDryRunService(
|
|
78
|
+
const executionResult = await new TransactionDryRunService_1.TransactionDryRunService('mock').dryRuntExtrinsic(sendersAddress, payloadTx, mock_1.blockHash22887036, 4);
|
|
45
79
|
const resData = executionResult === null || executionResult === void 0 ? void 0 : executionResult.result.result;
|
|
46
80
|
expect(resData.paysFee.toString()).toEqual(mockDryRunCall_1.mockDryRunCallResult.Ok.executionResult.Ok.paysFee);
|
|
47
81
|
});
|
|
48
82
|
it('should correctly execute a dry run for a call', async () => {
|
|
49
83
|
const callTx = '0x1f0801010100411f0100010100c224aad9c6f3bbd784120e9fceee5bfd22a62c69144ee673f76d6a34d280de160104000002043205040091010000000000';
|
|
50
|
-
const executionResult = await new TransactionDryRunService_1.TransactionDryRunService(
|
|
84
|
+
const executionResult = await new TransactionDryRunService_1.TransactionDryRunService('mock').dryRuntExtrinsic(sendersAddress, callTx);
|
|
51
85
|
expect(executionResult === null || executionResult === void 0 ? void 0 : executionResult.at.hash).toEqual('');
|
|
52
86
|
const resData = executionResult === null || executionResult === void 0 ? void 0 : executionResult.result.result;
|
|
53
87
|
expect(resData.paysFee.toString()).toEqual(mockDryRunCall_1.mockDryRunCallResult.Ok.executionResult.Ok.paysFee);
|
|
54
88
|
});
|
|
55
89
|
it('should correctly execute a dry run for a call and return an error', async () => {
|
|
56
|
-
const
|
|
57
|
-
...
|
|
90
|
+
const mockApiErr = {
|
|
91
|
+
...mockKusamaApiBlock26187139_1.mockKusamaApiBlock26187139,
|
|
58
92
|
call: {
|
|
59
93
|
dryRunApi: {
|
|
60
|
-
dryRunCall:
|
|
94
|
+
dryRunCall: mockDryRunError,
|
|
61
95
|
},
|
|
62
96
|
},
|
|
63
97
|
};
|
|
98
|
+
jest.spyOn(apiRegistry_1.ApiPromiseRegistry, 'getApi').mockImplementation(() => {
|
|
99
|
+
return mockApiErr;
|
|
100
|
+
});
|
|
64
101
|
const callTx = '0x0a0000fe06fc3db07fb1a4ce89a76eaed1e54519b5940d2652b8d6794ad4ddfcdcb16c0f00d0eca2b99401';
|
|
65
|
-
const executionResult = await new TransactionDryRunService_1.TransactionDryRunService(
|
|
102
|
+
const executionResult = await new TransactionDryRunService_1.TransactionDryRunService('mock').dryRuntExtrinsic(sendersAddress, callTx);
|
|
66
103
|
expect(executionResult === null || executionResult === void 0 ? void 0 : executionResult.at.hash).toEqual('');
|
|
67
104
|
const resData = executionResult === null || executionResult === void 0 ? void 0 : executionResult.result.result;
|
|
68
105
|
expect(resData.asToken.toString()).toEqual(mockDryRunError_1.mockDryRunCallError.Ok.executionResult.Err.Token);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TransactionDryRunService.spec.js","sourceRoot":"","sources":["../../../../src/services/transaction/TransactionDryRunService.spec.ts"],"names":[],"mappings":";AAAA,4DAA4D;AAC5D,sDAAsD;AACtD,oDAAoD;AACpD,8CAA8C;AAC9C,EAAE;AACF,gFAAgF;AAChF,uEAAuE;AACvE,oEAAoE;AACpE,sCAAsC;AACtC,EAAE;AACF,kEAAkE;AAClE,iEAAiE;AACjE,gEAAgE;AAChE,+CAA+C;AAC/C,EAAE;AACF,oEAAoE;AACpE,wEAAwE;;
|
|
1
|
+
{"version":3,"file":"TransactionDryRunService.spec.js","sourceRoot":"","sources":["../../../../src/services/transaction/TransactionDryRunService.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -18,6 +18,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
18
18
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
19
19
|
};
|
|
20
20
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
21
|
+
const apiRegistry_1 = require("../../apiRegistry");
|
|
21
22
|
const sanitizeNumbers_1 = require("../../sanitize/sanitizeNumbers");
|
|
22
23
|
const registries_1 = require("../../test-helpers/registries");
|
|
23
24
|
const mock_1 = require("../test-helpers/mock");
|
|
@@ -45,7 +46,7 @@ const mockApi = {
|
|
|
45
46
|
...mock_1.defaultMockApi,
|
|
46
47
|
at: (_hash) => mockApiAt,
|
|
47
48
|
};
|
|
48
|
-
const transactionFeeEstimateService = new TransactionFeeEstimateService_1.TransactionFeeEstimateService(
|
|
49
|
+
const transactionFeeEstimateService = new TransactionFeeEstimateService_1.TransactionFeeEstimateService('mock');
|
|
49
50
|
// Mocking the API at block 22887036
|
|
50
51
|
const queryInfoCallAt22887036 = () => Promise.resolve().then(() => registries_1.polkadotRegistryV1003000.createType('RuntimeDispatchInfoV2', {
|
|
51
52
|
weight: {
|
|
@@ -67,17 +68,20 @@ const mockApi22887036 = {
|
|
|
67
68
|
tx: mock_1.tx22887036,
|
|
68
69
|
at: (_hash) => mockApiAt22887036,
|
|
69
70
|
};
|
|
70
|
-
const transactionFeeEstimateService22887036 = new TransactionFeeEstimateService_1.TransactionFeeEstimateService(
|
|
71
|
+
const transactionFeeEstimateService22887036 = new TransactionFeeEstimateService_1.TransactionFeeEstimateService('mock');
|
|
71
72
|
describe('TransactionFeeEstimateService', () => {
|
|
72
73
|
describe('fetchTransactionFeeEstimate', () => {
|
|
73
74
|
it('Works with a valid transaction', async () => {
|
|
75
|
+
jest.spyOn(apiRegistry_1.ApiPromiseRegistry, 'getApi').mockImplementation(() => mockApi);
|
|
74
76
|
expect((0, sanitizeNumbers_1.sanitizeNumbers)(await transactionFeeEstimateService.fetchTransactionFeeEstimate(mock_1.blockHash789629, mock_1.balancesTransferValid))).toStrictEqual(feeEstimateValidRuntimeCall_json_1.default);
|
|
75
77
|
});
|
|
76
78
|
it('Works with a valid transaction at block 22887036', async () => {
|
|
79
|
+
jest.spyOn(apiRegistry_1.ApiPromiseRegistry, 'getApi').mockImplementation(() => mockApi22887036);
|
|
77
80
|
expect((0, sanitizeNumbers_1.sanitizeNumbers)(await transactionFeeEstimateService22887036.fetchTransactionFeeEstimate(mock_1.blockHash22887036, mock_1.balancesTransferKeepAliveValid))).toStrictEqual(feeEstimateValidRuntimeCall22887036_json_1.default);
|
|
78
81
|
});
|
|
79
82
|
it("Should default to the rpc call when the runtime call doesn't exist", async () => {
|
|
80
83
|
mockApiAt.call.transactionPaymentApi.queryInfo = undefined;
|
|
84
|
+
jest.spyOn(apiRegistry_1.ApiPromiseRegistry, 'getApi').mockImplementation(() => mockApi);
|
|
81
85
|
expect((0, sanitizeNumbers_1.sanitizeNumbers)(await transactionFeeEstimateService.fetchTransactionFeeEstimate(mock_1.blockHash789629, mock_1.balancesTransferValid))).toStrictEqual(feeEstimateValidRpcCall_json_1.default);
|
|
82
86
|
mockApiAt.call.transactionPaymentApi.queryInfo = queryInfoCallAt;
|
|
83
87
|
});
|
|
@@ -89,6 +93,7 @@ describe('TransactionFeeEstimateService', () => {
|
|
|
89
93
|
mockApi.rpc.payment.queryInfo = () => Promise.resolve().then(() => {
|
|
90
94
|
throw err;
|
|
91
95
|
});
|
|
96
|
+
jest.spyOn(apiRegistry_1.ApiPromiseRegistry, 'getApi').mockImplementation(() => mockApi);
|
|
92
97
|
await expect(transactionFeeEstimateService.fetchTransactionFeeEstimate(mock_1.blockHash789629, mock_1.balancesTransferInvalid)).rejects.toStrictEqual(feeEstimateInvalid_json_1.default);
|
|
93
98
|
mockApi.rpc.payment.queryInfo = mock_1.queryInfoAt;
|
|
94
99
|
mockApiAt.call.transactionPaymentApi.queryInfo = queryInfoCallAt;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TransactionFeeEstimateService.spec.js","sourceRoot":"","sources":["../../../../src/services/transaction/TransactionFeeEstimateService.spec.ts"],"names":[],"mappings":";AAAA,oDAAoD;AACpD,8CAA8C;AAC9C,EAAE;AACF,gFAAgF;AAChF,uEAAuE;AACvE,oEAAoE;AACpE,sCAAsC;AACtC,EAAE;AACF,kEAAkE;AAClE,iEAAiE;AACjE,gEAAgE;AAChE,+CAA+C;AAC/C,EAAE;AACF,oEAAoE;AACpE,wEAAwE;;;;;AAQxE,oEAAiE;AACjE,8DAAgG;AAChG,+CAU8B;AAC9B,4HAA4F;AAC5F,sIAAkG;AAClG,8IAA0G;AAC1G,8JAA0H;AAC1H,mFAAgF;AAEhF,MAAM,eAAe,GAAG,GAAG,EAAE,CAC5B,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAC3B,kCAAqB,CAAC,UAAU,CAAC,uBAAuB,EAAE;IACzD,MAAM,EAAE;QACP,OAAO,EAAE,WAAW;QACpB,SAAS,EAAE,GAAG;KACd;IACD,KAAK,EAAE,QAAQ;IACf,UAAU,EAAE,WAAW;CACvB,CAAC,CACF,CAAC;AAEH,MAAM,SAAS,GAAG;IACjB,IAAI,EAAE;QACL,qBAAqB,EAAE;YACtB,SAAS,EAAE,eAAe;SAC1B;KACD;CACD,CAAC;AAEF,MAAM,OAAO,GAAG;IACf,GAAG,qBAAc;IACjB,EAAE,EAAE,CAAC,KAAW,EAAE,EAAE,CAAC,SAAS;CACL,CAAC;AAE3B,MAAM,6BAA6B,GAAG,IAAI,6DAA6B,CAAC,
|
|
1
|
+
{"version":3,"file":"TransactionFeeEstimateService.spec.js","sourceRoot":"","sources":["../../../../src/services/transaction/TransactionFeeEstimateService.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -18,15 +18,21 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
18
18
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
19
19
|
};
|
|
20
20
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
21
|
+
const apiRegistry_1 = require("../../apiRegistry");
|
|
21
22
|
const sanitizeNumbers_1 = require("../../sanitize/sanitizeNumbers");
|
|
22
23
|
const mock_1 = require("../test-helpers/mock");
|
|
23
|
-
const
|
|
24
|
+
const material_json_1 = __importDefault(require("../test-helpers/responses/transaction/material.json"));
|
|
24
25
|
const TransactionMaterialService_1 = require("./TransactionMaterialService");
|
|
25
|
-
const transactionMaterialService = new TransactionMaterialService_1.TransactionMaterialService(
|
|
26
|
+
const transactionMaterialService = new TransactionMaterialService_1.TransactionMaterialService('mock');
|
|
26
27
|
describe('TransactionMaterialService', () => {
|
|
28
|
+
beforeAll(() => {
|
|
29
|
+
jest.spyOn(apiRegistry_1.ApiPromiseRegistry, 'getApi').mockImplementation(() => {
|
|
30
|
+
return mock_1.defaultMockApi;
|
|
31
|
+
});
|
|
32
|
+
});
|
|
27
33
|
describe('getTransactionMaterial', () => {
|
|
28
34
|
it('Should return the scale encoded metadata when the `metadata` query param is `scale`', async () => {
|
|
29
|
-
expect((0, sanitizeNumbers_1.sanitizeNumbers)(await transactionMaterialService.fetchTransactionMaterial(mock_1.blockHash789629, 'scale'))).toStrictEqual(
|
|
35
|
+
expect((0, sanitizeNumbers_1.sanitizeNumbers)(await transactionMaterialService.fetchTransactionMaterial(mock_1.blockHash789629, 'scale'))).toStrictEqual(material_json_1.default);
|
|
30
36
|
});
|
|
31
37
|
it('Should return the decoded metadata when the `metadata` query param is `json`', async () => {
|
|
32
38
|
const res = await transactionMaterialService.fetchTransactionMaterial(mock_1.blockHash789629, 'json');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TransactionMaterialService.spec.js","sourceRoot":"","sources":["../../../../src/services/transaction/TransactionMaterialService.spec.ts"],"names":[],"mappings":";AAAA,oDAAoD;AACpD,8CAA8C;AAC9C,EAAE;AACF,gFAAgF;AAChF,uEAAuE;AACvE,oEAAoE;AACpE,sCAAsC;AACtC,EAAE;AACF,kEAAkE;AAClE,iEAAiE;AACjE,gEAAgE;AAChE,+CAA+C;AAC/C,EAAE;AACF,oEAAoE;AACpE,wEAAwE;;;;;AAExE,oEAAiE;AACjE,+CAAuE;AACvE,
|
|
1
|
+
{"version":3,"file":"TransactionMaterialService.spec.js","sourceRoot":"","sources":["../../../../src/services/transaction/TransactionMaterialService.spec.ts"],"names":[],"mappings":";AAAA,oDAAoD;AACpD,8CAA8C;AAC9C,EAAE;AACF,gFAAgF;AAChF,uEAAuE;AACvE,oEAAoE;AACpE,sCAAsC;AACtC,EAAE;AACF,kEAAkE;AAClE,iEAAiE;AACjE,gEAAgE;AAChE,+CAA+C;AAC/C,EAAE;AACF,oEAAoE;AACpE,wEAAwE;;;;;AAExE,mDAAuD;AACvD,oEAAiE;AACjE,+CAAuE;AACvE,wGAA2E;AAC3E,6EAA0E;AAE1E,MAAM,0BAA0B,GAAG,IAAI,uDAA0B,CAAC,MAAM,CAAC,CAAC;AAE1E,QAAQ,CAAC,4BAA4B,EAAE,GAAG,EAAE;IAC3C,SAAS,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,KAAK,CAAC,gCAAkB,EAAE,QAAQ,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE;YAChE,OAAO,qBAAc,CAAC;QACvB,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;IACH,QAAQ,CAAC,wBAAwB,EAAE,GAAG,EAAE;QACvC,EAAE,CAAC,qFAAqF,EAAE,KAAK,IAAI,EAAE;YACpG,MAAM,CACL,IAAA,iCAAe,EAAC,MAAM,0BAA0B,CAAC,wBAAwB,CAAC,sBAAe,EAAE,OAAO,CAAC,CAAC,CACpG,CAAC,aAAa,CAAC,uBAAQ,CAAC,CAAC;QAC3B,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8EAA8E,EAAE,KAAK,IAAI,EAAE;YAC7F,MAAM,GAAG,GAAG,MAAM,0BAA0B,CAAC,wBAAwB,CAAC,sBAAe,EAAE,MAAM,CAAC,CAAC;YAC/F,sDAAsD;YACtD,MAAM,CAAC,OAAO,GAAG,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gFAAgF,EAAE,KAAK,IAAI,EAAE;YAC/F,MAAM,WAAW,GAAG;gBACnB,EAAE,EAAE;oBACH,IAAI,EAAE,oEAAoE;oBAC1E,MAAM,EAAE,QAAQ;iBAChB;gBACD,WAAW,EAAE,oEAAoE;gBACjF,SAAS,EAAE,UAAU;gBACrB,QAAQ,EAAE,UAAU;gBACpB,WAAW,EAAE,IAAI;gBACjB,SAAS,EAAE,GAAG;aACd,CAAC;YAEF,MAAM,GAAG,GAAG,MAAM,0BAA0B,CAAC,wBAAwB,CAAC,sBAAe,EAAE,KAAK,CAAC,CAAC;YAE9F,MAAM,CAAC,IAAA,iCAAe,EAAC,GAAG,CAAC,CAAC,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -18,6 +18,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
18
18
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
19
19
|
};
|
|
20
20
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
21
|
+
const apiRegistry_1 = require("../../apiRegistry");
|
|
21
22
|
const registries_1 = require("../../test-helpers/registries");
|
|
22
23
|
const mock_1 = require("../test-helpers/mock");
|
|
23
24
|
const submitFailParse_json_1 = __importDefault(require("../test-helpers/responses/transaction/submitFailParse.json"));
|
|
@@ -27,8 +28,13 @@ const mockApi = {
|
|
|
27
28
|
...mock_1.defaultMockApi,
|
|
28
29
|
tx: mock_1.tx,
|
|
29
30
|
};
|
|
30
|
-
const transactionSubmitService = new TransactionSubmitService_1.TransactionSubmitService(
|
|
31
|
+
const transactionSubmitService = new TransactionSubmitService_1.TransactionSubmitService('mock');
|
|
31
32
|
describe('TransactionSubmitService', () => {
|
|
33
|
+
beforeAll(() => {
|
|
34
|
+
jest.spyOn(apiRegistry_1.ApiPromiseRegistry, 'getApi').mockImplementation(() => {
|
|
35
|
+
return mockApi;
|
|
36
|
+
});
|
|
37
|
+
});
|
|
32
38
|
describe('submitTransaction', () => {
|
|
33
39
|
it('works with a valid a transaction', async () => {
|
|
34
40
|
return expect(transactionSubmitService.submitTransaction(mock_1.balancesTransferValid)).resolves.toStrictEqual({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TransactionSubmitService.spec.js","sourceRoot":"","sources":["../../../../src/services/transaction/TransactionSubmitService.spec.ts"],"names":[],"mappings":";AAAA,oDAAoD;AACpD,8CAA8C;AAC9C,EAAE;AACF,gFAAgF;AAChF,uEAAuE;AACvE,oEAAoE;AACpE,sCAAsC;AACtC,EAAE;AACF,kEAAkE;AAClE,iEAAiE;AACjE,gEAAgE;AAChE,+CAA+C;AAC/C,EAAE;AACF,oEAAoE;AACpE,wEAAwE;;;;;AAMxE,8DAAiE;AACjE,+CAM8B;AAC9B,sHAA2F;AAC3F,wHAA6F;AAC7F,yEAAsE;AAEtE,MAAM,OAAO,GAAG;IACf,GAAG,qBAAc;IACjB,EAAE,EAAE,SAAE;CACmB,CAAC;AAE3B,MAAM,wBAAwB,GAAG,IAAI,mDAAwB,CAAC,
|
|
1
|
+
{"version":3,"file":"TransactionSubmitService.spec.js","sourceRoot":"","sources":["../../../../src/services/transaction/TransactionSubmitService.spec.ts"],"names":[],"mappings":";AAAA,oDAAoD;AACpD,8CAA8C;AAC9C,EAAE;AACF,gFAAgF;AAChF,uEAAuE;AACvE,oEAAoE;AACpE,sCAAsC;AACtC,EAAE;AACF,kEAAkE;AAClE,iEAAiE;AACjE,gEAAgE;AAChE,+CAA+C;AAC/C,EAAE;AACF,oEAAoE;AACpE,wEAAwE;;;;;AAMxE,mDAAuD;AACvD,8DAAiE;AACjE,+CAM8B;AAC9B,sHAA2F;AAC3F,wHAA6F;AAC7F,yEAAsE;AAEtE,MAAM,OAAO,GAAG;IACf,GAAG,qBAAc;IACjB,EAAE,EAAE,SAAE;CACmB,CAAC;AAE3B,MAAM,wBAAwB,GAAG,IAAI,mDAAwB,CAAC,MAAM,CAAC,CAAC;AAEtE,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;IACzC,SAAS,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,KAAK,CAAC,gCAAkB,EAAE,QAAQ,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE;YAChE,OAAO,OAAO,CAAC;QAChB,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;IACH,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;QAClC,EAAE,CAAC,kCAAkC,EAAE,KAAK,IAAI,EAAE;YACjD,OAAO,MAAM,CAAC,wBAAwB,CAAC,iBAAiB,CAAC,4BAAqB,CAAC,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC;gBACvG,IAAI,EAAE,6BAAgB,CAAC,UAAU,CAAC,MAAM,CAAC;aACzC,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,qEAAqE,EAAE,KAAK,IAAI,EAAE;YACpF,MAAM,GAAG,GAAG,IAAI,KAAK;YACpB,6CAA6C;YAC7C,sMAAsM,CACtM,CAAC;YACF,GAAG,CAAC,KAAK,GAAG,8EAA8E,CAAC;YAE1F,OAAe,CAAC,EAAE,GAAG,GAAG,EAAE;gBAC1B,MAAM,GAAG,CAAC;YACX,CAAC,CAAC;YAEF,MAAM,MAAM,CAAC,wBAAwB,CAAC,iBAAiB,CAAC,8BAAuB,CAAC,CAAC,CAAC,OAAO,CAAC,aAAa,CACtG,8BAAiB,CACjB,CAAC;YAED,OAAe,CAAC,EAAE,GAAG,SAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,kFAAkF,EAAE,KAAK,IAAI,EAAE;YACjG,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;YACjE,GAAG,CAAC,KAAK,GAAG,6EAA6E,CAAC;YAEzF,OAAO,CAAC,GAAG,CAAC,MAAc,CAAC,eAAe,GAAG,GAAG,EAAE,CAClD,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;gBAC3B,MAAM,GAAG,CAAC;YACX,CAAC,CAAC,CAAC;YAEJ,MAAM,MAAM,CAAC,wBAAwB,CAAC,iBAAiB,CAAC,4BAAqB,CAAC,CAAC,CAAC,OAAO,CAAC,aAAa,CACpG,+BAAkB,CAClB,CAAC;YAED,OAAO,CAAC,GAAG,CAAC,MAAc,CAAC,eAAe,GAAG,sBAAe,CAAC;QAC/D,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { PalletConstantMetadataLatest } from '@polkadot/types/interfaces';
|
|
2
2
|
import { IPallet } from '.';
|
|
3
3
|
export interface IPalletConstantsItem extends IPallet {
|
|
4
4
|
constantsItem: string;
|
|
5
|
-
metadata:
|
|
5
|
+
metadata: PalletConstantMetadataLatest | undefined;
|
|
6
6
|
}
|
|
@@ -25,6 +25,7 @@ var CONFIG;
|
|
|
25
25
|
CONFIG["PORT"] = "PORT";
|
|
26
26
|
CONFIG["KEEP_ALIVE_TIMEOUT"] = "KEEP_ALIVE_TIMEOUT";
|
|
27
27
|
CONFIG["URL"] = "URL";
|
|
28
|
+
CONFIG["MULTI_CHAIN_URL"] = "MULTI_CHAIN_URL";
|
|
28
29
|
CONFIG["LEVEL"] = "LEVEL";
|
|
29
30
|
CONFIG["JSON"] = "JSON";
|
|
30
31
|
CONFIG["FILTER_RPC"] = "FILTER_RPC";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CONFIG.js","sourceRoot":"","sources":["../../../../src/types/sidecar-config/CONFIG.ts"],"names":[],"mappings":";AAAA,oDAAoD;AACpD,8CAA8C;AAC9C,EAAE;AACF,gFAAgF;AAChF,uEAAuE;AACvE,oEAAoE;AACpE,sCAAsC;AACtC,EAAE;AACF,kEAAkE;AAClE,iEAAiE;AACjE,gEAAgE;AAChE,+CAA+C;AAC/C,EAAE;AACF,oEAAoE;AACpE,wEAAwE;;;AAExE;;GAEG;AACH,IAAY,
|
|
1
|
+
{"version":3,"file":"CONFIG.js","sourceRoot":"","sources":["../../../../src/types/sidecar-config/CONFIG.ts"],"names":[],"mappings":";AAAA,oDAAoD;AACpD,8CAA8C;AAC9C,EAAE;AACF,gFAAgF;AAChF,uEAAuE;AACvE,oEAAoE;AACpE,sCAAsC;AACtC,EAAE;AACF,kEAAkE;AAClE,iEAAiE;AACjE,gEAAgE;AAChE,+CAA+C;AAC/C,EAAE;AACF,oEAAoE;AACpE,wEAAwE;;;AAExE;;GAEG;AACH,IAAY,MA2BX;AA3BD,WAAY,MAAM;IACjB,iCAAuB,CAAA;IACvB,uBAAa,CAAA;IACb,mDAAyC,CAAA;IACzC,qBAAW,CAAA;IACX,6CAAmC,CAAA;IACnC,yBAAe,CAAA;IACf,uBAAa,CAAA;IACb,mCAAyB,CAAA;IACzB,mCAAyB,CAAA;IACzB,uCAA6B,CAAA;IAC7B,qCAA2B,CAAA;IAC3B,mCAAyB,CAAA;IACzB,2CAAiC,CAAA;IACjC,yBAAe,CAAA;IACf,yBAAe,CAAA;IACf,mCAAyB,CAAA;IACzB,qDAA2C,CAAA;IAC3C,6CAAmC,CAAA;IACnC,6BAAmB,CAAA;IACnB,iCAAuB,CAAA;IACvB,iCAAuB,CAAA;IACvB,iCAAuB,CAAA;IACvB,iCAAuB,CAAA;IACvB,qDAA2C,CAAA;IAC3C,+BAAqB,CAAA;IACrB,uDAA6C,CAAA;AAC9C,CAAC,EA3BW,MAAM,sBAAN,MAAM,QA2BjB"}
|
|
@@ -9,6 +9,10 @@ export interface ISidecarConfig {
|
|
|
9
9
|
}
|
|
10
10
|
interface ISidecarConfigSubstrate {
|
|
11
11
|
URL: string;
|
|
12
|
+
MULTI_CHAIN_URL: Array<{
|
|
13
|
+
url: string;
|
|
14
|
+
type: 'relay' | 'assethub' | 'parachain' | undefined;
|
|
15
|
+
}>;
|
|
12
16
|
TYPES_BUNDLE: string;
|
|
13
17
|
TYPES_CHAIN: string;
|
|
14
18
|
TYPES_SPEC: string;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export declare class MultiKeyBiMap<K extends string | number, V extends string | number> {
|
|
2
|
+
private keyToValue;
|
|
3
|
+
private valueToKeys;
|
|
4
|
+
set(key: K, value: V): void;
|
|
5
|
+
getByKey(key: K): V | undefined;
|
|
6
|
+
getByValue(value: V): Set<K> | undefined;
|
|
7
|
+
get(input: K | V): V | Set<K> | undefined;
|
|
8
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MultiKeyBiMap = void 0;
|
|
4
|
+
class MultiKeyBiMap {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.keyToValue = new Map();
|
|
7
|
+
this.valueToKeys = new Map();
|
|
8
|
+
}
|
|
9
|
+
set(key, value) {
|
|
10
|
+
// Remove old value mapping if it exists
|
|
11
|
+
const oldValue = this.keyToValue.get(key);
|
|
12
|
+
if (oldValue !== undefined) {
|
|
13
|
+
const keys = this.valueToKeys.get(oldValue);
|
|
14
|
+
keys === null || keys === void 0 ? void 0 : keys.delete(key);
|
|
15
|
+
if (keys && keys.size === 0) {
|
|
16
|
+
this.valueToKeys.delete(oldValue);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
this.keyToValue.set(key, value);
|
|
20
|
+
if (!this.valueToKeys.has(value)) {
|
|
21
|
+
this.valueToKeys.set(value, new Set());
|
|
22
|
+
}
|
|
23
|
+
this.valueToKeys.get(value).add(key);
|
|
24
|
+
}
|
|
25
|
+
getByKey(key) {
|
|
26
|
+
return this.keyToValue.get(key);
|
|
27
|
+
}
|
|
28
|
+
getByValue(value) {
|
|
29
|
+
return this.valueToKeys.get(value);
|
|
30
|
+
}
|
|
31
|
+
get(input) {
|
|
32
|
+
if (this.keyToValue.has(input)) {
|
|
33
|
+
return this.keyToValue.get(input);
|
|
34
|
+
}
|
|
35
|
+
if (this.valueToKeys.has(input)) {
|
|
36
|
+
return this.valueToKeys.get(input);
|
|
37
|
+
}
|
|
38
|
+
return undefined;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
exports.MultiKeyBiMap = MultiKeyBiMap;
|
|
42
|
+
//# sourceMappingURL=MultiKeyBiMap.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MultiKeyBiMap.js","sourceRoot":"","sources":["../../../src/util/MultiKeyBiMap.ts"],"names":[],"mappings":";;;AAAA,MAAa,aAAa;IAA1B;QACS,eAAU,GAAG,IAAI,GAAG,EAAQ,CAAC;QAC7B,gBAAW,GAAG,IAAI,GAAG,EAAa,CAAC;IAsC5C,CAAC;IApCA,GAAG,CAAC,GAAM,EAAE,KAAQ;QACnB,wCAAwC;QACxC,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAC1C,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;YAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;YAC5C,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,MAAM,CAAC,GAAG,CAAC,CAAC;YAClB,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;gBAC7B,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YACnC,CAAC;QACF,CAAC;QAED,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QAEhC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;YAClC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;QACxC,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACvC,CAAC;IAED,QAAQ,CAAC,GAAM;QACd,OAAO,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC;IAED,UAAU,CAAC,KAAQ;QAClB,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAED,GAAG,CAAC,KAAY;QACf,IAAI,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,KAAU,CAAC,EAAE,CAAC;YACrC,OAAO,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,KAAU,CAAC,CAAC;QACxC,CAAC;QACD,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAU,CAAC,EAAE,CAAC;YACtC,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAU,CAAC,CAAC;QACzC,CAAC;QACD,OAAO,SAAS,CAAC;IAClB,CAAC;CACD;AAxCD,sCAwCC"}
|
package/package.json
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
{
|
|
2
|
-
"version": "20.
|
|
2
|
+
"version": "20.3.0",
|
|
3
3
|
"name": "@substrate/api-sidecar",
|
|
4
4
|
"description": "REST service that makes it easy to interact with blockchain nodes built using Substrate's FRAME framework.",
|
|
5
5
|
"homepage": "https://github.com/paritytech/substrate-api-sidecar#readme",
|
|
@@ -50,17 +50,17 @@
|
|
|
50
50
|
"test:test-release": "yarn build:scripts && node scripts/build/runYarnPack.js"
|
|
51
51
|
},
|
|
52
52
|
"dependencies": {
|
|
53
|
-
"@polkadot/api": "^
|
|
54
|
-
"@polkadot/api-augment": "^
|
|
55
|
-
"@polkadot/api-contract": "^
|
|
56
|
-
"@polkadot/types": "^
|
|
57
|
-
"@polkadot/types-codec": "^
|
|
58
|
-
"@polkadot/util": "^13.
|
|
59
|
-
"@polkadot/util-crypto": "^13.
|
|
60
|
-
"@substrate/calc": "^0.3.
|
|
53
|
+
"@polkadot/api": "^16.1.2",
|
|
54
|
+
"@polkadot/api-augment": "^16.1.2",
|
|
55
|
+
"@polkadot/api-contract": "^16.1.2",
|
|
56
|
+
"@polkadot/types": "^16.1.2",
|
|
57
|
+
"@polkadot/types-codec": "^16.1.2",
|
|
58
|
+
"@polkadot/util": "^13.5.1",
|
|
59
|
+
"@polkadot/util-crypto": "^13.5.1",
|
|
60
|
+
"@substrate/calc": "^0.3.2",
|
|
61
61
|
"argparse": "^2.0.1",
|
|
62
62
|
"confmgr": "^1.1.0",
|
|
63
|
-
"express": "^5.0
|
|
63
|
+
"express": "^5.1.0",
|
|
64
64
|
"express-winston": "^4.2.0",
|
|
65
65
|
"http-errors": "^2.0.0",
|
|
66
66
|
"lru-cache": "^11.1.0",
|
|
@@ -70,14 +70,16 @@
|
|
|
70
70
|
"winston-loki": "^6.1.3"
|
|
71
71
|
},
|
|
72
72
|
"devDependencies": {
|
|
73
|
+
"@acala-network/chopsticks-testing": "^1.0.5",
|
|
73
74
|
"@substrate/dev": "^0.9.0",
|
|
74
75
|
"@types/argparse": "2.0.17",
|
|
75
|
-
"@types/express": "^5.0.
|
|
76
|
+
"@types/express": "^5.0.2",
|
|
76
77
|
"@types/express-serve-static-core": "^5.0.6",
|
|
77
78
|
"@types/http-errors": "2.0.4",
|
|
78
79
|
"@types/lru-cache": "^7.10.10",
|
|
79
|
-
"@types/morgan": "1.9.
|
|
80
|
+
"@types/morgan": "1.9.10",
|
|
80
81
|
"@types/triple-beam": "^1.3.5",
|
|
82
|
+
"reflect-metadata": "^0.2.2",
|
|
81
83
|
"ts-node-dev": "^2.0.0"
|
|
82
84
|
},
|
|
83
85
|
"keywords": [
|
|
@@ -87,5 +89,15 @@
|
|
|
87
89
|
"polkadot",
|
|
88
90
|
"kusama"
|
|
89
91
|
],
|
|
90
|
-
"packageManager": "yarn@4.6.0"
|
|
92
|
+
"packageManager": "yarn@4.6.0",
|
|
93
|
+
"resolutions": {
|
|
94
|
+
"@polkadot/api": "16.1.2",
|
|
95
|
+
"@polkadot/api-augment": "16.1.2",
|
|
96
|
+
"@polkadot/api-contract": "16.1.2",
|
|
97
|
+
"@polkadot/types": "16.1.2",
|
|
98
|
+
"@polkadot/types-codec": "16.1.2",
|
|
99
|
+
"@polkadot/rpc-provider": "16.1.2",
|
|
100
|
+
"@polkadot/util": "^13.5.1",
|
|
101
|
+
"@polkadot/util-crypto": "^13.5.1"
|
|
102
|
+
}
|
|
91
103
|
}
|