Your IP : 216.73.217.77


Current Path : /home/users/unlimited/www/whatsjet-saas/Source/app/Http/Middleware/
Upload File :
Current File : /home/users/unlimited/www/whatsjet-saas/Source/app/Http/Middleware/AppApiAuthenticateMiddleware.php

<?php

namespace App\Http\Middleware;

use App\Yantrana\Components\Auth\Models\AuthModel;
use App\Yantrana\Components\Vendor\Models\VendorModel;
use Auth;
use Closure;
use Illuminate\Support\Facades\Route;
use YesTokenAuth;

class AppApiAuthenticateMiddleware
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        config([
            '__tech.auth_info' => [
                'authorized' => false,
                'reaction_code' => 9,
            ],
        ]);

        $isVerified = YesTokenAuth::verifyToken();

        if(($isVerified['error'] or ($isVerified['error'] !== false)) and (Route::currentRouteName() != 'base_data')) {
            return __apiResponse([
                'message' => $isVerified['error'],
                'auth_info' => getUserAuthInfo(),
            ], 2);
        }

        $tokenRefreshed = array_get($isVerified, 'refreshed_token', null);

        if ($tokenRefreshed) {
            /*set refreshed token */
            setAccessToken($tokenRefreshed);
        }
        if (!$isVerified['error'] or ($isVerified['error'] === false)) {
            $userInfo = AuthModel::where('_id', $isVerified['aud'])->first();
            if (! __isEmpty($userInfo) && in_array($userInfo->status, [2, 3, 4, 5, 6])) {
                return __apiResponse([
                    'message' => __tr('Your Account seems to Inactive or Deleted or Not Activated, Please contact Administrator.'),
                    'auth_info' => getUserAuthInfo(),
                ], 9);
            } elseif (! __isEmpty($userInfo) && $userInfo->status == 1) {
                Auth::loginUsingId($isVerified['aud']);
            } else {
                if (Route::currentRouteName() != 'base_data') {
                    return __apiResponse([
                        'message' => __tr('Please login to complete request.'),
                        'auth_info' => getUserAuthInfo(),
                    ], 9);
                }
            }
        }

        return $next($request);
    }
}