Вход Регистрация
Файл: gapps/vendor/laravel/framework/src/Illuminate/Foundation/Auth/ThrottlesLogins.php
Строк: 145
<?php

namespace IlluminateFoundationAuth;

use 
IlluminateHttpRequest;
use 
IlluminateCacheRateLimiter;
use 
IlluminateAuthEventsLockout;
use 
IlluminateSupportFacadesLang;

trait 
ThrottlesLogins
{
    
/**
     * Determine if the user has too many failed login attempts.
     *
     * @param  IlluminateHttpRequest  $request
     * @return bool
     */
    
protected function hasTooManyLoginAttempts(Request $request)
    {
        return 
app(RateLimiter::class)->tooManyAttempts(
            
$this->getThrottleKey($request),
            
$this->maxLoginAttempts(), $this->lockoutTime() / 60
        
);
    }

    
/**
     * Increment the login attempts for the user.
     *
     * @param  IlluminateHttpRequest  $request
     * @return int
     */
    
protected function incrementLoginAttempts(Request $request)
    {
        
app(RateLimiter::class)->hit(
            
$this->getThrottleKey($request)
        );
    }

    
/**
     * Determine how many retries are left for the user.
     *
     * @param  IlluminateHttpRequest  $request
     * @return int
     */
    
protected function retriesLeft(Request $request)
    {
        return 
app(RateLimiter::class)->retriesLeft(
            
$this->getThrottleKey($request),
            
$this->maxLoginAttempts()
        );
    }

    
/**
     * Redirect the user after determining they are locked out.
     *
     * @param  IlluminateHttpRequest  $request
     * @return IlluminateHttpRedirectResponse
     */
    
protected function sendLockoutResponse(Request $request)
    {
        
$seconds $this->secondsRemainingOnLockout($request);

        return 
redirect()->back()
            ->
withInput($request->only($this->loginUsername(), 'remember'))
            ->
withErrors([
                
$this->loginUsername() => $this->getLockoutErrorMessage($seconds),
            ]);
    }

    
/**
     * Get the login lockout error message.
     *
     * @param  int  $seconds
     * @return string
     */
    
protected function getLockoutErrorMessage($seconds)
    {
        return 
Lang::has('auth.throttle')
            ? 
Lang::get('auth.throttle', ['seconds' => $seconds])
            : 
'Too many login attempts. Please try again in '.$seconds.' seconds.';
    }

    
/**
     * Get the lockout seconds.
     *
     * @param  IlluminateHttpRequest  $request
     * @return int
     */
    
protected function secondsRemainingOnLockout(Request $request)
    {
        return 
app(RateLimiter::class)->availableIn(
            
$this->getThrottleKey($request)
        );
    }

    
/**
     * Clear the login locks for the given user credentials.
     *
     * @param  IlluminateHttpRequest  $request
     * @return void
     */
    
protected function clearLoginAttempts(Request $request)
    {
        
app(RateLimiter::class)->clear(
            
$this->getThrottleKey($request)
        );
    }

    
/**
     * Get the throttle key for the given request.
     *
     * @param  IlluminateHttpRequest  $request
     * @return string
     */
    
protected function getThrottleKey(Request $request)
    {
        return 
mb_strtolower($request->input($this->loginUsername())).'|'.$request->ip();
    }

    
/**
     * Get the maximum number of login attempts for delaying further attempts.
     *
     * @return int
     */
    
protected function maxLoginAttempts()
    {
        return 
property_exists($this'maxLoginAttempts') ? $this->maxLoginAttempts 5;
    }

    
/**
     * The number of seconds to delay further login attempts.
     *
     * @return int
     */
    
protected function lockoutTime()
    {
        return 
property_exists($this'lockoutTime') ? $this->lockoutTime 60;
    }

    
/**
     * Fire an event when a lockout occurs.
     *
     * @param  IlluminateHttpRequest  $request
     * @return void
     */
    
protected function fireLockoutEvent(Request $request)
    {
        
event(new Lockout($request));
    }
}
Онлайн: 1
Реклама