IMMREX7

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

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