IMMREX7
<?php
namespace App\Http\Controllers\Teacher;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use App\Http\SendSmsApi;
use Session;
class PasswordResetController extends Controller {
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index() {
return view('teachers.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',
]);
$teacher = \App\Employee::where('mobile', '=', Session::get('mobile'))->whereNotNull('otp')->first();
if ($teacher) {
$password = $request->password;
$teacher->pwd = $password;
$teacher->password = bcrypt($password);
$teacher->otp = null;
$teacher->update();
$request->session()->flush();
flash('Password has been updated.Login To continue', 'sucess');
return redirect('teacher/login');
} else {
flash('OTP Has been expired.Re-generate the OTP', 'alert');
return redirect('teacher/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:teachers'];
$messages = [
'mobile.exists' => 'This Mobile no is not registered with us.'
];
$this->validate($request, $rules, $messages);
$otp = mt_rand(100000, 999999);
$teacher = \App\Employee::where('mobile', '=', $request->mobile)->first();
$school = \App\School::where('idSchool', '=', $teacher->idSchool)->first();
$teacher->otp = $otp;
$teacher->otpSendAt = \Carbon\Carbon::now();
$teacher->update();
Session::put('mobile', $request->mobile);
$phone_number = $request->mobile;
if($school->idCountry == 1){
$message = $otp . 'OTP for reseting Password. Regards ' . $school->sms_regard_text . '.';
$template = \App\SchoolSmsTemplate::where('idSchool', '=', $school->idSchool)->where('template_name', '=', 'forgot_password')->first();
if (!empty($template)) {
$tempid = $template->template_id;
\App\Http\SendSmsApi::getUserNumber($phone_number, $message, $school, $tempid);
}
}
flash('OTP has been sent to your mobile no.Enter OTP To continue', 'success');
return redirect('teacher/verifym');
}
public function verifyOtpForm() {
return view('teachers.verifyotp');
}
public function verifyOtp(Request $request) {
$rules = ['otp' => 'required|exists:teachers'];
$this->validate($request, $rules);
$teacher = \App\Employee::where('mobile', '=', Session::get('mobile'))->where('otp', '=', $request->otp)->first();
//dd($diff_in_minutes);
if ($teacher) {
$to = \Carbon\Carbon::now();
$otpvalid = $teacher->otpsendAt;
$diff_in_minutes = $to->diffInMinutes($otpvalid);
if ($diff_in_minutes <= 5) {
return redirect('teacher/resetpassword');
} else {
flash('Otp is invalid. Re-enter/Re-generate the OTP', 'danger');
return redirect('teacher/verifym');
}
} else {
flash('Otp is invalid. Re-enter/Re-generate the OTP', 'danger');
return redirect('teacher/verifym');
}
}
public function resetPassword() {
$session_data = Session::get('mobile');
if ($session_data != null) {
return view('teachers.resetpassword');
} else {
flash('OTP Has been expired.Re-generate the OTP', 'danger');
return redirect('teacher/password/reset');
}
}
}
Copyright © 2021 -