c2-http 1.0.109 → 1.0.111

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,6 +1,7 @@
1
1
  import { RequestHandler, Router } from "express";
2
2
  import { NormalizePathEntry } from "express-prom-bundle";
3
- export interface IRouteParam {
3
+ import { IControllerOptions } from "./IControllerOptions";
4
+ export interface ISingleRouteParam {
4
5
  method: "get" | "post" | "patch" | "delete";
5
6
  uri: string;
6
7
  middlewareAuthorization?: RequestHandler;
@@ -16,8 +17,8 @@ export declare abstract class Controller {
16
17
  prefixRole: string[];
17
18
  roles: string[];
18
19
  byPass: boolean;
19
- constructor(options: any);
20
- registerRoute(options: IRouteParam): void;
20
+ constructor(options: IControllerOptions);
21
+ registerRoute(options: ISingleRouteParam): void;
21
22
  }
22
23
  export declare function HttpDispatchHandling(target: any, methodName: string, descriptor: PropertyDescriptor): PropertyDescriptor;
23
24
  export declare function HttpDispatchDownload(target: any, methodName: string, descriptor: PropertyDescriptor): PropertyDescriptor;
@@ -94,45 +94,45 @@ function OpenApi(target) {
94
94
  return class extends target {
95
95
  constructor() {
96
96
  super(); // Chama o construtor da classe original
97
- const paths = {};
98
- this.routesControlled.forEach((route) => {
99
- const methods = {};
100
- methods[route.method] = {
101
- tags: [target.name]
102
- };
103
- if (route.middlewareCheckAuthorization) {
104
- methods[route.method].description = `${methods[route.method].description ?? ""} \nRoles necessárias: ${route.middlewareCheckAuthorization.roles.join(", ")}`;
105
- methods[route.method].security = [
106
- {
107
- OAuth2: route.middlewareCheckAuthorization.roles
108
- }
109
- ];
110
- methods[route.method].responses =
111
- {
112
- "200": {
113
- "content": {
114
- "application/json": {
115
- "schema": {
116
- "type": "object"
117
- }
118
- }
119
- }
120
- }
121
- };
122
- }
123
- const pathsAux = route.uri.replace(/:([^/]+)/g, "{$1}");
124
- paths[pathsAux] = {
125
- ...paths[pathsAux],
126
- ...methods
127
- };
128
- });
129
- global.OPEN_API_DOC = {
130
- ...global.OPEN_API_DOC,
131
- paths: {
132
- ...global.OPEN_API_DOC.paths,
133
- ...paths
134
- }
135
- };
97
+ // const paths: { [key: string]: any } = {}
98
+ // this.forEach((route: any) => {
99
+ // const methods: { [key: string]: any } = {}
100
+ // methods[route.method] = {
101
+ // tags: [target.name]
102
+ // }
103
+ // if (route.middlewareCheckAuthorization) {
104
+ // methods[route.method].description = `${methods[route.method].description ?? ""} \nRoles necessárias: ${route.middlewareCheckAuthorization.roles.join(", ")}`
105
+ // methods[route.method].security = [
106
+ // {
107
+ // OAuth2: route.middlewareCheckAuthorization.roles
108
+ // }
109
+ // ]
110
+ // methods[route.method].responses =
111
+ // {
112
+ // "200": {
113
+ // "content": {
114
+ // "application/json": {
115
+ // "schema": {
116
+ // "type": "object"
117
+ // }
118
+ // }
119
+ // }
120
+ // }
121
+ // }
122
+ // }
123
+ // const pathsAux = route.uri.replace(/:([^/]+)/g, "{$1}")
124
+ // paths[pathsAux] = {
125
+ // ...paths[pathsAux],
126
+ // ...methods
127
+ // };
128
+ // });
129
+ // (global as any).OPEN_API_DOC = {
130
+ // ...(global as any).OPEN_API_DOC,
131
+ // paths: {
132
+ // ...(global as any).OPEN_API_DOC.paths,
133
+ // ...paths
134
+ // }
135
+ // }
136
136
  }
137
137
  };
138
138
  }
@@ -1,9 +1,10 @@
1
- import express, { Router } from "express";
1
+ import express from "express";
2
+ import { Controller } from "./Controller";
2
3
  export interface IServerConfig {
3
4
  openApiFileOutput: any;
4
5
  port: string;
5
- routesWithToken: Router[];
6
- routes: Router[];
6
+ closeControllers: Controller[];
7
+ openControllers: Controller[];
7
8
  i18n: any;
8
9
  }
9
10
  export declare class Server {
@@ -6,7 +6,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.Server = void 0;
7
7
  const c2_util_1 = require("c2-util");
8
8
  const express_1 = __importDefault(require("express"));
9
- const swagger_ui_express_1 = __importDefault(require("swagger-ui-express"));
9
+ const express_prom_bundle_1 = __importDefault(require("express-prom-bundle"));
10
10
  const i18n_1 = require("../i18n");
11
11
  const MiddlewareGlobals_1 = __importDefault(require("../middleware/global-middleware/MiddlewareGlobals"));
12
12
  const MiddlewareJwt_1 = __importDefault(require("../middleware/jwt-middlware/MiddlewareJwt"));
@@ -22,15 +22,25 @@ class Server {
22
22
  (0, c2_util_1.log)("LOG_INIT_SERVER", `Initializing server on ${this.config.port}...`);
23
23
  (0, i18n_1.initializei18n)(this.config.i18n);
24
24
  MiddlewareGlobals_1.default.config(this.app);
25
- for (const router of this.config.routes) {
26
- this.app.use(router);
25
+ let pathsToMetrics = [];
26
+ for (const openController of this.config.openControllers) {
27
+ this.app.use(openController.router);
28
+ pathsToMetrics = [...pathsToMetrics, ...openController.normalizedPaths];
27
29
  }
28
- this.app.use("/docs", swagger_ui_express_1.default.serve, swagger_ui_express_1.default.setup(global.OPEN_API_DOC));
30
+ // this.app.use("/docs", swaggerUI.serve, swaggerUI.setup((global as any).OPEN_API_DOC))
29
31
  (0, c2_util_1.log)("LOG", "Rotas abertas OK");
30
32
  this.app.use(MiddlewareJwt_1.default.config);
31
- for (const router of this.config.routesWithToken) {
32
- this.app.use(router);
33
+ for (const closeRouter of this.config.closeControllers) {
34
+ this.app.use(closeRouter.router);
35
+ pathsToMetrics = [...pathsToMetrics, ...closeRouter.normalizedPaths];
33
36
  }
37
+ const metricsMiddleware = (0, express_prom_bundle_1.default)({
38
+ includeMethod: true,
39
+ includePath: true,
40
+ normalizePath: pathsToMetrics,
41
+ metricsPath: "/metrics"
42
+ });
43
+ this.app.use(metricsMiddleware);
34
44
  (0, c2_util_1.log)("LOG", "Rotas fechadas OK");
35
45
  this.server = this.app.listen(this.config.port, async () => {
36
46
  (0, c2_util_1.log)("LOG_INIT_SERVER", `Server running on port ${this.config.port}`);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "c2-http",
3
- "version": "1.0.109",
3
+ "version": "1.0.111",
4
4
  "description": "Biblioteca Typescript para API NodeJS",
5
5
  "repository": "https://cabralsilva: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@github.com/cabralsilva/c2-http.git",
6
6
  "author": "Daniel Cabral <cabralconsultoriaemsoftware@gmail.com>",