UNPKG

@ijodkor/nest-payme

Version:

NestJs ilovalar uchun Payme ETT bilan integratsiya qilish uchun kutubxona.

78 lines (77 loc) 3.58 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var __param = (this && this.__param) || function (paramIndex, decorator) { return function (target, key) { decorator(target, key, paramIndex); } }; 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.BasicAuthGuard = void 0; const common_1 = require("@nestjs/common"); const auth_option_config_1 = require("../config/auth-option.config"); let BasicAuthGuard = class BasicAuthGuard { constructor(config) { this.config = config; } canActivate(context) { return __awaiter(this, void 0, void 0, function* () { const request = context.switchToHttp().getRequest(); const token = this.extractTokenFromHeader(request); if (!token) { throw new common_1.UnauthorizedException("Unauthorized"); } try { const decoded = this.decodeToken(token); if (!decoded) { return false; } const [username, password] = decoded.split(':'); const isValidUser = this.config.params.username === username; const isValidPassword = this.config.params.password === password; if (!isValidUser || !isValidPassword) { return false; } } catch (error) { return false; } return true; }); } extractTokenFromHeader(request) { const header = request.headers['authorization']; if (!header) return undefined; const [type, token] = header.split(' '); return type === 'Basic' ? token : undefined; } decodeToken(token) { try { return Buffer.from(token, 'base64').toString('utf8'); } catch (error) { return undefined; } } }; exports.BasicAuthGuard = BasicAuthGuard; exports.BasicAuthGuard = BasicAuthGuard = __decorate([ (0, common_1.Injectable)(), __param(0, (0, common_1.Inject)(auth_option_config_1.AUTH_GUARD_OPTIONS)), __metadata("design:paramtypes", [Object]) ], BasicAuthGuard);