@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.
- package/README.md +29 -22
- package/build/package.json +8 -7
- package/build/src/SidecarConfig.js +9 -1
- package/build/src/SidecarConfig.js.map +1 -1
- package/build/src/Specs.d.ts +1 -0
- package/build/src/Specs.js +34 -1
- package/build/src/Specs.js.map +1 -1
- package/build/src/controllers/AbstractController.js.map +1 -1
- package/build/src/controllers/blocks/BlocksController.d.ts +2 -0
- package/build/src/controllers/blocks/BlocksController.js +87 -8
- package/build/src/controllers/blocks/BlocksController.js.map +1 -1
- package/build/src/controllers/blocks/BlocksExtrinsicsController.d.ts +1 -0
- package/build/src/controllers/blocks/BlocksExtrinsicsController.js +13 -2
- package/build/src/controllers/blocks/BlocksExtrinsicsController.js.map +1 -1
- package/build/src/controllers/blocks/BlocksRawExtrinsicsController.js +12 -3
- package/build/src/controllers/blocks/BlocksRawExtrinsicsController.js.map +1 -1
- package/build/src/logging/Log.js +11 -0
- package/build/src/logging/Log.js.map +1 -1
- package/build/src/main.js +5 -5
- package/build/src/main.js.map +1 -1
- package/build/src/{util/metrics.d.ts → metrics/Metrics.d.ts} +3 -8
- package/build/src/{util/metrics.js → metrics/Metrics.js} +20 -139
- package/build/src/metrics/Metrics.js.map +1 -0
- package/build/src/metrics/config.d.ts +2 -0
- package/build/src/metrics/config.js +71 -0
- package/build/src/metrics/config.js.map +1 -0
- package/build/src/metrics/index.d.ts +2 -0
- package/build/src/metrics/index.js +33 -0
- package/build/src/metrics/index.js.map +1 -0
- package/build/src/parseArgs.js +0 -13
- package/build/src/parseArgs.js.map +1 -1
- package/build/src/services/accounts/AccountsAssetsService.js +1 -2
- package/build/src/services/accounts/AccountsAssetsService.js.map +1 -1
- package/build/src/services/accounts/AccountsPoolAssetsService.js +1 -2
- package/build/src/services/accounts/AccountsPoolAssetsService.js.map +1 -1
- package/build/src/services/accounts/AccountsStakingPayoutsService.js +4 -2
- package/build/src/services/accounts/AccountsStakingPayoutsService.js.map +1 -1
- package/build/src/services/blocks/BlocksService.d.ts +1 -3
- package/build/src/services/blocks/BlocksService.js +16 -26
- package/build/src/services/blocks/BlocksService.js.map +1 -1
- package/build/src/services/blocks/BlocksService.spec.js +6 -67
- package/build/src/services/blocks/BlocksService.spec.js.map +1 -1
- package/build/src/services/pallets/PalletsStakingProgressService.js +3 -3
- package/build/src/services/pallets/PalletsStakingProgressService.js.map +1 -1
- package/build/src/types/metrics/index.d.ts +13 -0
- package/build/src/types/metrics/index.js +3 -0
- package/build/src/types/metrics/index.js.map +1 -0
- package/build/src/types/requests.d.ts +17 -0
- package/build/src/types/sidecar-config/CONFIG.d.ts +7 -1
- package/build/src/types/sidecar-config/CONFIG.js +6 -0
- package/build/src/types/sidecar-config/CONFIG.js.map +1 -1
- package/build/src/types/sidecar-config/MODULES.d.ts +2 -1
- package/build/src/types/sidecar-config/MODULES.js +1 -0
- package/build/src/types/sidecar-config/MODULES.js.map +1 -1
- package/build/src/types/sidecar-config/SidecarConfig.d.ts +9 -0
- package/package.json +8 -7
- 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 (
|
|
86
|
+
if (config.METRICS.ENABLED) {
|
|
87
87
|
// Create Metrics App
|
|
88
|
-
const metricsApp = new
|
|
89
|
-
port:
|
|
90
|
-
host: config.
|
|
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());
|
package/build/src/main.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"main.js","sourceRoot":"","sources":["../../src/main.ts"],"names":[],"mappings":";;AAEA,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,yCAAyC;AACzC,iCAA+B;AAE/B,uCAA2C;AAC3C,yDAAkE;AAElE,qCAA+B;AAE/B,mEAA0C;AAC1C,gDAAwB;AACxB,mDAAwD;AACxD,+DAA4D;AAC5D,uCAAoC;AACpC,yDAA2C;AAC3C,+EAA2D;AAC3D,2CAAwC;AACxC,mDAAgD;
|
|
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
|
|
10
|
-
const
|
|
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
|
-
|
|
82
|
-
this.
|
|
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['
|
|
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['
|
|
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['
|
|
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
|
|
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['
|
|
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['
|
|
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
|
-
|
|
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=
|
|
175
|
+
//# sourceMappingURL=Metrics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Metrics.js","sourceRoot":"","sources":["../../../src/metrics/Metrics.ts"],"names":[],"mappings":";;;;;AAAA,sDAA8B;AAE9B,8DAAiC;AAEjC,wCAAqC;AACrC,oDAAiD;AAEjD,wBAA2B;AAmB3B,MAAqB,WAAW;IAQ/B;;OAEG;IACH,YAAY,EAAE,IAAI,EAAE,IAAI,EAAqB;QAC5C,IAAI,CAAC,kBAAkB,GAAG,6BAAa,CAAC,MAAM,CAAC,OAAO,CAAC,mBAAmB,CAAC;QAC3E,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,GAAG,GAAG,IAAA,iBAAO,GAAE,CAAC;QACrB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,QAAQ,GAAG,IAAI,qBAAM,CAAC,QAAQ,EAAE,CAAC;QACtC,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAClB,IAAI,CAAC,IAAI,EAAE,CAAC;IACb,CAAC;IAED,MAAM;QACL,MAAM,EAAE,MAAM,EAAE,GAAG,SAAG,CAAC;QACvB,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,GAAG,EAAE;YAC1C,MAAM,CAAC,IAAI,CAAC,oCAAoC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,UAAU,CAAC,CAAC;QACnF,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,oBAAoB;QACnB,OAAO,IAAI,CAAC,OAAO,CAAC;IACrB,CAAC;IAEO,kBAAkB,CAAC,MAAM,GAAG,KAAK,EAAE,MAAe;QACzD,MAAM,YAAY,GAAG,MAAM,GAAG,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC;QAChD,IAAI,YAAY,IAAI,IAAI,CAAC,OAAO,EAAE;YACjC,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;SAClC;QAED,QAAQ,MAAM,CAAC,IAAI,EAAE;YACpB,uCAAuB,CAAC,CAAC;gBACxB,MAAM,OAAO,GAAG,IAAI,qBAAM,CAAC,OAAO,CAAC;oBAClC,IAAI,EAAE,YAAY;oBAClB,IAAI,EAAE,MAAM,CAAC,IAAI;oBACjB,UAAU,EAAE,MAAM,CAAC,MAAM,IAAI,EAAE;oBAC/B,SAAS,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC;iBAC1B,CAAC,CAAC;gBAEH,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;gBACtC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC;gBACrC,OAAO,OAAO,CAAC;aACf;YACD,2CAAyB,CAAC,CAAC;gBAC1B,MAAM,SAAS,GAAG,IAAI,qBAAM,CAAC,SAAS,CAAC;oBACtC,IAAI,EAAE,YAAY;oBAClB,IAAI,EAAE,MAAM,CAAC,IAAI;oBACjB,UAAU,EAAE,MAAM,CAAC,MAAM,IAAI,EAAE;oBAC/B,SAAS,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC;oBAC1B,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;iBACzD,CAAC,CAAC;gBAEH,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,GAAG,SAAS,CAAC;gBACvC,OAAO,SAAS,CAAC;aACjB;YACD;gBACC,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;YAC1C;gBACC,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;YAC5C;gBACC,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;SACxC;IACF,CAAC;IAEO,QAAQ,CAAC,GAAU;;QAC1B,IAAI,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC;QACxB,IAAI,GAAG,CAAC,KAAK,EAAE;YACd,IAAI,GAAG,CAAC,KAAK,CAAC,IAAI,KAAK,GAAG,EAAE;gBAC3B,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,IAAG,MAAA,GAAG,CAAC,KAAK,0CAAE,IAAI,CAAA,CAAC,CAAC,CAAC,MAAA,GAAG,CAAC,KAAK,0CAAE,IAAI,CAAC;aAC1D;YAED,IAAI,CAAC,KAAK,IAAI,KAAK,KAAK,EAAE,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;gBACxD,KAAK,GAAG,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;aACtC;iBAAM;gBACN,MAAM,aAAa,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBACvC,MAAM,WAAW,GAAG,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBAC7D,MAAM,UAAU,GAAG,WAAW,CAAC,MAAM,GAAG,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;gBAEjE,MAAM,OAAO,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAC3D,KAAK,GAAG,OAAO,GAAG,KAAK,CAAC;aACxB;YAED,IAAI,IAAI,CAAC,kBAAkB,KAAK,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC1E,KAAK,GAAG,GAAG,KAAK,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC;qBACxC,IAAI,EAAE;qBACN,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,GAAG,UAAU,MAAM,CAAC;qBACxC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;aACd;SACD;QAED,IAAI,OAAO,GAAG,CAAC,MAAM,KAAK,QAAQ,EAAE;YACnC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;gBAC7C,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,GAAG,GAAG,SAAS,CAAC,CAAC;YAC/D,CAAC,CAAC,CAAC;SACH;QAED,IAAI,CAAC,KAAK,IAAI,KAAK,KAAK,EAAE,EAAE;YAC3B,qDAAqD;YACrD,KAAK,GAAG,KAAK,CAAC;SACd;QAED,OAAO,KAAK,CAAC;IACd,CAAC;IAED,aAAa;QACZ,OAAO,CAAC,GAAU,EAAE,GAAa,EAAE,IAAgB,EAAE,EAAE;YACtD,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAmB,CAAC;YAEzE,wBAAwB;YACxB,IAAI,GAAG,CAAC,WAAW,IAAI,cAAc,EAAE;gBACtC,YAAY,CAAC,GAAG,EAAE,CAAC;aACnB;YACD,MAAM,wBAAwB,GAAG,IAAI,CAAC,OAAO,CAAC,8BAA8B,CAAqB,CAAC;YAClG,MAAM,GAAG,GAAG,wBAAwB,CAAC,UAAU,EAAE,CAAC;YAElD,GAAG,CAAC,MAAM,CAAC,OAAO,GAAG;gBACpB,KAAK,EAAE,GAAG;gBACV,QAAQ,EAAE,IAAI,CAAC,OAAO;aACtB,CAAC;YAEF,MAAM,OAAO,GAAG,GAAG,CAAC,IAAI,CAAC;YACzB,GAAG,CAAC,IAAI,GAAG,CAAC,IAAU,EAAE,EAAE;gBACzB,GAAG,CAAC,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC;gBACvB,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YAChC,CAAC,CAAC;YAEF,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE;gBACvB,IAAI,GAAG,CAAC,UAAU,IAAI,GAAG,IAAI,GAAG,CAAC,WAAW,IAAI,cAAc,EAAE;oBAC/D,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,wBAAwB,CAAmB,CAAC;oBAChF,cAAc,CAAC,GAAG,EAAE,CAAC;iBACrB;qBAAM,IAAI,GAAG,CAAC,UAAU,GAAG,GAAG,EAAE;oBAChC,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,0BAA0B,CAAmB,CAAC;oBACnF,eAAe,CAAC,GAAG,EAAE,CAAC;iBACtB;gBAED,IAAI,gBAAgB,GAAG,GAAG,CAAC;gBAC3B,IAAI,gBAAgB,IAAI,GAAG,IAAI,GAAG,CAAC,gBAAgB,CAAC,IAAI,IAAI,EAAE;oBAC7D,gBAAgB,GAAG,GAAG,CAAC,gBAAgB,CAAW,CAAC;iBACnD;qBAAM,IAAI,GAAG,CAAC,SAAS,CAAC,gBAAgB,CAAC,EAAE;oBAC3C,gBAAgB,GAAG,GAAG,CAAC,SAAS,CAAC,gBAAgB,CAAW,CAAC;iBAC7D;gBACD,qFAAqF;gBACrF,wBAAwB;gBACxB,MAAM,mBAAmB,GAAG,IAAI,CAAC,OAAO,CAAC,yBAAyB,CAAqB,CAAC;gBACxF,mBAAmB;qBACjB,MAAM,CAAC,EAAE,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,GAAG,CAAC,UAAU,EAAE,CAAC;qBACtF,OAAO,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC,CAAC;gBAExC,kBAAkB;gBAClB,MAAM,OAAO,GAAG,GAAG,CAAC,EAAE,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,GAAG,CAAC,UAAU,EAAE,CAAC,CAAC;gBAEpG,iCAAiC;gBACjC,MAAM,2BAA2B,GAAG,IAAI,CAAC,OAAO,CAAC,iCAAiC,CAAqB,CAAC;gBACxG,2BAA2B;qBACzB,MAAM,CAAC,EAAE,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,GAAG,CAAC,UAAU,EAAE,CAAC;qBACtF,OAAO,CAAC,UAAU,CAAC,gBAAgB,CAAC,GAAG,OAAO,CAAC,CAAC;YACnD,CAAC,CAAC,CAAC;YAEH,IAAI,EAAE,CAAC;QACR,CAAC,CAAC;IACH,CAAC;IAEO,IAAI;QACX,SAAS;QACT,SAAM,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;QAE/E,qBAAM,CAAC,qBAAqB,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;QAE1E,8BAA8B;QAC9B,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,IAAa,EAAE,GAAa,EAAE,EAAE;YACzD,KAAK,CAAC,KAAK,IAAI,EAAE;gBAChB,GAAG,CAAC,GAAG,CAAC,cAAc,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;gBACnD,GAAG,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC;YACzC,CAAC,CAAC,EAAE,CAAC;QACN,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,eAAe,EAAE,CAAC,IAAa,EAAE,GAAa,EAAE,EAAE;YAC9D,KAAK,CAAC,KAAK,IAAI,EAAE;gBAChB,GAAG,CAAC,GAAG,CAAC,cAAc,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;gBACnD,GAAG,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE,CAAC,CAAC;YAClD,CAAC,CAAC,EAAE,CAAC;QACN,CAAC,CAAC,CAAC;IACJ,CAAC;CACD;AA9LD,8BA8LC"}
|
|
@@ -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,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"}
|
package/build/src/parseArgs.js
CHANGED
|
@@ -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;
|
|
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":";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,WAAW,
|
|
1
|
+
{"version":3,"file":"AccountsAssetsService.js","sourceRoot":"","sources":["../../../../src/services/accounts/AccountsAssetsService.ts"],"names":[],"mappings":"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"}
|
|
@@ -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":";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,yBAA0B,SAAQ,iCAAe;IAC7D;;;;;;;;;OASG;IACH,KAAK,CAAC,sBAAsB,CAC3B,IAAe,EACf,OAAe,EACf,MAAgB;QAEhB,MAAM,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;QACrB,MAAM,WAAW,
|
|
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
|
|
166
|
-
|
|
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))
|