@cripty2001/utils 0.0.36 → 0.0.37

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.
@@ -8,6 +8,9 @@ declare class AppserverError extends Error {
8
8
  status: number;
9
9
  constructor(code: string, message: string, payload?: AppserverData, status?: number);
10
10
  }
11
+ export declare class AppserverAuthError extends AppserverError {
12
+ constructor();
13
+ }
11
14
  export declare class AppserverHandledError extends AppserverError {
12
15
  constructor(code: string, message: string, payload?: AppserverData);
13
16
  }
@@ -16,6 +19,6 @@ export declare class Appserver<U extends AppserverData> {
16
19
  private parseUser;
17
20
  constructor(port: number, parseUser: AppserverUsergetter<U>);
18
21
  private parseInput;
19
- register<ISchema extends TSchema, O extends AppserverData, I extends Static<ISchema> & AppserverData = Static<ISchema> & AppserverData>(action: string, inputSchema: ISchema, handler: AppserverHandler<I, U, O>): void;
22
+ register<ISchema extends TSchema, O extends AppserverData, I extends Static<ISchema> & AppserverData = Static<ISchema> & AppserverData>(action: string, inputSchema: ISchema, auth: boolean, handler: AppserverHandler<I, U, O>): void;
20
23
  }
21
24
  export {};
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.Appserver = exports.AppserverHandledError = void 0;
6
+ exports.Appserver = exports.AppserverHandledError = exports.AppserverAuthError = void 0;
7
7
  const express_1 = __importDefault(require("express"));
8
8
  const value_1 = require("@sinclair/typebox/value");
9
9
  const msgpack_1 = require("@msgpack/msgpack");
@@ -19,6 +19,12 @@ class AppserverError extends Error {
19
19
  this.status = status;
20
20
  }
21
21
  }
22
+ class AppserverAuthError extends AppserverError {
23
+ constructor() {
24
+ super("PERMISSION_DENIED", "You have no right to access this page", {}, 403);
25
+ }
26
+ }
27
+ exports.AppserverAuthError = AppserverAuthError;
22
28
  class AppserverHandledError extends AppserverError {
23
29
  constructor(code, message, payload = {}) {
24
30
  super(code, message, payload);
@@ -51,11 +57,16 @@ class Appserver {
51
57
  user: token ? await this.parseUser(token) : null
52
58
  };
53
59
  }
54
- register(action, inputSchema, handler) {
60
+ register(action, inputSchema, auth, handler) {
55
61
  this.app.post(`/exec/${action}`, async (req, res) => {
56
62
  const { status, data } = await (async () => {
57
63
  try {
58
64
  const { data: unsafeData, user } = await this.parseInput(req);
65
+ if (auth && user === null)
66
+ return {
67
+ status: 401,
68
+ data: { error: 'Authentication required', code: 'AUTHENTICATION_REQUIRED' }
69
+ };
59
70
  if (!value_1.Value.Check(inputSchema, unsafeData))
60
71
  return {
61
72
  status: 422,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cripty2001/utils",
3
- "version": "0.0.36",
3
+ "version": "0.0.37",
4
4
  "description": "Internal Set of utils. If you need them use them, otherwise go to the next package ;)",
5
5
  "homepage": "https://github.com/cripty2001/utils#readme",
6
6
  "bugs": {