@substrate/api-sidecar 14.5.1 → 14.5.3

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.
@@ -1,5 +1,5 @@
1
1
  {
2
- "version": "14.5.1",
2
+ "version": "14.5.3",
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",
@@ -1,5 +1,5 @@
1
1
  import { BlockHash } from '@polkadot/types/interfaces';
2
- import { IPalletStakingValidator } from 'src/types/responses';
2
+ import { IPalletStakingValidator } from '../../types/responses';
3
3
  import { AbstractService } from '../AbstractService';
4
4
  export declare class PalletsStakingValidatorsService extends AbstractService {
5
5
  /**
@@ -29,7 +29,15 @@ class PalletsStakingValidatorsService extends AbstractService_1.AbstractService
29
29
  async derivePalletStakingValidators(hash) {
30
30
  const { api } = this;
31
31
  const historicApi = await api.at(hash);
32
- const validatorSession = await historicApi.query.session.validators();
32
+ const [{ number }, validatorSession, validatorsEntries] = await Promise.all([
33
+ api.rpc.chain.getHeader(hash),
34
+ historicApi.query.session.validators(),
35
+ historicApi.query.staking.validators.entries(),
36
+ ]);
37
+ const at = {
38
+ hash,
39
+ height: number.unwrap().toString(10),
40
+ };
33
41
  const validatorsActiveSet = new Set();
34
42
  for (const address of validatorSession) {
35
43
  validatorsActiveSet.add(address.toString());
@@ -38,16 +46,31 @@ class PalletsStakingValidatorsService extends AbstractService_1.AbstractService
38
46
  // status. If the address is found in the `validatorsActiveSet` then
39
47
  // status is `active` otherwise is set to `waiting`
40
48
  const validators = [];
41
- const validatorsEntries = await historicApi.query.staking.validators.entries();
49
+ // Active validators that wont be part of the next active validator set
50
+ // for the incoming era.
51
+ const validatorsToBeChilled = [];
42
52
  validatorsEntries.map(([key]) => {
43
- const address = key.args.map((k) => k.toHuman())[0];
44
- const status = validatorsActiveSet.has(address)
45
- ? 'active'
46
- : 'waiting';
53
+ const address = key.args.map((k) => k.toString())[0];
54
+ let status;
55
+ if (validatorsActiveSet.has(address)) {
56
+ status = 'active';
57
+ validatorsActiveSet.delete(address);
58
+ }
59
+ else {
60
+ status = 'waiting';
61
+ }
47
62
  validators.push({ address, status });
48
63
  });
64
+ if (validatorsActiveSet.size > 0) {
65
+ validatorsActiveSet.forEach((address) => {
66
+ validators.push({ address, status: 'active' });
67
+ validatorsToBeChilled.push({ address, status: 'active' });
68
+ });
69
+ }
49
70
  return {
71
+ at,
50
72
  validators,
73
+ validatorsToBeChilled,
51
74
  };
52
75
  }
53
76
  }
@@ -1 +1 @@
1
- {"version":3,"file":"PalletsStakingValidatorsService.js","sourceRoot":"","sources":["../../../../src/services/pallets/PalletsStakingValidatorsService.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;;;AAKxE,wDAAqD;AAErD,MAAa,+BAAgC,SAAQ,iCAAe;IACnE;;;;;;;OAOG;IACH,KAAK,CAAC,6BAA6B,CAClC,IAAe;QAEf,MAAM,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;QACrB,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAEvC,MAAM,gBAAgB,GAAG,MAAM,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;QACtE,MAAM,mBAAmB,GAAG,IAAI,GAAG,EAAU,CAAC;QAC9C,KAAK,MAAM,OAAO,IAAI,gBAAgB,EAAE;YACvC,mBAAmB,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;SAC5C;QAED,mEAAmE;QACnE,oEAAoE;QACpE,mDAAmD;QACnD,MAAM,UAAU,GAAiB,EAAE,CAAC;QACpC,MAAM,iBAAiB,GACtB,MAAM,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;QACtD,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE;YAC/B,MAAM,OAAO,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;YACpD,MAAM,MAAM,GAAW,mBAAmB,CAAC,GAAG,CAAC,OAAO,CAAC;gBACtD,CAAC,CAAC,QAAQ;gBACV,CAAC,CAAC,SAAS,CAAC;YACb,UAAU,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;QAEH,OAAO;YACN,UAAU;SACV,CAAC;IACH,CAAC;CACD;AAvCD,0EAuCC"}
1
+ {"version":3,"file":"PalletsStakingValidatorsService.js","sourceRoot":"","sources":["../../../../src/services/pallets/PalletsStakingValidatorsService.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;;;AAKxE,wDAAqD;AAErD,MAAa,+BAAgC,SAAQ,iCAAe;IACnE;;;;;;;OAOG;IACH,KAAK,CAAC,6BAA6B,CAClC,IAAe;QAEf,MAAM,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;QACrB,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QACvC,MAAM,CAAC,EAAE,MAAM,EAAE,EAAE,gBAAgB,EAAE,iBAAiB,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAC1E;YACC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC;YAC7B,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,EAAE;YACtC,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,OAAO,EAAE;SAC9C,CACD,CAAC;QAEF,MAAM,EAAE,GAAG;YACV,IAAI;YACJ,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC;SACpC,CAAC;QAEF,MAAM,mBAAmB,GAAG,IAAI,GAAG,EAAU,CAAC;QAC9C,KAAK,MAAM,OAAO,IAAI,gBAAgB,EAAE;YACvC,mBAAmB,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;SAC5C;QAED,mEAAmE;QACnE,oEAAoE;QACpE,mDAAmD;QACnD,MAAM,UAAU,GAAiB,EAAE,CAAC;QACpC,uEAAuE;QACvE,wBAAwB;QACxB,MAAM,qBAAqB,GAAiB,EAAE,CAAC;QAE/C,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE;YAC/B,MAAM,OAAO,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;YACrD,IAAI,MAA4B,CAAC;YACjC,IAAI,mBAAmB,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;gBACrC,MAAM,GAAG,QAAQ,CAAC;gBAClB,mBAAmB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;aACpC;iBAAM;gBACN,MAAM,GAAG,SAAS,CAAC;aACnB;YACD,UAAU,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;QAEH,IAAI,mBAAmB,CAAC,IAAI,GAAG,CAAC,EAAE;YACjC,mBAAmB,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;gBACvC,UAAU,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;gBAC/C,qBAAqB,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;YAC3D,CAAC,CAAC,CAAC;SACH;QAED,OAAO;YACN,EAAE;YACF,UAAU;YACV,qBAAqB;SACrB,CAAC;IACH,CAAC;CACD;AAjED,0EAiEC"}
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+ // Copyright 2017-2023 Parity Technologies (UK) Ltd.
3
+ // This file is part of Substrate API Sidecar.
4
+ //
5
+ // Substrate API Sidecar is free software: you can redistribute it and/or modify
6
+ // it under the terms of the GNU General Public License as published by
7
+ // the Free Software Foundation, either version 3 of the License, or
8
+ // (at your option) any later version.
9
+ //
10
+ // This program is distributed in the hope that it will be useful,
11
+ // but WITHOUT ANY WARRANTY; without even the implied warranty of
12
+ // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
+ // GNU General Public License for more details.
14
+ //
15
+ // You should have received a copy of the GNU General Public License
16
+ // along with this program. If not, see <http://www.gnu.org/licenses/>.
17
+ var __importDefault = (this && this.__importDefault) || function (mod) {
18
+ return (mod && mod.__esModule) ? mod : { "default": mod };
19
+ };
20
+ Object.defineProperty(exports, "__esModule", { value: true });
21
+ const sanitizeNumbers_1 = require("../../sanitize/sanitizeNumbers");
22
+ const registries_1 = require("../../test-helpers/registries");
23
+ const mock_1 = require("../test-helpers/mock");
24
+ const validator14815152Entries_1 = require("../test-helpers/mock/data/validator14815152Entries");
25
+ const validators14815152Hex_1 = require("../test-helpers/mock/data/validators14815152Hex");
26
+ const fetchValidators14815152_json_1 = __importDefault(require("../test-helpers/responses/pallets/fetchValidators14815152.json"));
27
+ const PalletsStakingValidatorsService_1 = require("./PalletsStakingValidatorsService");
28
+ const validatorsAt = () => Promise.resolve().then(() => registries_1.polkadotRegistryV9370.createType('Vec<AccountId32>', validators14815152Hex_1.validators14815152Hex));
29
+ const validatorsEntriesAt = () => Promise.resolve().then(() => (0, validator14815152Entries_1.validatorsEntries)());
30
+ const mockHistoricApi = {
31
+ query: {
32
+ session: {
33
+ validators: validatorsAt,
34
+ },
35
+ staking: {
36
+ validators: {
37
+ entries: validatorsEntriesAt,
38
+ },
39
+ },
40
+ },
41
+ };
42
+ const mockApi = {
43
+ ...mock_1.defaultMockApi,
44
+ at: (_hash) => mockHistoricApi,
45
+ };
46
+ /**
47
+ * Mock PalletStakingProgressService instance.
48
+ */
49
+ const palletsStakingValidatorsService = new PalletsStakingValidatorsService_1.PalletsStakingValidatorsService(mockApi);
50
+ describe('PalletsStakingValidatorsService', () => {
51
+ describe('derivePalletStakingValidators', () => {
52
+ it('Works for block 14815152', async () => {
53
+ expect((0, sanitizeNumbers_1.sanitizeNumbers)(
54
+ // The inputted blockHash does not change the tests since the mocked data is all based
55
+ // on block 14815152
56
+ await palletsStakingValidatorsService.derivePalletStakingValidators(mock_1.blockHash789629))).toStrictEqual(fetchValidators14815152_json_1.default);
57
+ });
58
+ });
59
+ });
60
+ //# sourceMappingURL=PalletsStakingValidatorsService.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PalletsStakingValidatorsService.spec.js","sourceRoot":"","sources":["../../../../src/services/pallets/PalletsStakingValidatorsService.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,oEAAiE;AACjE,8DAAsE;AACtE,+CAAuE;AACvE,iGAAuF;AACvF,2FAAwF;AACxF,kIAAqG;AACrG,uFAAoF;AAEpF,MAAM,YAAY,GAAG,GAAG,EAAE,CACzB,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAC3B,kCAAqB,CAAC,UAAU,CAAC,kBAAkB,EAAE,6CAAqB,CAAC,CAC3E,CAAC;AAEH,MAAM,mBAAmB,GAAG,GAAG,EAAE,CAChC,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAA,4CAAiB,GAAE,CAAC,CAAC;AAEnD,MAAM,eAAe,GAAG;IACvB,KAAK,EAAE;QACN,OAAO,EAAE;YACR,UAAU,EAAE,YAAY;SACxB;QACD,OAAO,EAAE;YACR,UAAU,EAAE;gBACX,OAAO,EAAE,mBAAmB;aAC5B;SACD;KACD;CACsC,CAAC;AAEzC,MAAM,OAAO,GAAG;IACf,GAAG,qBAAc;IACjB,EAAE,EAAE,CAAC,KAAW,EAAE,EAAE,CAAC,eAAe;CACX,CAAC;AAC3B;;GAEG;AACH,MAAM,+BAA+B,GAAG,IAAI,iEAA+B,CAC1E,OAAO,CACP,CAAC;AAEF,QAAQ,CAAC,iCAAiC,EAAE,GAAG,EAAE;IAChD,QAAQ,CAAC,+BAA+B,EAAE,GAAG,EAAE;QAC9C,EAAE,CAAC,0BAA0B,EAAE,KAAK,IAAI,EAAE;YACzC,MAAM,CACL,IAAA,iCAAe;YACd,sFAAsF;YACtF,oBAAoB;YACpB,MAAM,+BAA+B,CAAC,6BAA6B,CAClE,sBAAe,CACf,CACD,CACD,CAAC,aAAa,CAAC,sCAAuB,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -1,3 +1,4 @@
1
+ import { IAt } from './At';
1
2
  export interface IValidator {
2
3
  /**
3
4
  * Address of the validator.
@@ -11,5 +12,7 @@ export interface IValidator {
11
12
  status: string;
12
13
  }
13
14
  export interface IPalletStakingValidator {
15
+ at: IAt;
14
16
  validators: IValidator[];
17
+ validatorsToBeChilled: IValidator[];
15
18
  }
package/package.json CHANGED
@@ -1,5 +1,5 @@
1
1
  {
2
- "version": "14.5.1",
2
+ "version": "14.5.3",
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",