D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
home
/
etb1lp46s9ed
/
wacloud.digitalizer.in
/
app
/
Http
/
Middleware
/
Filename :
CheckApiKey.php
back
Copy
<?php namespace App\Http\Middleware; use App\Models\Device; use App\Models\User; use App\Repositories\DeviceRepository; use App\Services\Common; use App\Utils\CacheKey; use Closure; use Illuminate\Http\Request; use Illuminate\Http\Response; use Illuminate\Support\Facades\Cache; use Illuminate\Support\Facades\Log; class CheckApiKey { /** * Handle an incoming request. * * @param \Illuminate\Http\Request $request * @param \Closure(\Illuminate\Http\Request): (\Illuminate\Http\Response|\Illuminate\Http\RedirectResponse) $next * @return \Illuminate\Http\Response|\Illuminate\Http\RedirectResponse */ public function handle(Request $request, Closure $next) { if ($request->is('create-device')) { $user = Cache::remember( CacheKey::USER_BY_API_KEY . $request->api_key, 60 * 60 * 12, fn () => User::where('api_key', $request->api_key)->first() ); $request->merge([ 'user' => $user]); return $next($request); if (!$user) { return response()->json([ 'status' => false, 'msg' => 'Invalid api_key', ], Response::HTTP_BAD_REQUEST); } } try { $deviceRepository = new DeviceRepository(); $user = Cache::remember(CacheKey::USER_BY_API_KEY . $request->api_key, 60 * 60 * 12, fn () => User::where('api_key', $request->api_key)->first()); $device = $deviceRepository->byBody($request->sender)->single(); if ($device->user_id != $user->id) { return response()->json( [ 'status' => false, 'msg' => 'Invalid api_key or sender,please check again', ], Response::HTTP_BAD_REQUEST ); } $request->merge(['device' => $device, 'user' => $user]); return $next($request); } catch (\Throwable $th) { Log::error($th->getMessage()); return response()->json( [ 'status' => false, 'msg' => 'Invali api_key or sender,please check again (2)', ], Response::HTTP_BAD_REQUEST ); } } }