JWTMiddleware.php 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. <?php
  2. namespace App\Http\Middleware;
  3. use Closure;
  4. use Illuminate\Http\Request;
  5. use Illuminate\Support\Carbon;
  6. use Illuminate\Support\Facades\DB;
  7. use Firebase\JWT\JWT;
  8. use Firebase\JWT\Key;
  9. use App\Http\Controllers\ResponseController;
  10. class JWTMiddleware{
  11. private $responseController;
  12. private $publicKey = "zOgD0uF22+xg37nTmA+bg/6/E80BJYeHeByGpeTrNFw=";
  13. /**
  14. * Handle an incoming request.
  15. *
  16. * @param \Illuminate\Http\Request $request
  17. * @param \Closure(\Illuminate\Http\Request): (\Illuminate\Http\Response|\Illuminate\Http\RedirectResponse) $next
  18. * @return \Illuminate\Http\Response|\Illuminate\Http\RedirectResponse
  19. */
  20. public function __construct($responseController = new ResponseController()){
  21. $this->responseController = $responseController;
  22. }
  23. public function handle(Request $request, Closure $next){
  24. $auth = $request->header('Authorization');
  25. if(is_null($auth)){
  26. return $this->responseController->makeResponse(true, "No se encontró el token de autorización.", [], 401);
  27. }else if(!str_contains($auth, "Bearer")){
  28. return $this->responseController->makeResponse(true, "No se encontró el token de autorización.", [], 401);
  29. }
  30. $token = str_replace("Bearer ", "", $auth);
  31. if(strlen($token) < 234){
  32. return $this->responseController->makeResponse(true, "Token inválido.", [], 401);
  33. }
  34. $decoded = JWT::decode($token, new Key($this->publicKey, 'EdDSA'));
  35. $now = Carbon::now('America/Mexico_city')->timestamp;
  36. $usr = DB::table('samusua')->where('USUA_EMAI', '=', $decoded->iss)->first();
  37. if(is_null($usr)){
  38. return $this->responseController->makeResponse(true, "El usuario que generó el token no está registrado en la base.", [], 401);
  39. }
  40. if($decoded->aud != "dominio.syp.mx"){
  41. return $this->responseController->makeResponse(true, "El token no fue generado en este sistema.", [], 401);
  42. }
  43. if($now > $decoded->cad){
  44. return $this->responseController->makeResponse(true, "Token expirado.", [], 401);
  45. }
  46. return $next($request);
  47. }
  48. }