Пример #1
0
        public async Task <IActionResult> VerifyOtpCode([FromBody] GetOTP getOtp)
        {
            // Verify Otp
            var verified = await _service.VerifyOtpCode(getOtp.OtpCode);

            if (!verified)
            {
                return(BadRequest(new
                {
                    Response = new JsonResponseHandler {
                        ErrorMessage = AppStrings.WrongOtp, IsSuccess = false,
                    }
                }));
            }

            // Check if OTP time is expired
            var checkOtpLimit = await _service.CheckOtpTimeExpired(getOtp.OtpCode);

            if (!checkOtpLimit)
            {
                return(BadRequest(new
                {
                    Response = new JsonResponseHandler {
                        ErrorMessage = AppStrings.OtpTimeExpired, IsSuccess = false,
                    }
                }));
            }

            //            var user = await _service.GetUserByPhoneNumber(getOtp.PhoneNumber);

            return(Ok(new
            {
                Response = new JsonResponseHandler
                {
                    IsSuccess = true,
                }
            }));
        }
Пример #2
0
        public async Task <IActionResult> ResendOtp([FromBody] GetOTP getOtp)
        {
            int userId = 0;
            var otp    = new GenerateOtp();

            if (string.IsNullOrEmpty(getOtp.PhoneNumber))
            {
                return(BadRequest(new
                {
                    Response = new JsonResponseHandler
                    {
                        IsSuccess = false,
                        ErrorMessage = AppStrings.PhoneNumberOrCountryCodeEmpty
                    }
                }));
            }

            // Generating OTP Passcode
            var otpPassCode = otp.GetOtpNumber();
            var otpSms      = AppStrings.ConnectApi + otpPassCode;

            // Get Number Of OTP Attemps
            int numberOfAttempts = await _service.GetNumberOfAttempts(getOtp.PhoneNumber);

            //Get UserID with PhoneNumber
            var user = await _service.GetUserByPhoneNumber(getOtp.PhoneNumber);

            if (user != null)
            {
                userId = user.Id;
            }

            //Get UserOTP with PhoneNumber
            var userOtp = await _service.GetUserOtpInfoByPhoneNumber(getOtp.PhoneNumber);

            // Exceeded OTP Attempts Response
            if (numberOfAttempts > AppConstants.OtpNumberOfAttempts ||
                userOtp.CreatedDate.AddMinutes(AppConstants.DurationUntilOtpCodeActive) < DateTime.UtcNow)
            {
                return(BadRequest(new
                {
                    Response = new JsonResponseHandler
                    {
                        ErrorMessage = AppStrings.OtpCodeAttemptsExceeded,
                        IsSuccess = false
                    }
                }));
            }

            ++numberOfAttempts;

            //To Save Otp Code Against PhoneNumber
            await _service.SaveResentOtpAgainstPhoneNumber(otpPassCode, getOtp.PhoneNumber, numberOfAttempts, userId);

            //Send OTP Code To Mobile
            var twilioSmsHelper = new TwilioSmsSendHelper();
            var responseTwilio  = await twilioSmsHelper.SendSms(otpSms, getOtp.PhoneNumber);

            return(Ok(new
            {
                Code = otpPassCode,
                Response = new JsonResponseHandler
                {
                    IsSuccess = true,
                    ErrorMessage = responseTwilio
                }
            }));
        }
Пример #3
0
        public async Task <IActionResult> SendOtpCode([FromBody] GetOTP getOtp)
        {
            int userId           = 0;
            int numberOfAttempts = 1;

            var otp = new GenerateOtp();

            if (string.IsNullOrEmpty(getOtp.PhoneNumber))
            {
                return(BadRequest(new
                {
                    Response = new JsonResponseHandler
                    {
                        IsSuccess = false,
                        ErrorMessage = AppStrings.PhoneNumberOrCountryCodeEmpty
                    }
                }));
            }

            // Check if Phone Number is Digits Only
//            var checkPhoneNumberCorrect = _service.IsDigitsOnly(getOtp.PhoneNumber);
//            if (!checkPhoneNumberCorrect)
//            {
//                return BadRequest(new
//                {
//                    Response = new JsonResponseHandler
//                    {
//                        IsSuccess = false,
//                        ErrorMessage = AppStrings.InvalidPhoneNumberOrCountryCode,
//                    }
//                });
//            }


            // Generating OTP Passcode
            var otpPassCode = otp.GetOtpNumber();
            var otpSms      = AppStrings.ConnectApi + otpPassCode;

            //Get UserID with PhoneNumber
            var user = await _service.GetUserByPhoneNumber(getOtp.PhoneNumber);

            if (user != null)
            {
                userId = user.Id;
            }


            //To Save Otp Code Against PhoneNumber
            await _service.SaveGeneratedOtpAgainstPhoneNumber(otpPassCode, getOtp.PhoneNumber, numberOfAttempts,
                                                              userId);

            //Send OTP Code To Mobile
            var twilioSmsHelper = new TwilioSmsSendHelper();
            var responseTwilio  = await twilioSmsHelper.SendSms(otpSms, getOtp.PhoneNumber);


            return(Ok(new
            {
                Code = otpPassCode,
                Response = new JsonResponseHandler
                {
                    IsSuccess = true,
                    ErrorMessage = responseTwilio,
                }
            }));
        }