mirror of
https://github.com/cedar2025/Xboard.git
synced 2025-01-22 10:38:14 -05:00
Merge pull request #313 from elysias123/dev
Some checks failed
Docker Build and Publish / build (push) Has been cancelled
Some checks failed
Docker Build and Publish / build (push) Has been cancelled
allow admin/staff unbind a user and better subscription domain names
This commit is contained in:
commit
74d93691b9
@ -12,11 +12,17 @@ class UnBind extends Telegram {
|
||||
|
||||
public function handle($message, $match = []) {
|
||||
if (!$message->is_private) return;
|
||||
if (!isset($message->args[0])) {
|
||||
$user = User::where('telegram_id', $message->chat_id)->first();
|
||||
$telegramService = $this->telegramService;
|
||||
if (!$user) {
|
||||
$telegramService->sendMessage($message->chat_id, '没有查询到您的用户信息,请先绑定账号', 'markdown');
|
||||
return;
|
||||
} else {
|
||||
$chat = User::where('telegram_id', $message->chat_id)->first();
|
||||
if (!$chat) return;
|
||||
if (!($chat->is_admin || $chat->is_staff)) return;
|
||||
if (strpos($message->args[0], '@') !== true) {
|
||||
$user = User::where('email', $message->args[0])->first();
|
||||
} else {
|
||||
$user = User::where('telegram_id', $message->args[0])->first();
|
||||
}
|
||||
}
|
||||
$user->telegram_id = NULL;
|
||||
if (!$user->save()) {
|
||||
|
@ -110,11 +110,20 @@ class Helper
|
||||
|
||||
public static function getSubscribeUrl(string $token, $subscribeUrl = null)
|
||||
{
|
||||
$strs = 'QWERTYUIOPASDFGHJKLZXCVBNM1234567890qwertyuiopasdfghjklzxcvbnm';
|
||||
$randstr = substr(str_shuffle($strs), 0, rand(4,8));
|
||||
|
||||
$path = route('client.subscribe', ['token' => $token], false);
|
||||
if(!$subscribeUrl){
|
||||
$subscribeUrls = explode(',', admin_setting('subscribe_url'));
|
||||
$subscribeUrl = \Arr::random($subscribeUrls);
|
||||
$subscribeUrl = self::replaceByPattern($subscribeUrl);
|
||||
if (strpos($subscribeUrl, "*") !== false) {
|
||||
$subscribeUrl = str_replace("*", $randstr, $subscribeUrl);
|
||||
} elseif (strpos($subscribeUrl, '{uuid}') !== false) {
|
||||
$user = User::where('token', $token)->first();
|
||||
$subscribeUrl = str_replace('{uuid}', $user->uuid, $subscribeUrl);
|
||||
}
|
||||
}
|
||||
return $subscribeUrl ? rtrim($subscribeUrl, '/') . $path : url($path);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user