34 lines
813 B
PHP
34 lines
813 B
PHP
<?php
|
|
|
|
namespace App\Http\Middleware;
|
|
|
|
use Closure;
|
|
use Illuminate\Cache\RateLimiter;
|
|
use Illuminate\Http\Request;
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
|
|
class ThrottlePrompts
|
|
{
|
|
protected RateLimiter $limiter;
|
|
|
|
public function __construct(RateLimiter $limiter)
|
|
{
|
|
$this->limiter = $limiter;
|
|
}
|
|
|
|
public function handle(Request $request, Closure $next): Response
|
|
{
|
|
$key = 'prompts:' . $request->user()->id;
|
|
|
|
if ($this->limiter->tooManyAttempts($key, 60)) { // 每分鐘 60 次
|
|
return response()->json([
|
|
'error' => '請求過於頻繁,請稍後再試。',
|
|
'retry_after' => $this->limiter->availableIn($key)
|
|
], 429);
|
|
}
|
|
|
|
$this->limiter->hit($key);
|
|
|
|
return $next($request);
|
|
}
|
|
}
|