IMMREX7
<?php
namespace App\Http\Controllers\Student;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use Session;
class PasswordResetController extends Controller {
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index() {
return view('students.password_resetform');
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create() {
//
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response
*/
public function store(Request $request) {
$rules = [];
$this->validate($request, $rules + [
'password' => 'required|min:6|confirmed',
]);
$parent = \App\Parents::where('mobile', '=', Session::get('mobile'))->whereNotNull('otp')->first();
if ($parent) {
$password = $request->password;
$parent->pwd = $password;
$parent->password = bcrypt($password);
$parent->otp = null;
$parent->update();
$request->session()->flush();
flash('Password has been updated.Login To continue', 'sucess');
return redirect('student/login');
} else {
flash('OTP Has been expired.Re-generate the OTP', 'alert');
return redirect('student/password/reset');
}
}
/**
* Display the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function show($id) {
//
}
/**
* Show the form for editing the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function edit($id) {
//
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param int $id
* @return \Illuminate\Http\Response
*/
public function update(Request $request, $id) {
//
}
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function destroy($id) {
//
}
public function sendOtp(Request $request) {
$rules = ['mobile' => 'required|exists:parents'];
$messages = [
'mobile.exists' => 'This Mobile no is not registered with us.'
];
$this->validate($request, $rules, $messages);
$otp = mt_rand(100000, 999999);
$parent = \App\Parents::where('mobile', '=', $request->mobile)->first();
$school = \App\School::where('idSchool', '=', $parent->idSchool)->first();
$parent->otp = $otp;
$parent->otpSendAt = \Carbon\Carbon::now();
$parent->update();
Session::put('mobile', $request->mobile);
$message = $otp.' OTP for reseting Password. Regards JIJAU ENTP.';
$phone_number = $request->mobile;
if($school->idCountry == 1)
\App\Http\SendSmsApi::initiateForgotPassword($phone_number, $message, $school);
flash('OTP has been sent to your mobile no.Enter OTP To continue', 'success');
return redirect('student/verifym');
}
public function verifyOtpForm() {
return view('students.verifyotp');
}
public function verifyOtp(Request $request) {
$rules = ['otp' => 'required|exists:parents'];
$this->validate($request, $rules);
$parent = \App\Parents::where('mobile', '=', Session::get('mobile'))->where('otp', '=', $request->otp)->first();
//dd($diff_in_minutes);
if ($parent) {
$to = \Carbon\Carbon::now();
$otpvalid = $parent->otpsendAt;
$diff_in_minutes = $to->diffInMinutes($otpvalid);
if ($diff_in_minutes <= 5) {
return redirect('student/resetpassword');
} else {
flash('Otp is invalid. Re-enter/Re-generate the OTP', 'danger');
return redirect('student/verifym');
}
} else {
flash('Otp is invalid. Re-enter/Re-generate the OTP', 'danger');
return redirect('student/verifym');
}
}
public function resetPassword() {
$session_data = Session::get('mobile');
if ($session_data != null) {
return view('students.resetpassword');
} else {
flash('OTP Has been expired.Re-generate the OTP', 'danger');
return redirect('student/password/reset');
}
}
}
Copyright © 2021 -