@theia/metrics 1.47.0 → 1.48.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.
@@ -0,0 +1,4 @@
1
+ import { ContainerModule } from '@theia/core/shared/inversify';
2
+ declare const _default: ContainerModule;
3
+ export default _default;
4
+ //# sourceMappingURL=electron-metrics-backend-module.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"electron-metrics-backend-module.d.ts","sourceRoot":"","sources":["../../src/electron-node/electron-metrics-backend-module.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;;AAI/D,wBAGG"}
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ // *****************************************************************************
3
+ // Copyright (C) 2023 STMicroelectronics and others.
4
+ //
5
+ // This program and the accompanying materials are made available under the
6
+ // terms of the Eclipse Public License v. 2.0 which is available at
7
+ // http://www.eclipse.org/legal/epl-2.0.
8
+ //
9
+ // This Source Code may also be made available under the following Secondary
10
+ // Licenses when the conditions for such availability set forth in the Eclipse
11
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
+ // with the GNU Classpath Exception which is available at
13
+ // https://www.gnu.org/software/classpath/license.html.
14
+ //
15
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
16
+ // *****************************************************************************
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ const inversify_1 = require("@theia/core/shared/inversify");
19
+ const electron_token_validator_1 = require("./electron-token-validator");
20
+ const electron_token_validator_2 = require("@theia/core/lib/electron-node/token/electron-token-validator");
21
+ exports.default = new inversify_1.ContainerModule((bind, unbind, isBound, rebind) => {
22
+ bind(electron_token_validator_1.MetricsElectronTokenValidator).toSelf().inSingletonScope();
23
+ rebind(electron_token_validator_2.ElectronTokenValidator).to(electron_token_validator_1.MetricsElectronTokenValidator);
24
+ });
25
+ //# sourceMappingURL=electron-metrics-backend-module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"electron-metrics-backend-module.js","sourceRoot":"","sources":["../../src/electron-node/electron-metrics-backend-module.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,oDAAoD;AACpD,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;AAEhF,4DAA+D;AAC/D,yEAA2E;AAC3E,2GAAsG;AAEtG,kBAAe,IAAI,2BAAe,CAAC,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE;IACjE,IAAI,CAAC,wDAA6B,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IAChE,MAAM,CAAC,iDAAsB,CAAC,CAAC,EAAE,CAAC,wDAA6B,CAAC,CAAC;AACrE,CAAC,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ /// <reference types="node" />
2
+ import { ElectronTokenValidator } from '@theia/core/lib/electron-node/token/electron-token-validator';
3
+ import { IncomingMessage } from 'http';
4
+ import { MaybePromise } from '@theia/core';
5
+ export declare class MetricsElectronTokenValidator extends ElectronTokenValidator {
6
+ protected init(): void;
7
+ allowWsUpgrade(request: IncomingMessage): MaybePromise<boolean>;
8
+ allowRequest(request: IncomingMessage): boolean;
9
+ }
10
+ //# sourceMappingURL=electron-token-validator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"electron-token-validator.d.ts","sourceRoot":"","sources":["../../src/electron-node/electron-token-validator.ts"],"names":[],"mappings":";AAiBA,OAAO,EAAE,sBAAsB,EAAE,MAAM,8DAA8D,CAAC;AACtG,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AAEvC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,qBACa,6BAA8B,SAAQ,sBAAsB;cAElD,IAAI,IAAI,IAAI;IAItB,cAAc,CAAC,OAAO,EAAE,eAAe,GAAG,YAAY,CAAC,OAAO,CAAC;IAI/D,YAAY,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO;CAG3D"}
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ // *****************************************************************************
3
+ // Copyright (C) 2023 STMicroelectronics and others.
4
+ //
5
+ // This program and the accompanying materials are made available under the
6
+ // terms of the Eclipse Public License v. 2.0 which is available at
7
+ // http://www.eclipse.org/legal/epl-2.0.
8
+ //
9
+ // This Source Code may also be made available under the following Secondary
10
+ // Licenses when the conditions for such availability set forth in the Eclipse
11
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
+ // with the GNU Classpath Exception which is available at
13
+ // https://www.gnu.org/software/classpath/license.html.
14
+ //
15
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
16
+ // *****************************************************************************
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ exports.MetricsElectronTokenValidator = void 0;
19
+ const tslib_1 = require("tslib");
20
+ const inversify_1 = require("@theia/core/shared/inversify");
21
+ const electron_token_validator_1 = require("@theia/core/lib/electron-node/token/electron-token-validator");
22
+ const metrics_backend_application_contribution_1 = require("../node/metrics-backend-application-contribution");
23
+ let MetricsElectronTokenValidator = class MetricsElectronTokenValidator extends electron_token_validator_1.ElectronTokenValidator {
24
+ init() {
25
+ super.init();
26
+ }
27
+ allowWsUpgrade(request) {
28
+ return this.allowRequest(request);
29
+ }
30
+ allowRequest(request) {
31
+ return request.url === metrics_backend_application_contribution_1.MetricsBackendApplicationContribution.ENDPOINT || super.allowRequest(request);
32
+ }
33
+ };
34
+ (0, tslib_1.__decorate)([
35
+ (0, inversify_1.postConstruct)(),
36
+ (0, tslib_1.__metadata)("design:type", Function),
37
+ (0, tslib_1.__metadata)("design:paramtypes", []),
38
+ (0, tslib_1.__metadata)("design:returntype", void 0)
39
+ ], MetricsElectronTokenValidator.prototype, "init", null);
40
+ MetricsElectronTokenValidator = (0, tslib_1.__decorate)([
41
+ (0, inversify_1.injectable)()
42
+ ], MetricsElectronTokenValidator);
43
+ exports.MetricsElectronTokenValidator = MetricsElectronTokenValidator;
44
+ //# sourceMappingURL=electron-token-validator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"electron-token-validator.js","sourceRoot":"","sources":["../../src/electron-node/electron-token-validator.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,oDAAoD;AACpD,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;;AAEhF,4DAAyE;AACzE,2GAAsG;AAEtG,+GAAyG;AAIzG,IAAa,6BAA6B,GAA1C,MAAa,6BAA8B,SAAQ,iDAAsB;IAElD,IAAI;QACnB,KAAK,CAAC,IAAI,EAAE,CAAC;IACjB,CAAC;IAEQ,cAAc,CAAC,OAAwB;QAC5C,OAAO,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IACtC,CAAC;IAEQ,YAAY,CAAC,OAAwB;QAC1C,OAAO,OAAO,CAAC,GAAG,KAAK,gFAAqC,CAAC,QAAQ,IAAI,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IACzG,CAAC;CACJ,CAAA;AAXG;IADC,IAAA,yBAAa,GAAE;;;;yDAGf;AAJQ,6BAA6B;IADzC,IAAA,sBAAU,GAAE;GACA,6BAA6B,CAazC;AAbY,sEAA6B"}
@@ -8,6 +8,7 @@ import { BackendApplicationContribution } from '@theia/core/lib/node';
8
8
  import { MetricsContribution } from './metrics-contribution';
