c2-http 1.0.144 → 1.0.146

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 { NextFunction, Request, Response } from "express";
2
2
  declare class MiddlewareCheckTokenFlow {
3
3
  execute(): Promise<(request: Request, response: Response, next: NextFunction) => Promise<void>>;
4
+ config: (request: Request, response: Response, next: NextFunction) => Promise<void>;
4
5
  checkToken(): Promise<void>;
5
6
  }
6
7
  declare const _default: MiddlewareCheckTokenFlow;
@@ -1,14 +1,37 @@
1
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
+ };
2
25
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
26
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
27
  };
5
28
  Object.defineProperty(exports, "__esModule", { value: true });
29
+ const c2_util_1 = require("c2-util");
6
30
  const http_status_1 = require("http-status");
31
+ const jwt = __importStar(require("jsonwebtoken"));
7
32
  const __1 = require("../..");
8
33
  const AddInContextFlowItem_1 = __importDefault(require("./item/AddInContextFlowItem"));
9
34
  const GetTokenFlowItem_1 = __importDefault(require("./item/GetTokenFlowItem"));
10
- const ValidateTokenFlowItem_1 = __importDefault(require("./item/ValidateTokenFlowItem"));
11
- const c2_util_1 = require("c2-util");
12
35
  class MiddlewareCheckTokenFlow {
13
36
  async execute() {
14
37
  return async (request, response, next) => {
@@ -37,41 +60,40 @@ class MiddlewareCheckTokenFlow {
37
60
  }
38
61
  };
39
62
  }
40
- // public config = async (request: Request, response: Response, next: NextFunction) => {
41
- // log("LOG_CHECK_TOKEN", "Checking token");
42
- // try {
43
- // if (
44
- // (
45
- // request.path === "/metrics" ||
46
- // request.path.startsWith("/metrics") ||
47
- // request.path?.includes("/docs")
48
- // )
49
- // && request.method === "GET") {
50
- // next();
51
- // return;
52
- // }
53
- // if (request.headers["x-api-key"]) {
54
- // next();
55
- // return;
56
- // }
57
- // await this.checkToken()
58
- // log("LOG_CHECK_TOKEN", "Token checked");
59
- // return next()
60
- // } catch (error: any) {
61
- // log("LOG_ERROR_CHECK_TOKEN", error);
62
- // response
63
- // .status(error.status || INTERNAL_SERVER_ERROR)
64
- // .json({ message: error.message, detail: error.detail?.data });
65
- // }
66
- // }
63
+ config = async (request, response, next) => {
64
+ (0, c2_util_1.log)("LOG_CHECK_TOKEN", "Checking token");
65
+ try {
66
+ if ((request.path === "/metrics" ||
67
+ request.path.startsWith("/metrics") ||
68
+ request.path?.includes("/docs"))
69
+ && request.method === "GET") {
70
+ next();
71
+ return;
72
+ }
73
+ if (request.headers["x-api-key"]) {
74
+ next();
75
+ return;
76
+ }
77
+ await this.checkToken();
78
+ (0, c2_util_1.log)("LOG_CHECK_TOKEN", "Token checked");
79
+ return next();
80
+ }
81
+ catch (error) {
82
+ (0, c2_util_1.log)("LOG_ERROR_CHECK_TOKEN", error);
83
+ response
84
+ .status(error.status || http_status_1.INTERNAL_SERVER_ERROR)
85
+ .json({ message: error.message, detail: error.detail?.data });
86
+ }
87
+ };
67
88
  async checkToken() {
68
89
  let token = "";
69
90
  try {
70
91
  token = GetTokenFlowItem_1.default.get();
71
- const tokenDecoded = await ValidateTokenFlowItem_1.default.exec(token);
92
+ const tokenDecoded = jwt.verify(token, process.env.JWT_SECRET ?? ""); //await ValidateTokenFlowItem.exec(token)
72
93
  AddInContextFlowItem_1.default.exec(tokenDecoded, token);
73
94
  }
74
95
  catch (error) {
96
+ (0, c2_util_1.log)("LOG_ERROR_CHECK_TOKEN_CHECK_TOKEN", error);
75
97
  throw (0, __1.convertErrorToHttpError)(error);
76
98
  }
77
99
  }
@@ -4,6 +4,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const express_http_context_1 = __importDefault(require("express-http-context"));
7
+ const c2_util_1 = require("c2-util");
7
8
  class AddInContextFlowItem {
8
9
  exec(decode, token) {
9
10
  express_http_context_1.default.set("token", token);
@@ -16,6 +17,17 @@ class AddInContextFlowItem {
16
17
  express_http_context_1.default.set("accountBlockDate", decode.accountBlockDate);
17
18
  express_http_context_1.default.set("accountExpireDate", decode.accountExpireDate);
18
19
  express_http_context_1.default.set("scopes", decode.scopes);
20
+ (0, c2_util_1.log)("LOG_ADD_IN_CONTEXT", "Adding in context");
21
+ (0, c2_util_1.log)("LOG_ADD_IN_CONTEXT_TOKEN", express_http_context_1.default.get("token"));
22
+ (0, c2_util_1.log)("LOG_ADD_IN_CONTEXT_USER_ID", express_http_context_1.default.get("userId"));
23
+ (0, c2_util_1.log)("LOG_ADD_IN_CONTEXT_USER_PROFILE_ID", express_http_context_1.default.get("userProfileId"));
24
+ (0, c2_util_1.log)("LOG_ADD_IN_CONTEXT_USER_IS_ADMIN", express_http_context_1.default.get("userIsAdmin"));
25
+ (0, c2_util_1.log)("LOG_ADD_IN_CONTEXT_USER_EMAIL", express_http_context_1.default.get("userEmail"));
26
+ (0, c2_util_1.log)("LOG_ADD_IN_CONTEXT_USER_NAME", express_http_context_1.default.get("userName"));
27
+ (0, c2_util_1.log)("LOG_ADD_IN_CONTEXT_ACCOUNT_ID", express_http_context_1.default.get("accountId"));
28
+ (0, c2_util_1.log)("LOG_ADD_IN_CONTEXT_ACCOUNT_BLOCK_DATE", express_http_context_1.default.get("accountBlockDate"));
29
+ (0, c2_util_1.log)("LOG_ADD_IN_CONTEXT_ACCOUNT_EXPIRE_DATE", express_http_context_1.default.get("accountExpireDate"));
30
+ (0, c2_util_1.log)("LOG_ADD_IN_CONTEXT_SCOPES", express_http_context_1.default.get("scopes"));
19
31
  }
20
32
  }
21
33
  exports.default = new AddInContextFlowItem;
@@ -40,7 +40,7 @@ class Server {
40
40
  // this.app.use("/docs", swaggerUI.serve, swaggerUI.setup((global as any).OPEN_API_DOC))
41
41
  (0, c2_util_1.log)("LOG", "Rotas abertas OK");
42
42
  //middlewares de checagem de token obrigatorio
43
- this.app.use(MiddlewareCheckTokenFlow_1.default.execute);
43
+ this.app.use(MiddlewareCheckTokenFlow_1.default.config);
44
44
  //middlewares de checagem de token opcional
45
45
  // this.config.middlewaresCloseControllers?.forEach((middl: RequestHandler) => {
46
46
  // this.app.use(middl)
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "c2-http",
3
- "version": "1.0.144",
3
+ "version": "1.0.146",
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>",