@substrate/api-sidecar 19.1.0 → 19.2.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.
Files changed (57) hide show
  1. package/README.md +29 -22
  2. package/build/package.json +8 -7
  3. package/build/src/SidecarConfig.js +9 -1
  4. package/build/src/SidecarConfig.js.map +1 -1
  5. package/build/src/Specs.d.ts +1 -0
  6. package/build/src/Specs.js +34 -1
  7. package/build/src/Specs.js.map +1 -1
  8. package/build/src/controllers/AbstractController.js.map +1 -1
  9. package/build/src/controllers/blocks/BlocksController.d.ts +2 -0
  10. package/build/src/controllers/blocks/BlocksController.js +87 -8
  11. package/build/src/controllers/blocks/BlocksController.js.map +1 -1
  12. package/build/src/controllers/blocks/BlocksExtrinsicsController.d.ts +1 -0
  13. package/build/src/controllers/blocks/BlocksExtrinsicsController.js +13 -2
  14. package/build/src/controllers/blocks/BlocksExtrinsicsController.js.map +1 -1
  15. package/build/src/controllers/blocks/BlocksRawExtrinsicsController.js +12 -3
  16. package/build/src/controllers/blocks/BlocksRawExtrinsicsController.js.map +1 -1
  17. package/build/src/logging/Log.js +11 -0
  18. package/build/src/logging/Log.js.map +1 -1
  19. package/build/src/main.js +5 -5
  20. package/build/src/main.js.map +1 -1
  21. package/build/src/{util/metrics.d.ts → metrics/Metrics.d.ts} +3 -8
  22. package/build/src/{util/metrics.js → metrics/Metrics.js} +20 -139
  23. package/build/src/metrics/Metrics.js.map +1 -0
  24. package/build/src/metrics/config.d.ts +2 -0
  25. package/build/src/metrics/config.js +71 -0
  26. package/build/src/metrics/config.js.map +1 -0
  27. package/build/src/metrics/index.d.ts +2 -0
  28. package/build/src/metrics/index.js +33 -0
  29. package/build/src/metrics/index.js.map +1 -0
  30. package/build/src/parseArgs.js +0 -13
  31. package/build/src/parseArgs.js.map +1 -1
  32. package/build/src/services/accounts/AccountsAssetsService.js +1 -2
  33. package/build/src/services/accounts/AccountsAssetsService.js.map +1 -1
  34. package/build/src/services/accounts/AccountsPoolAssetsService.js +1 -2
  35. package/build/src/services/accounts/AccountsPoolAssetsService.js.map +1 -1
  36. package/build/src/services/accounts/AccountsStakingPayoutsService.js +4 -2
  37. package/build/src/services/accounts/AccountsStakingPayoutsService.js.map +1 -1
  38. package/build/src/services/blocks/BlocksService.d.ts +1 -3
  39. package/build/src/services/blocks/BlocksService.js +16 -26
  40. package/build/src/services/blocks/BlocksService.js.map +1 -1
  41. package/build/src/services/blocks/BlocksService.spec.js +6 -67
  42. package/build/src/services/blocks/BlocksService.spec.js.map +1 -1
  43. package/build/src/services/pallets/PalletsStakingProgressService.js +3 -3
  44. package/build/src/services/pallets/PalletsStakingProgressService.js.map +1 -1
  45. package/build/src/types/metrics/index.d.ts +13 -0
  46. package/build/src/types/metrics/index.js +3 -0
  47. package/build/src/types/metrics/index.js.map +1 -0
  48. package/build/src/types/requests.d.ts +17 -0
  49. package/build/src/types/sidecar-config/CONFIG.d.ts +7 -1
  50. package/build/src/types/sidecar-config/CONFIG.js +6 -0
  51. package/build/src/types/sidecar-config/CONFIG.js.map +1 -1
  52. package/build/src/types/sidecar-config/MODULES.d.ts +2 -1
  53. package/build/src/types/sidecar-config/MODULES.js +1 -0
  54. package/build/src/types/sidecar-config/MODULES.js.map +1 -1
  55. package/build/src/types/sidecar-config/SidecarConfig.d.ts +9 -0
  56. package/package.json +8 -7
  57. package/build/src/util/metrics.js.map +0 -1
