UNPKG

@brewww/authentication-service

Version:
76 lines 3.79 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); } }; Object.defineProperty(exports, "__esModule", { value: true }); exports.LoginOtpPhoneController = void 0; const openapi = require("@nestjs/swagger"); const swagger_1 = require("@nestjs/swagger"); const common_1 = require("@nestjs/common"); const otp_service_1 = require("../otp/otp.service"); const user_service_1 = require("../user/user.service"); const token_service_1 = require("../token/token.service"); const error_1 = require("../error"); const login_otp_phone_request_dto_1 = require("./dto/login-otp-phone-request.dto"); let LoginOtpPhoneController = class LoginOtpPhoneController { constructor(otpService, tokenService, userService) { this.otpService = otpService; this.tokenService = tokenService; this.userService = userService; } async loginAsync(loginOtpPhoneRequest) { try { const phone = { country_code: loginOtpPhoneRequest.phone.countryCode, phone_number: loginOtpPhoneRequest.phone.number, }; const isOtpValid = await this.otpService.validatePhoneOtpAsync(phone, loginOtpPhoneRequest.otpValue); if (!isOtpValid) throw new error_1.InvalidCredentialsError(); const user = await this.userService.getUserAsync({ phone: loginOtpPhoneRequest.phone, }); if (!user) throw new error_1.InvalidCredentialsError(); this.otpService.expireOtpAsync({ phone, }); return await this.tokenService.createTokensAsync(user); } catch (error) { if (error instanceof error_1.InvalidCredentialsError) throw new common_1.UnauthorizedException(null, { cause: error }); console.log("login-otp-phone", error); throw new common_1.InternalServerErrorException(); } } }; __decorate([ (0, common_1.Post)("login-otp-phone"), openapi.ApiResponse({ status: 201, type: require("./dto/login-response.dto").LoginResponse }), __param(0, (0, common_1.Body)()), __metadata("design:type", Function), __metadata("design:paramtypes", [login_otp_phone_request_dto_1.LoginOtpPhoneRequest]), __metadata("design:returntype", Promise) ], LoginOtpPhoneController.prototype, "loginAsync", null); LoginOtpPhoneController = __decorate([ (0, swagger_1.ApiTags)("authentication"), (0, swagger_1.ApiSecurity)("ApiKey"), (0, common_1.Controller)(), __param(1, (0, common_1.Inject)("TokenService")), __param(2, (0, common_1.Inject)("UserService")), __metadata("design:paramtypes", [otp_service_1.OtpService, token_service_1.TokenService, user_service_1.UserService]) ], LoginOtpPhoneController); exports.LoginOtpPhoneController = LoginOtpPhoneController; //# sourceMappingURL=login-otp-phone.controller.js.map