IMMREX7

aku nok ndi : /home/spdtg/www/schoolmis/app/Http/Controllers/Teacher/
File Up :
aku nok ndi : /home/spdtg/www/schoolmis/app/Http/Controllers/Teacher/PasswordResetController.php

<?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 - 2025 IMMREX7