@mtg-tracker/common 1.0.26 → 1.0.28

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,8 @@
1
+ import { CustomError } from './custom-error';
2
+ export declare class NotAuthorizedError extends CustomError {
3
+ statusCode: number;
4
+ constructor();
5
+ serializeErrors(): {
6
+ message: string;
7
+ }[];
8
+ }
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NotAuthorizedError = void 0;
4
+ const custom_error_1 = require("./custom-error");
5
+ class NotAuthorizedError extends custom_error_1.CustomError {
6
+ constructor() {
7
+ super('Not authorized');
8
+ this.statusCode = 401;
9
+ Object.setPrototypeOf(this, NotAuthorizedError.prototype);
10
+ }
11
+ serializeErrors() {
12
+ return [{ message: 'Not authorized' }];
13
+ }
14
+ }
15
+ exports.NotAuthorizedError = NotAuthorizedError;
@@ -0,0 +1,8 @@
1
+ import { CustomError } from './custom-error';
2
+ export declare class NotFoundError extends CustomError {
3
+ statusCode: number;
4
+ constructor();
5
+ serializeErrors(): {
6
+ message: string;
7
+ }[];
8
+ }
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NotFoundError = void 0;
4
+ const custom_error_1 = require("./custom-error");
5
+ class NotFoundError extends custom_error_1.CustomError {
6
+ constructor() {
7
+ super('Route not found');
8
+ this.statusCode = 404;
9
+ Object.setPrototypeOf(this, NotFoundError.prototype);
10
+ }
11
+ serializeErrors() {
12
+ return [{ message: 'Not Found' }];
13
+ }
14
+ }
15
+ exports.NotFoundError = NotFoundError;
package/build/index.d.ts CHANGED
@@ -3,8 +3,11 @@ export * from './errors/bad-request-error';
3
3
  export * from './errors/custom-error';
4
4
  export * from './errors/database-connection-error';
5
5
  export * from './errors/request-validation-error';
6
+ export * from './errors/not-found-error';
7
+ export * from './errors/not-authorized-error';
6
8
  export * from './middlewares/current-user';
7
9
  export * from './middlewares/error-handler';
8
10
  export * from './middlewares/require-auth';
9
11
  export * from './middlewares/validate-request';
12
+ export * from './middlewares/require-admin';
10
13
  export * from './logs/service-log';
package/build/index.js CHANGED
@@ -19,8 +19,11 @@ __exportStar(require("./errors/bad-request-error"), exports);
19
19
  __exportStar(require("./errors/custom-error"), exports);
20
20
  __exportStar(require("./errors/database-connection-error"), exports);
21
21
  __exportStar(require("./errors/request-validation-error"), exports);
22
+ __exportStar(require("./errors/not-found-error"), exports);
23
+ __exportStar(require("./errors/not-authorized-error"), exports);
22
24
  __exportStar(require("./middlewares/current-user"), exports);
23
25
  __exportStar(require("./middlewares/error-handler"), exports);
24
26
  __exportStar(require("./middlewares/require-auth"), exports);
25
27
  __exportStar(require("./middlewares/validate-request"), exports);
28
+ __exportStar(require("./middlewares/require-admin"), exports);
26
29
  __exportStar(require("./logs/service-log"), exports);
@@ -1,7 +1,9 @@
1
1
  import { Request, Response, NextFunction } from 'express';
2
2
  interface UserPayload {
3
- id: string;
3
+ id: number;
4
4
  email: string;
5
+ username: string;
6
+ role: 'user' | 'admin';
5
7
  }
6
8
  declare global {
7
9
  namespace Express {
@@ -0,0 +1,2 @@
1
+ import { Request, Response, NextFunction } from 'express';
2
+ export declare const requireAdmin: (req: Request, res: Response, next: NextFunction) => void;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.requireAdmin = void 0;
4
+ const not_authorized_error_1 = require("../errors/not-authorized-error");
5
+ const requireAdmin = (req, res, next) => {
6
+ if (!req.currentUser) {
7
+ throw new not_authorized_error_1.NotAuthorizedError();
8
+ }
9
+ if (req.currentUser.role !== 'admin') {
10
+ throw new not_authorized_error_1.NotAuthorizedError();
11
+ }
12
+ next();
13
+ };
14
+ exports.requireAdmin = requireAdmin;
@@ -1,10 +1,2 @@
1
1
  import { Request, Response, NextFunction } from 'express';
2
- import { CustomError } from '../errors/custom-error';
3
- export declare class NotAuthorizedError extends CustomError {
4
- statusCode: number;
5
- constructor();
6
- serializeErrors(): {
7
- message: string;
8
- }[];
9
- }
10
2
  export declare const requireAuth: (req: Request, res: Response, next: NextFunction) => void;
@@ -1,21 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.requireAuth = exports.NotAuthorizedError = void 0;
4
- const custom_error_1 = require("../errors/custom-error");
5
- class NotAuthorizedError extends custom_error_1.CustomError {
6
- constructor() {
7
- super('Not authorized');
8
- this.statusCode = 401;
9
- Object.setPrototypeOf(this, NotAuthorizedError.prototype);
10
- }
11
- serializeErrors() {
12
- return [{ message: 'Not authorized' }];
13
- }
14
- }
15
- exports.NotAuthorizedError = NotAuthorizedError;
3
+ exports.requireAuth = void 0;
4
+ const not_authorized_error_1 = require("../errors/not-authorized-error");
16
5
  const requireAuth = (req, res, next) => {
17
6
  if (!req.currentUser) {
18
- throw new NotAuthorizedError();
7
+ throw new not_authorized_error_1.NotAuthorizedError();
19
8
  }
20
9
  next();
21
10
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mtg-tracker/common",
3
- "version": "1.0.26",
3
+ "version": "1.0.28",
4
4
  "description": "",
5
5
  "main": "./build/index.js",
6
6
  "types": "./build/index.d.ts",