package/build/src/main.js CHANGED
@@ -52,11 +52,11 @@ const App_1 = __importDefault(require("./App"));
52
52
  const chains_config_1 = require("./chains-config");
53
53
  const consoleOverride_1 = require("./logging/consoleOverride");
54
54
  const Log_1 = require("./logging/Log");
55
+ const index_1 = require("./metrics/index");
55
56
  const middleware = __importStar(require("./middleware"));
56
57
  const typesBundle_1 = __importDefault(require("./override-types/typesBundle"));
57
58
  const parseArgs_1 = require("./parseArgs");
58
59
  const SidecarConfig_1 = require("./SidecarConfig");
59
- const metrics_1 = __importDefault(require("./util/metrics"));
60
60
  async function main() {
61
61
  const { config } = SidecarConfig_1.SidecarConfig;
62
62
  const { logger } = Log_1.Log;
@@ -83,11 +83,11 @@ async function main() {
83
83
  ]);
84
84
  startUpPrompt(config.SUBSTRATE.URL, chainName.toString(), implName.toString());
85
85
  const preMiddlewares = [(0, express_1.json)(), middleware.httpLoggerCreate(logger)];
86
- if (args.prometheus) {
86
+ if (config.METRICS.ENABLED) {
87
87
  // Create Metrics App
88
- const metricsApp = new metrics_1.default({
89
- port: 9100,
90
- host: config.EXPRESS.HOST,
88
+ const metricsApp = new index_1.MetricsApp({
89
+ port: config.METRICS.PROM_PORT,
90
+ host: config.METRICS.PROM_HOST,
91
91
  });
92
92
  // Generate metrics middleware
93
93
  preMiddlewares.push(metricsApp.preMiddleware());
@@ -1 +1 @@
1
- {"version":3,"file":"main.js","sourceRoot":"","sources":["../../src/main.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"main.js","sourceRoot":"","sources":["../../src/main.ts"],"names":[],"mappings":"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"}
@@ -1,14 +1,9 @@
1
1
  import { Request, Response } from 'express';
2
+ import client from 'prom-client';
2
3
  interface IAppConfiguration {
3
4
  port: number;
4
5
  host: string;
5
6
  }
6
- export declare const enum MetricType {
7
- Counter = "counter",
8
- Gauge = "gauge",
9
- Histogram = "histogram",
10
- Summary = "summary"
11
- }
12
7
  interface Query extends Request {
13
8
  route: {
14
9
  path: string;
@@ -25,11 +20,11 @@ export default class Metrics_App {
25
20
  /**
26
21
  * @param appConfig configuration for app.
27
22
  */
28
- constructor({ host }: IAppConfiguration);
23
+ constructor({ host, port }: IAppConfiguration);
29
24
  listen(): void;
25
+ getRegisteredMetrics(): Record<string, client.Metric>;
30
26
  private createMetricByType;
31
27
  private getRoute;
32
- private blocksControllerMetrics;
33
28
  preMiddleware(): (req: Query, res: Response, next: () => void) => void;
34
29
  private init;
35
30
  }
@@ -6,81 +6,15 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const express_1 = __importDefault(require("express"));
7
7
  const prom_client_1 = __importDefault(require("prom-client"));
8
8
  const Log_1 = require("../logging/Log");
9
- const parseArgs_1 = require("../parseArgs");
10
- const metrics = [
11
- {
12
- name: 'request_errors_total',
13
- help: 'Number of HTTP Errors',
14
- type: "counter" /* MetricType.Counter */,
15
- },
16
- {
17
- name: 'request_success_total',
18
- help: 'Number of HTTP Success',
19
- type: "counter" /* MetricType.Counter */,
20
- },
21
- {
22
- name: 'requests_total',
23
- help: 'Total number of HTTP Requests',
24
- type: "counter" /* MetricType.Counter */,
25
- },
26
- {
27
- name: 'request_duration_seconds',
28
- help: 'Duration of HTTP requests in seconds',
29
- labels: ['method', 'route', 'status_code'],
30
- buckets: [0.1, 0.5, 1, 1.5, 2, 3, 4, 5],
31
- type: "histogram" /* MetricType.Histogram */,
32
- },
33
- {
34
- name: 'response_size_bytes_seconds',
35
- help: 'Size of HTTP responses in bytes',
36
- labels: ['method', 'route', 'status_code'],
37
- buckets: [100, 500, 1000, 5000, 10000, 50000, 100000, 500000, 1000000, 5000000],
38
- type: "histogram" /* MetricType.Histogram */,
39
- },
40
- {
41
- name: 'response_size_latency_ratio_seconds',
42
- help: 'Ratio of response size to latency',
43
- labels: ['method', 'route', 'status_code'],
44
- buckets: [64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768, 65536, 131072, 262144],
45
- type: "histogram" /* MetricType.Histogram */,
46
- },
47
- {
48
- name: 'extrinsics_in_request_count',
49
- help: 'Number of extrinsics in a request',
50
- type: "histogram" /* MetricType.Histogram */,
51
- buckets: [5, 10, 20, 40, 80, 160, 320, 640, 1280, 2560, 5120, 10240, 20480],
52
- labels: ['method', 'route', 'status_code'],
53
- },
54
- {
55
- name: 'extrinsics_per_second_count',
56
- help: 'Number of extrinsics per second',
57
- type: "histogram" /* MetricType.Histogram */,
58
- labels: ['method', 'route', 'status_code'],
59
- buckets: [1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024],
60
- },
61
- {
62
- name: 'extrinsics_per_block_count',
63
- help: 'Average number of extrinsics per block',
64
- type: "histogram" /* MetricType.Histogram */,
65
- labels: ['method', 'route', 'status_code'],
66
- buckets: [1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024],
67
- },
68
- {
69
- name: 'seconds_per_block_count',
70
- help: 'Average seconds per block',
71
- type: "histogram" /* MetricType.Histogram */,
72
- labels: ['method', 'route', 'status_code'],
73
- buckets: [1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024],
74
- },
75
- ];
9
+ const SidecarConfig_1 = require("../SidecarConfig");
10
+ const _1 = require(".");
76
11
  class Metrics_App {
77
12
  /**
78
13
  * @param appConfig configuration for app.
79
14
  */
80
- constructor({ host }) {
81
- const args = (0, parseArgs_1.parseArgs)();
82
- this.includeQueryParams = !!args.prometheus_queryparams;
83
- this.port = Number(args.prometheus_port);
15
+ constructor({ host, port }) {
16
+ this.includeQueryParams = SidecarConfig_1.SidecarConfig.config.METRICS.INCLUDE_QUERYPARAMS;
17
+ this.port = port;
84
18
  this.app = (0, express_1.default)();
85
19
  this.host = host;
86
20
  this.registry = new prom_client_1.default.Registry();
@@ -93,6 +27,9 @@ class Metrics_App {
93
27
  logger.info(`Metrics Server started at http://${this.host}:${this.port}/metrics`);
94
28
  });
95
29
  }
30
+ getRegisteredMetrics() {
31
+ return this.metrics;
32
+ }
96
33
  createMetricByType(prefix = 'sas', metric) {
97
34
  const prefixedName = prefix + '_' + metric.name;
98
35
  if (prefixedName in this.metrics) {
@@ -164,72 +101,19 @@ class Metrics_App {
164
101
  }
165
102
  return route;
166
103
  }
167
- blocksControllerMetrics(req, res, end) {
168
- var _a, _b;
169
- const body = res.locals.body;
170
- if (((_a = req.params) === null || _a === void 0 ? void 0 : _a.number) && !Array.isArray(body)) {
171
- const extrinscs = body.extrinsics ? body.extrinsics.length : 0;
172
- const extrinsics_per_second = this.metrics['sas_extrinsics_per_second_count'];
173
- const seconds = end();
174
- extrinsics_per_second
175
- .labels({ method: req.method, route: this.getRoute(req), status_code: res.statusCode })
176
- .observe(extrinscs / seconds);
177
- const extrinsics_per_block = this.metrics['sas_extrinsics_per_block_count'];
178
- const blocks = 1;
179
- extrinsics_per_block
180
- .labels({ method: req.method, route: this.getRoute(req), status_code: res.statusCode })
181
- .observe(extrinscs / blocks);
182
- const seconds_per_block = this.metrics['sas_seconds_per_block_count'];
183
- seconds_per_block
184
- .labels({ method: req.method, route: this.getRoute(req), status_code: res.statusCode })
185
- .observe(seconds / blocks);
186
- }
187
- if ((_b = req.query) === null || _b === void 0 ? void 0 : _b.range) {
188
- let totExtrinsics = 0;
189
- if (Array.isArray(body)) {
190
- totExtrinsics = body.reduce((current, block) => {
191
- const extrinsics = block['extrinsics'];
192
- if (Array.isArray(extrinsics)) {
193
- return current + extrinsics.length;
194
- }
195
- return current;
196
- }, 0);
197
- }
198
- else {
199
- const extrinsics = body['extrinsics'];
200
- if (Array.isArray(extrinsics)) {
201
- totExtrinsics = extrinsics.length;
202
- }
203
- }
204
- const extrinsics_in_request = this.metrics['sas_extrinsics_in_request_count'];
205
- extrinsics_in_request
206
- .labels({ method: req.method, route: this.getRoute(req), status_code: res.statusCode })
207
- .observe(totExtrinsics);
208
- const extrinsics_per_second = this.metrics['sas_extrinsics_per_second_count'];
209
- const seconds = end();
210
- extrinsics_per_second
211
- .labels({ method: req.method, route: this.getRoute(req), status_code: res.statusCode })
212
- .observe(totExtrinsics / seconds);
213
- const extrinsics_per_block = this.metrics['sas_extrinsics_per_block_count'];
214
- const blocks = Array.isArray(body) ? body.length : 1;
215
- extrinsics_per_block
216
- .labels({ method: req.method, route: this.getRoute(req), status_code: res.statusCode })
217
- .observe(totExtrinsics / blocks);
218
- const seconds_per_block = this.metrics['sas_seconds_per_block_count'];
219
- seconds_per_block
220
- .labels({ method: req.method, route: this.getRoute(req), status_code: res.statusCode })
221
- .observe(seconds / blocks);
222
- }
223
- }
224
104
  preMiddleware() {
225
105
  return (req, res, next) => {
226
- const tot_requests = this.metrics['sas_requests_total'];
106
+ const tot_requests = this.metrics['sas_http_requests'];
227
107
  // request count metrics
228
108
  if (req.originalUrl != '/favicon.ico') {
229
109
  tot_requests.inc();
230
110
  }
231
111
  const request_duration_seconds = this.metrics['sas_request_duration_seconds'];
232
112
  const end = request_duration_seconds.startTimer();
113
+ res.locals.metrics = {
114
+ timer: end,
115
+ registry: this.metrics,
116
+ };
233
117
  const oldJson = res.json;
234
118
  res.json = (body) => {
235
119
  res.locals.body = body;
@@ -237,11 +121,11 @@ class Metrics_App {
237
121
  };
238
122
  res.once('finish', () => {
239
123
  if (res.statusCode >= 400 && req.originalUrl != '/favicon.ico') {
240
- const request_errors = this.metrics['sas_request_errors'];
124
+ const request_errors = this.metrics['sas_http_request_error'];
241
125
  request_errors.inc();
242
126
  }
243
127
  else if (res.statusCode < 400) {
244
- const request_success = this.metrics['sas_request_errors_total'];
128
+ const request_success = this.metrics['sas_http_request_success'];
245
129
  request_success.inc();
246
130
  }
247
131
  let resContentLength = '0';
@@ -251,19 +135,16 @@ class Metrics_App {
251
135
  else if (res.hasHeader('Content-Length')) {
252
136
  resContentLength = res.getHeader('Content-Length');
253
137
  }
254
- // route specific metrics
255
- if (this.getRoute(req).includes('blocks')) {
256
- this.blocksControllerMetrics(req, res, end);
257
- }
138
+ // Generic Metrics per route (latency, response size, response size to latency ratio)
258
139
  // response size metrics
259
- const response_size_bytes = this.metrics['sas_response_size_bytes_seconds'];
140
+ const response_size_bytes = this.metrics['sas_response_size_bytes'];
260
141
  response_size_bytes
261
142
  .labels({ method: req.method, route: this.getRoute(req), status_code: res.statusCode })
262
143
  .observe(parseFloat(resContentLength));
263
144
  // latency metrics
264
145
  const latency = end({ method: req.method, route: this.getRoute(req), status_code: res.statusCode });
265
146
  // response size to latency ratio
266
- const response_size_latency_ratio = this.metrics['sas_response_size_latency_ratio_seconds'];
147
+ const response_size_latency_ratio = this.metrics['sas_response_size_bytes_seconds'];
267
148
  response_size_latency_ratio
268
149
  .labels({ method: req.method, route: this.getRoute(req), status_code: res.statusCode })
269
150
  .observe(parseFloat(resContentLength) / latency);
@@ -273,7 +154,7 @@ class Metrics_App {
273
154
  }
274
155
  init() {
275
156
  // Set up
276
- metrics.forEach((metric) => this.createMetricByType('sas', metric));
157
+ _1.config.metric_list.forEach((metric) => this.createMetricByType('sas', metric));
277
158
  prom_client_1.default.collectDefaultMetrics({ register: this.registry, prefix: 'sas_' });
278
159
  // Set up the metrics endpoint
279
160
  this.app.get('/metrics', (_req, res) => {
@@ -291,4 +172,4 @@ class Metrics_App {
291
172
  }
292
173
  }
293
174
  exports.default = Metrics_App;
294
- //# sourceMappingURL=metrics.js.map
175
+ //# sourceMappingURL=Metrics.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Metrics.js","sourceRoot":"","sources":["../../../src/metrics/Metrics.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { IMetric } from '../types/metrics';
2
+ export declare const metric_list: IMetric[];
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ // as new metrics are added in routes they need to be registered here to make them available across the apps
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.metric_list = void 0;
5
+ exports.metric_list = [
6
+ {
7
+ name: 'http_request_error',
8
+ help: 'Number of HTTP Errors',
9
+ type: "counter" /* MetricType.Counter */,
10
+ },
11
+ {
12
+ name: 'http_request_success',
13
+ help: 'Number of HTTP Success',
14
+ type: "counter" /* MetricType.Counter */,
15
+ },
16
+ {
17
+ name: 'http_requests',
18
+ help: 'Total number of HTTP Requests',
19
+ type: "counter" /* MetricType.Counter */,
20
+ },
21
+ {
22
+ name: 'request_duration_seconds',
23
+ help: 'Duration of HTTP requests in seconds',
24
+ labels: ['method', 'route', 'status_code'],
25
+ buckets: [0.1, 0.5, 1, 1.5, 2, 3, 4, 5],
26
+ type: "histogram" /* MetricType.Histogram */,
27
+ },
28
+ {
29
+ name: 'response_size_bytes',
30
+ help: 'Size of HTTP responses in bytes',
31
+ labels: ['method', 'route', 'status_code'],
32
+ buckets: [100, 500, 1000, 5000, 10000, 50000, 100000, 500000, 1000000, 5000000],
33
+ type: "histogram" /* MetricType.Histogram */,
34
+ },
35
+ {
36
+ name: 'response_size_bytes_seconds',
37
+ help: 'Ratio of response size to latency',
38
+ labels: ['method', 'route', 'status_code'],
39
+ buckets: [64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768, 65536, 131072, 262144],
40
+ type: "histogram" /* MetricType.Histogram */,
41
+ },
42
+ {
43
+ name: 'extrinsics_in_request',
44
+ help: 'Number of extrinsics in a request',
45
+ type: "histogram" /* MetricType.Histogram */,
46
+ buckets: [5, 10, 20, 40, 80, 160, 320, 640, 1280, 2560, 5120, 10240, 20480],
47
+ labels: ['method', 'route', 'status_code'],
48
+ },
49
+ {
50
+ name: 'extrinsics_per_second',
51
+ help: 'Number of extrinsics per second',
52
+ type: "histogram" /* MetricType.Histogram */,
53
+ labels: ['method', 'route', 'status_code'],
54
+ buckets: [1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024],
55
+ },
56
+ {
57
+ name: 'extrinsics_per_block',
58
+ help: 'Average number of extrinsics per block',
59
+ type: "histogram" /* MetricType.Histogram */,
60
+ labels: ['method', 'route', 'status_code'],
61
+ buckets: [1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024],
62
+ },
63
+ {
64
+ name: 'seconds_per_block',
65
+ help: 'Average seconds per block',
66
+ type: "histogram" /* MetricType.Histogram */,
67
+ labels: ['method', 'route', 'status_code'],
68
+ buckets: [1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024],
69
+ },
70
+ ];
71
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/metrics/config.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * as config from './config';
2
+ export { default as MetricsApp } from './Metrics';
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.MetricsApp = exports.config = void 0;
30
+ exports.config = __importStar(require("./config"));
31
+ var Metrics_1 = require("./Metrics");
32
+ Object.defineProperty(exports, "MetricsApp", { enumerable: true, get: function () { return __importDefault(Metrics_1).default; } });
33
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/metrics/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mDAAmC;AACnC,qCAAkD;AAAzC,sHAAA,OAAO,OAAc"}
@@ -23,19 +23,6 @@ const parseArgs = () => {
23
23
  action: 'store_true',
24
24
  help: 'print substrate-api-sidecar version',
25
25
  });
26
- parser.add_argument('-p', '--prometheus', {
27
- action: 'store_true',
28
- help: 'enable the prometheus metrics endpoint',
29
- });
30
- parser.add_argument('-pp', '--prometheus-port', {
31
- type: 'int',
32
- default: 9100,
33
- help: 'specify the port number on which the prometheus metrics are exposed [default: 9100]',
34
- });
35
- parser.add_argument('-pq', '--prometheus-queryparams', {
36
- action: 'store_true',
37
- help: 'enambles query parameters in the prometheus metrics',
38
- });
39
26
  return parser.parse_args();
40
27
  };
41
28
  exports.parseArgs = parseArgs;
@@ -1 +1 @@
1
- {"version":3,"file":"parseArgs.js","sourceRoot":"","sources":["../../src/parseArgs.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,uCAAqD;AAE9C,MAAM,SAAS,GAAG,GAAc,EAAE;IACxC,MAAM,MAAM,GAAG,IAAI,yBAAc,EAAE,CAAC;IAEpC,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,WAAW,EAAE;QACtC,MAAM,EAAE,YAAY;QACpB,IAAI,EAAE,qCAAqC;KAC3C,CAAC,CAAC;IACH,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,cAAc,EAAE;QACzC,MAAM,EAAE,YAAY;QACpB,IAAI,EAAE,wCAAwC;KAC9C,CAAC,CAAC;IACH,MAAM,CAAC,YAAY,CAAC,KAAK,EAAE,mBAAmB,EAAE;QAC/C,IAAI,EAAE,KAAK;QACX,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,qFAAqF;KAC3F,CAAC,CAAC;IACH,MAAM,CAAC,YAAY,CAAC,KAAK,EAAE,0BAA0B,EAAE;QACtD,MAAM,EAAE,YAAY;QACpB,IAAI,EAAE,qDAAqD;KAC3D,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC,UAAU,EAAe,CAAC;AACzC,CAAC,CAAC;AAtBW,QAAA,SAAS,aAsBpB"}
1
+ {"version":3,"file":"parseArgs.js","sourceRoot":"","sources":["../../src/parseArgs.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,uCAAqD;AAE9C,MAAM,SAAS,GAAG,GAAc,EAAE;IACxC,MAAM,MAAM,GAAG,IAAI,yBAAc,EAAE,CAAC;IAEpC,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,WAAW,EAAE;QACtC,MAAM,EAAE,YAAY;QACpB,IAAI,EAAE,qCAAqC;KAC3C,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC,UAAU,EAAe,CAAC;AACzC,CAAC,CAAC;AATW,QAAA,SAAS,aASpB"}
@@ -31,10 +31,9 @@ class AccountsAssetsService extends AbstractService_1.AbstractService {
31
31
  */
32
32
  async fetchAssetBalances(hash, address, assets) {
33
33
  const { api } = this;
34
- const historicApi = await api.at(hash);
34
+ const [historicApi, { number }] = await Promise.all([api.at(hash), api.rpc.chain.getHeader(hash)]);
35
35
  // Check if this runtime has the assets pallet
36
36
  this.checkAssetsError(historicApi);
37
- const { number } = await api.rpc.chain.getHeader(hash);
38
37
  let response;
39
38
  if (assets.length === 0) {
40
39
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"AccountsAssetsService.js","sourceRoot":"","sources":["../../../../src/services/accounts/AccountsAssetsService.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"AccountsAssetsService.js","sourceRoot":"","sources":["../../../../src/services/accounts/AccountsAssetsService.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,6CAAyC;AAGzC,wDAAqD;AA6BrD,MAAa,qBAAsB,SAAQ,iCAAe;IACzD;;;;;;;;;OASG;IACH,KAAK,CAAC,kBAAkB,CAAC,IAAe,EAAE,OAAe,EAAE,MAAgB;QAC1E,MAAM,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;QACrB,MAAM,CAAC,WAAW,EAAE,EAAE,MAAM,EAAE,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACnG,8CAA8C;QAC9C,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC;QAEnC,IAAI,QAAQ,CAAC;QACb,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;YACxB;;eAEG;YACH,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YACzD,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;YAE5C,QAAQ,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;SAClE;aAAM;YACN;;eAEG;YACH,QAAQ,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;SAChE;QAED,MAAM,EAAE,GAAG;YACV,IAAI;YACJ,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC;SACpC,CAAC;QAEF,OAAO;YACN,EAAE;YACF,MAAM,EAAE,QAAQ;SAChB,CAAC;IACH,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,kBAAkB,CACvB,IAAe,EACf,OAAe,EACf,OAAe,EACf,QAAgB;QAEhB,MAAM,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;QACrB,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAEvC,8CAA8C;QAC9C,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC;QAEnC,MAAM,CAAC,EAAE,MAAM,EAAE,EAAE,aAAa,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YACrD,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC;YAC7B,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,CAAC;SAC9D,CAAC,CAAC,KAAK,CAAC,CAAC,GAAU,EAAE,EAAE;YACvB,MAAM,IAAI,CAAC,sBAAsB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;QAEH,IAAI,MAAM,GAAG,IAAI,EAChB,OAAO,GAAG,IAAI,CAAC;QAChB,IAAI,aAAa,CAAC,MAAM,EAAE;YACzB,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,aAAa,CAAC,MAAM,EAAE,CAAC,CAAC;SAC/C;QAED,MAAM,EAAE,GAAG;YACV,IAAI;YACJ,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC;SACpC,CAAC;QAEF,OAAO;YACN,EAAE;YACF,MAAM;YACN,OAAO;SACP,CAAC;IACH,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,WAAW,CAChB,WAAqC,EACrC,MAA4B,EAC5B,OAAe;QAEf,OAAO,OAAO,CAAC,GAAG,CACjB,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,OAAyB,EAAE,EAAE;YAC9C,MAAM,YAAY,GAAG,MAAM,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;YAE9E;;eAEG;YAEH,wEAAwE;YACxE,sFAAsF;YACtF,IAAI,YAAY,CAAC,MAAM,EAAE;gBACxB,MAAM,YAAY,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC;gBAE3C,IAAI,QAAuB,CAAC;gBAC5B,IAAI,UAAU,IAAI,YAAY,EAAE;oBAC/B,QAAQ,GAAG,YAAY,CAAC,QAAgB,CAAC;iBACzC;qBAAM;oBACN,QAAQ,GAAG,0CAA0C,CAAC;iBACtD;gBAED,OAAO;oBACN,OAAO;oBACP,OAAO,EAAE,YAAY,CAAC,OAAO;oBAC7B,QAAQ,EAAE,QAAQ;oBAClB,YAAY,EAAE,YAAY,CAAC,MAAM,CAAC,YAAY;iBAC9C,CAAC;aACF;YAED,gGAAgG;YAChG,yBAAyB;YACzB,IAAK,YAAoD,CAAC,UAAU,EAAE;gBACrE,MAAM,YAAY,GAAG,YAAmD,CAAC;gBAEzE,OAAO;oBACN,OAAO;oBACP,OAAO,EAAE,YAAY,CAAC,OAAO;oBAC7B,QAAQ,EAAE,YAAY,CAAC,QAAQ;oBAC/B,YAAY,EAAE,YAAY,CAAC,UAAU;iBACrC,CAAC;aACF;YAED,6FAA6F;YAC7F,mBAAmB;YACnB,IAAI,YAAY,CAAC,cAAc,CAAS,EAAE;gBACzC,MAAM,YAAY,GAAG,YAAyD,CAAC;gBAE/E,OAAO;oBACN,OAAO;oBACP,OAAO,EAAE,YAAY,CAAC,OAAO;oBAC7B,QAAQ,EAAE,YAAY,CAAC,QAAQ;oBAC/B,YAAY,EAAE,YAAY,CAAC,YAAY;iBACvC,CAAC;aACF;YAED;;;;;eAKG;YACH,OAAO;gBACN,OAAO;gBACP,OAAO,EAAE,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;gBACnD,QAAQ,EAAE,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAC,MAAM,EAAE,KAAK,CAAC;gBACxD,YAAY,EAAE,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAC,MAAM,EAAE,KAAK,CAAC;aAC5D,CAAC;QACH,CAAC,CAAC,CACF,CAAC,KAAK,CAAC,CAAC,GAAU,EAAE,EAAE;YACtB,MAAM,IAAI,CAAC,sBAAsB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,eAAe,CAAC,IAA6B;QAC5C,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC;IACnD,CAAC;IAED;;;;;OAKG;IACK,gBAAgB,CAAC,WAAqC;QAC7D,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,MAAM,EAAE;YAC9B,MAAM,IAAI,wBAAU,CAAC,+DAA+D,CAAC,CAAC;SACtF;IACF,CAAC;CACD;AAjMD,sDAiMC"}
@@ -31,10 +31,9 @@ class AccountsPoolAssetsService extends AbstractService_1.AbstractService {
31
31
  */
32
32
  async fetchPoolAssetBalances(hash, address, assets) {
33
33
  const { api } = this;
34
- const historicApi = await api.at(hash);
34
+ const [historicApi, { number }] = await Promise.all([api.at(hash), api.rpc.chain.getHeader(hash)]);
35
35
  // Check if this runtime has the PoolAssets pallet
36
36
  this.checkPoolAssetsError(historicApi);
37
- const { number } = await api.rpc.chain.getHeader(hash);
38
37
  let response;
39
38
  if (assets.length === 0) {
40
39
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"AccountsPoolAssetsService.js","sourceRoot":"","sources":["../../../../src/services/accounts/AccountsPoolAssetsService.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"AccountsPoolAssetsService.js","sourceRoot":"","sources":["../../../../src/services/accounts/AccountsPoolAssetsService.ts"],"names":[],"mappings":"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"}
@@ -162,8 +162,10 @@ class AccountsStakingPayoutsService extends AbstractService_1.AbstractService {
162
162
  ? await this.api.rpc.chain.getBlockHash(earlyErasBlockInfo[0].end)
163
163
  : await this.api.rpc.chain.getBlockHash(earlyErasBlockInfo[era - 1].end);
164
164
  let reward = historicApi.registry.createType('Option<u128>');
165
- const blockInfo = await this.api.rpc.chain.getBlock(nextEraStartBlockHash);
166
- const allRecords = await historicApi.query.system.events();
165
+ const [blockInfo, allRecords] = await Promise.all([
166
+ this.api.rpc.chain.getBlock(nextEraStartBlockHash),
167
+ historicApi.query.system.events(),
168
+ ]);
167
169
  blockInfo.block.extrinsics.forEach((index) => {
168
170
  allRecords
169
171
  .filter(({ phase }) => phase.isApplyExtrinsic && phase.asApplyExtrinsic.eq(index))