Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
68.75% covered (warning)
68.75%
11 / 16
0.00% covered (danger)
0.00%
0 / 1
CRAP
0.00% covered (danger)
0.00%
0 / 1
AuthenticateWithToken
68.75% covered (warning)
68.75%
11 / 16
0.00% covered (danger)
0.00%
0 / 1
8.50
0.00% covered (danger)
0.00%
0 / 1
 handle
68.75% covered (warning)
68.75%
11 / 16
0.00% covered (danger)
0.00%
0 / 1
8.50
1<?php
2
3namespace App\Http\Middleware;
4
5use App\Models\TblAuthUsers;
6use Closure;
7use Illuminate\Http\Request;
8use App\Models\TblUsers;
9use Carbon\Carbon;
10
11class AuthenticateWithToken
12{
13    public function handle(Request $request, Closure $next)
14    {
15        $token = $request->bearerToken();
16
17        if (!$token) {
18            return response(['error' => 'Token expired or invalid'], 401);
19        }
20
21        $user = TblUsers::where('api_token', $token)->first();
22        $authUser = TblAuthUsers::where('api_token', $token)->first();
23
24        $validUser = null;
25
26        if ($user && $user->token_expires_at > Carbon::now()) {
27            $validUser = $user;
28        } elseif ($authUser && $authUser->token_expires_at > Carbon::now()) {
29            $validUser = $authUser;
30        }
31
32        if (!$validUser) {
33            return response(['error' => 'Token expired or invalid'], 401);
34        }
35
36        // Set the authenticated user for the request
37        $request->setUserResolver(function () use ($validUser) {
38            return $validUser;
39        });
40
41        return $next($request);
42    }
43}