9
9
  export declare class MetricsBackendApplicationContribution implements BackendApplicationContribution {
10
10
  protected readonly metricsProviders: ContributionProvider<MetricsContribution>;
11
+ static ENDPOINT: string;
11
12
  constructor(metricsProviders: ContributionProvider<MetricsContribution>);
12
13
  configure(app: express.Application): void;
13
14
  onStart(server: http.Server | https.Server): void;
@@ -1 +1 @@
1
- {"version":3,"file":"metrics-backend-application-contribution.d.ts","sourceRoot":"","sources":["../../src/node/metrics-backend-application-contribution.ts"],"names":[],"mappings":";;AAiBA,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,OAAO,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,8BAA8B,EAAE,MAAM,sBAAsB,CAAC;AACtE,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAE7D,qBACa,qCAAsC,YAAW,8BAA8B;IAGpF,SAAS,CAAC,QAAQ,CAAC,gBAAgB,EAAE,oBAAoB,CAAC,mBAAmB,CAAC;gBAA3D,gBAAgB,EAAE,oBAAoB,CAAC,mBAAmB,CAAC;IAIlF,SAAS,CAAC,GAAG,EAAE,OAAO,CAAC,WAAW,GAAG,IAAI;IAOzC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,GAAG,IAAI;IAMjD,yBAAyB,IAAI,MAAM;CAItC"}
1
+ {"version":3,"file":"metrics-backend-application-contribution.d.ts","sourceRoot":"","sources":["../../src/node/metrics-backend-application-contribution.ts"],"names":[],"mappings":";;AAiBA,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,OAAO,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,8BAA8B,EAAE,MAAM,sBAAsB,CAAC;AACtE,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAE7D,qBACa,qCAAsC,YAAW,8BAA8B;IAIpF,SAAS,CAAC,QAAQ,CAAC,gBAAgB,EAAE,oBAAoB,CAAC,mBAAmB,CAAC;IAHlF,MAAM,CAAC,QAAQ,SAAc;gBAGN,gBAAgB,EAAE,oBAAoB,CAAC,mBAAmB,CAAC;IAIlF,SAAS,CAAC,GAAG,EAAE,OAAO,CAAC,WAAW,GAAG,IAAI;IAOzC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,GAAG,IAAI;IAMjD,yBAAyB,IAAI,MAAM;CAItC"}
@@ -14,18 +14,19 @@
14
14
  //
15
15
  // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
16
16
  // *****************************************************************************
17
+ var MetricsBackendApplicationContribution_1;
17
18
  Object.defineProperty(exports, "__esModule", { value: true });
18
19
  exports.MetricsBackendApplicationContribution = void 0;
19
20
  const tslib_1 = require("tslib");
20
21
  const inversify_1 = require("@theia/core/shared/inversify");
21
22
  const common_1 = require("@theia/core/lib/common");
22
23
  const metrics_contribution_1 = require("./metrics-contribution");
23
- let MetricsBackendApplicationContribution = class MetricsBackendApplicationContribution {
24
+ let MetricsBackendApplicationContribution = MetricsBackendApplicationContribution_1 = class MetricsBackendApplicationContribution {
24
25
  constructor(metricsProviders) {
25
26
  this.metricsProviders = metricsProviders;
26
27
  }
27
28
  configure(app) {
28
- app.get('/metrics', (req, res) => {
29
+ app.get(MetricsBackendApplicationContribution_1.ENDPOINT, (req, res) => {
29
30
  const lastMetrics = this.fetchMetricsFromProviders();
30
31
  res.send(lastMetrics);
31
32
  });
@@ -39,7 +40,8 @@ let MetricsBackendApplicationContribution = class MetricsBackendApplicationContr
39
40
  return this.metricsProviders.getContributions().reduce((total, contribution) => total += contribution.getMetrics() + '\n', '');
40
41
  }
41
42
  };
42
- MetricsBackendApplicationContribution = (0, tslib_1.__decorate)([
43
+ MetricsBackendApplicationContribution.ENDPOINT = '/metrics';
44
+ MetricsBackendApplicationContribution = MetricsBackendApplicationContribution_1 = (0, tslib_1.__decorate)([
43
45
  (0, inversify_1.injectable)(),
44
46
  (0, tslib_1.__param)(0, (0, inversify_1.inject)(common_1.ContributionProvider)),
45
47
  (0, tslib_1.__param)(0, (0, inversify_1.named)(metrics_contribution_1.MetricsContribution)),
@@ -1 +1 @@
1
- {"version":3,"file":"metrics-backend-application-contribution.js","sourceRoot":"","sources":["../../src/node/metrics-backend-application-contribution.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,+CAA+C;AAC/C,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;;AAEhF,4DAAyE;AAIzE,mDAA8D;AAE9D,iEAA6D;AAG7D,IAAa,qCAAqC,GAAlD,MAAa,qCAAqC;IAC9C,YAEuB,gBAA2D;QAA3D,qBAAgB,GAAhB,gBAAgB,CAA2C;IAElF,CAAC;IAED,SAAS,CAAC,GAAwB;QAC9B,GAAG,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YAC7B,MAAM,WAAW,GAAG,IAAI,CAAC,yBAAyB,EAAE,CAAC;YACrD,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,OAAO,CAAC,MAAkC;QACtC,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE;YAC5D,YAAY,CAAC,eAAe,EAAE,CAAC;QACnC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,yBAAyB;QACrB,OAAO,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,YAAY,EAAE,EAAE,CAC3E,KAAK,IAAI,YAAY,CAAC,UAAU,EAAE,GAAG,IAAI,EAAE,EAAE,CAAC,CAAC;IACvD,CAAC;CACJ,CAAA;AAxBY,qCAAqC;IADjD,IAAA,sBAAU,GAAE;IAGJ,wBAAA,IAAA,kBAAM,EAAC,6BAAoB,CAAC,CAAA;IAAE,wBAAA,IAAA,iBAAK,EAAC,0CAAmB,CAAC,CAAA;;GAFpD,qCAAqC,CAwBjD;AAxBY,sFAAqC"}
1
+ {"version":3,"file":"metrics-backend-application-contribution.js","sourceRoot":"","sources":["../../src/node/metrics-backend-application-contribution.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,+CAA+C;AAC/C,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,gFAAgF;AAChF,gFAAgF;;;;;AAEhF,4DAAyE;AAIzE,mDAA8D;AAE9D,iEAA6D;AAG7D,IAAa,qCAAqC,6CAAlD,MAAa,qCAAqC;IAE9C,YAEuB,gBAA2D;QAA3D,qBAAgB,GAAhB,gBAAgB,CAA2C;IAElF,CAAC;IAED,SAAS,CAAC,GAAwB;QAC9B,GAAG,CAAC,GAAG,CAAC,uCAAqC,CAAC,QAAQ,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YACjE,MAAM,WAAW,GAAG,IAAI,CAAC,yBAAyB,EAAE,CAAC;YACrD,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,OAAO,CAAC,MAAkC;QACtC,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE;YAC5D,YAAY,CAAC,eAAe,EAAE,CAAC;QACnC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,yBAAyB;QACrB,OAAO,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,YAAY,EAAE,EAAE,CAC3E,KAAK,IAAI,YAAY,CAAC,UAAU,EAAE,GAAG,IAAI,EAAE,EAAE,CAAC,CAAC;IACvD,CAAC;CACJ,CAAA;AAxBU,8CAAQ,GAAG,UAAU,CAAC;AADpB,qCAAqC;IADjD,IAAA,sBAAU,GAAE;IAIJ,wBAAA,IAAA,kBAAM,EAAC,6BAAoB,CAAC,CAAA;IAAE,wBAAA,IAAA,iBAAK,EAAC,0CAAmB,CAAC,CAAA;;GAHpD,qCAAqC,CAyBjD;AAzBY,sFAAqC"}
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@theia/metrics",
3
- "version": "1.47.0",
3
+ "version": "1.48.0",
4
4
  "description": "Theia - Metrics Extension",
5
5
  "dependencies": {
6
- "@theia/core": "1.47.0",
6
+ "@theia/core": "1.48.0",
7
7
  "prom-client": "^10.2.0",
8
8
  "tslib": "^2.6.2"
9
9
  },
@@ -14,6 +14,9 @@
14
14
  {
15
15
  "frontend": "lib/browser/metrics-frontend-module",
16
16
  "backend": "lib/node/metrics-backend-module"
17
+ },
18
+ {
19
+ "backendElectron": "lib/electron-node/electron-metrics-backend-module"
17
20
  }
18
21
  ],
19
22
  "keywords": [
@@ -41,10 +44,10 @@
41
44
  "watch": "theiaext watch"
42
45
  },
43
46
  "devDependencies": {
44
- "@theia/ext-scripts": "1.47.0"
47
+ "@theia/ext-scripts": "1.48.0"
45
48
  },
46
49
  "nyc": {
47
50
  "extends": "../../configs/nyc.json"
48
51
  },
49
- "gitHead": "96685e37b5450a599370355ccffd4062cf1b72ab"
52
+ "gitHead": "ffae6a0739f7924a7cacafeb5ceb1140d93fe010"
50
53
  }
@@ -0,0 +1,24 @@
1
+ // *****************************************************************************
2
+ // Copyright (C) 2023 STMicroelectronics and others.
3
+ //
4
+ // This program and the accompanying materials are made available under the
5
+ // terms of the Eclipse Public License v. 2.0 which is available at
6
+ // http://www.eclipse.org/legal/epl-2.0.
7
+ //
8
+ // This Source Code may also be made available under the following Secondary
9
+ // Licenses when the conditions for such availability set forth in the Eclipse
10
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
11
+ // with the GNU Classpath Exception which is available at
12
+ // https://www.gnu.org/software/classpath/license.html.
13
+ //
14
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
15
+ // *****************************************************************************
16
+
17
+ import { ContainerModule } from '@theia/core/shared/inversify';
18
+ import { MetricsElectronTokenValidator } from './electron-token-validator';
19
+ import { ElectronTokenValidator } from '@theia/core/lib/electron-node/token/electron-token-validator';
20
+
21
+ export default new ContainerModule((bind, unbind, isBound, rebind) => {
22
+ bind(MetricsElectronTokenValidator).toSelf().inSingletonScope();
23
+ rebind(ElectronTokenValidator).to(MetricsElectronTokenValidator);
24
+ });
@@ -0,0 +1,37 @@
1
+ // *****************************************************************************
2
+ // Copyright (C) 2023 STMicroelectronics and others.
3
+ //
4
+ // This program and the accompanying materials are made available under the
5
+ // terms of the Eclipse Public License v. 2.0 which is available at
6
+ // http://www.eclipse.org/legal/epl-2.0.
7
+ //
8
+ // This Source Code may also be made available under the following Secondary
9
+ // Licenses when the conditions for such availability set forth in the Eclipse
10
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
11
+ // with the GNU Classpath Exception which is available at
12
+ // https://www.gnu.org/software/classpath/license.html.
13
+ //
14
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
15
+ // *****************************************************************************
16
+
17
+ import { injectable, postConstruct } from '@theia/core/shared/inversify';
18
+ import { ElectronTokenValidator } from '@theia/core/lib/electron-node/token/electron-token-validator';
19
+ import { IncomingMessage } from 'http';
20
+ import { MetricsBackendApplicationContribution } from '../node/metrics-backend-application-contribution';
21
+ import { MaybePromise } from '@theia/core';
22
+
23
+ @injectable()
24
+ export class MetricsElectronTokenValidator extends ElectronTokenValidator {
25
+ @postConstruct()
26
+ protected override init(): void {
27
+ super.init();
28
+ }
29
+
30
+ override allowWsUpgrade(request: IncomingMessage): MaybePromise<boolean> {
31
+ return this.allowRequest(request);
32
+ }
33
+
34
+ override allowRequest(request: IncomingMessage): boolean {
35
+ return request.url === MetricsBackendApplicationContribution.ENDPOINT || super.allowRequest(request);
36
+ }
37
+ }
@@ -24,6 +24,7 @@ import { MetricsContribution } from './metrics-contribution';
24
24
 
25
25
  @injectable()
26
26
  export class MetricsBackendApplicationContribution implements BackendApplicationContribution {
27
+ static ENDPOINT = '/metrics';
27
28
  constructor(
28
29
  @inject(ContributionProvider) @named(MetricsContribution)
29
30
  protected readonly metricsProviders: ContributionProvider<MetricsContribution>
@@ -31,7 +32,7 @@ export class MetricsBackendApplicationContribution implements BackendApplication
31
32
  }
32
33
 
33
34
  configure(app: express.Application): void {
34
- app.get('/metrics', (req, res) => {
35
+ app.get(MetricsBackendApplicationContribution.ENDPOINT, (req, res) => {
35
36
  const lastMetrics = this.fetchMetricsFromProviders();
36
37
  res.send(lastMetrics);
37
38
  });