Middleware Session Timeout Laravel

Menentukan berapa lama session user berada didalam aplikasi adalah hal yang penting. Pengaturan session timeout di PHP dapat dilakukan file php.ini tapi rasanya kurang “elegan” untuk melakukan konfigurasinya disana, apalagi itu akan berlaku global.

Di laravel dapat dilakukan pada middleware, middleware tersebut yang kita pasang di routing maka akan memeriksa session berjalan. Kurang lebih inilah script session timeout laravel pada middleware :

namespace App\Http\Middleware;

use Closure;
use Illuminate\Support\Facades\Auth;
use Illuminate\Session\Store;

    class SessionTimeout {
    protected $session;
    protected $timeout=1200;

    public function __construct(Store $session){
        $this->session=$session;
    }
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        if(!$this->session->has('lastActivityTime'))
            $this->session->put('lastActivityTime',time());
        elseif(time() - $this->session->get('lastActivityTime') > $this->timeout){
            $this->session->forget('lastActivityTime');
            Auth::logout();
            return redirect('login')->with(['warning' => 'You had not activity in '.$this->timeout/60 .' minutes ago.']);
        }
        $this->session->put('lastActivityTime',time());
        return $next($request);
    }

}

Jangan lupa untuk me-register middleware tersebut pada kernel.php

Mungkin Anda juga menyukai

Tinggalkan Balasan

Alamat surel Anda tidak akan dipublikasikan. Ruas yang wajib ditandai *