UNPKG

@leismore/authappself_handler

Version:

An Express.js HTTP handler of authentication and authorization services for self-owned LMOS (NodeJS) applications.

49 lines (48 loc) 1.82 kB
"use strict"; // Authorization var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.author = void 0; const axios_1 = require("axios"); const CONFIG = require("../config.json"); const TIMEOUT = CONFIG.auth_app_self.timeout; /** * Authorization * @param api - auth_app_self API URL */ function author(input, api) { return __awaiter(this, void 0, void 0, function* () { let configAxios = { url: api, method: 'POST', data: { hostID: input.hostID, permission: input.permission }, timeout: TIMEOUT, withCredentials: true, auth: { username: input.authen.appID, password: input.authen.token }, validateStatus: (statusCode) => { if (statusCode === 403) { return true; } else { return (statusCode >= 200 && statusCode < 300); } } }; return (0, axios_1.default)(configAxios); }); } exports.author = author;