mirror of
https://github.com/v2board/v2board.git
synced 2024-11-10 09:39:10 +08:00
update: register limit by ip
This commit is contained in:
parent
c6cc307147
commit
9d45b71731
51
app/Console/Commands/ClearUser.php
Normal file
51
app/Console/Commands/ClearUser.php
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Console\Commands;
|
||||||
|
|
||||||
|
use App\Models\Ticket;
|
||||||
|
use App\Models\User;
|
||||||
|
use Illuminate\Console\Command;
|
||||||
|
|
||||||
|
class ClearUser extends Command
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The name and signature of the console command.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $signature = 'clear:user';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The console command description.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $description = '清理用户';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new command instance.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Execute the console command.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
$builder = User::where('plan_id', NULL)
|
||||||
|
->where('transfer_enable', 0)
|
||||||
|
->where('expired_at', 0)
|
||||||
|
->where('last_login_at', NULL);
|
||||||
|
$count = $builder->count();
|
||||||
|
if ($builder->delete()) {
|
||||||
|
$this->info("已删除${count}位没有任何数据的用户");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -20,6 +20,10 @@ class AuthController extends Controller
|
|||||||
{
|
{
|
||||||
public function register(AuthRegister $request)
|
public function register(AuthRegister $request)
|
||||||
{
|
{
|
||||||
|
$registerCountByIP = CacheKey::get('REGISTER_IP_RATE_LIMIT', $request->ip()) || 0;
|
||||||
|
if ($registerCountByIP >= 3) {
|
||||||
|
abort(500, __('Register frequently, please try again after 1 hour'));
|
||||||
|
}
|
||||||
if ((int)config('v2board.recaptcha_enable', 0)) {
|
if ((int)config('v2board.recaptcha_enable', 0)) {
|
||||||
$recaptcha = new ReCaptcha(config('v2board.recaptcha_key'));
|
$recaptcha = new ReCaptcha(config('v2board.recaptcha_key'));
|
||||||
$recaptchaResp = $recaptcha->verify($request->input('recaptcha_data'));
|
$recaptchaResp = $recaptcha->verify($request->input('recaptcha_data'));
|
||||||
@ -109,6 +113,9 @@ class AuthController extends Controller
|
|||||||
];
|
];
|
||||||
$request->session()->put('email', $user->email);
|
$request->session()->put('email', $user->email);
|
||||||
$request->session()->put('id', $user->id);
|
$request->session()->put('id', $user->id);
|
||||||
|
$user->last_login_at = time();
|
||||||
|
$user->save();
|
||||||
|
Cache::put(CacheKey::get('REGISTER_IP_RATE_LIMIT', $request->ip()), $registerCountByIP + 1, 3600);
|
||||||
return response()->json([
|
return response()->json([
|
||||||
'data' => $data
|
'data' => $data
|
||||||
]);
|
]);
|
||||||
|
@ -18,7 +18,8 @@ class CacheKey
|
|||||||
'SERVER_SHADOWSOCKS_LAST_PUSH_AT' => 'ss节点最后推送时间',
|
'SERVER_SHADOWSOCKS_LAST_PUSH_AT' => 'ss节点最后推送时间',
|
||||||
'TEMP_TOKEN' => '临时令牌',
|
'TEMP_TOKEN' => '临时令牌',
|
||||||
'LAST_SEND_EMAIL_REMIND_TRAFFIC' => '最后发送流量邮件提醒',
|
'LAST_SEND_EMAIL_REMIND_TRAFFIC' => '最后发送流量邮件提醒',
|
||||||
'SCHEDULE_LAST_CHECK_AT' => '计划任务最后检查时间'
|
'SCHEDULE_LAST_CHECK_AT' => '计划任务最后检查时间',
|
||||||
|
'REGISTER_IP_RATE_LIMIT' => '注册频率限制'
|
||||||
];
|
];
|
||||||
|
|
||||||
public static function get(string $key, $uniqueValue)
|
public static function get(string $key, $uniqueValue)
|
||||||
|
@ -87,5 +87,6 @@
|
|||||||
"The service in :app_name is about to expire": "The service in :app_name is about to expire",
|
"The service in :app_name is about to expire": "The service in :app_name is about to expire",
|
||||||
"The coupon can only be used :limit_use_with_user per person": "The coupon can only be used :limit_use_with_user per person",
|
"The coupon can only be used :limit_use_with_user per person": "The coupon can only be used :limit_use_with_user per person",
|
||||||
"The coupon code cannot be used for this period": "The coupon code cannot be used for this period",
|
"The coupon code cannot be used for this period": "The coupon code cannot be used for this period",
|
||||||
"Request failed, please try again later": "Request failed, please try again later"
|
"Request failed, please try again later": "Request failed, please try again later",
|
||||||
|
"Register frequently, please try again after 1 hour": "Register frequently, please try again after 1 hour"
|
||||||
}
|
}
|
||||||
|
@ -87,5 +87,6 @@
|
|||||||
"The service in :app_name is about to expire": "在 :app_name 的服务即将到期",
|
"The service in :app_name is about to expire": "在 :app_name 的服务即将到期",
|
||||||
"The coupon can only be used :limit_use_with_user per person": "该优惠券每人只能用 :limit_use_with_user 次",
|
"The coupon can only be used :limit_use_with_user per person": "该优惠券每人只能用 :limit_use_with_user 次",
|
||||||
"The coupon code cannot be used for this period": "此优惠券无法用于该付款周期",
|
"The coupon code cannot be used for this period": "此优惠券无法用于该付款周期",
|
||||||
"Request failed, please try again later": "请求失败,请稍后再试"
|
"Request failed, please try again later": "请求失败,请稍后再试",
|
||||||
|
"Register frequently, please try again after 1 hour": "注册频繁,请等待1小时后再次尝试"
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user