v2board/app/Http/Controllers/User/TicketController.php

201 lines
6.5 KiB
PHP
Raw Normal View History

2019-12-12 19:47:32 +08:00
<?php
2020-01-29 16:08:50 +08:00
namespace App\Http\Controllers\User;
2019-12-12 19:47:32 +08:00
2020-01-29 16:08:50 +08:00
use App\Http\Controllers\Controller;
2020-01-29 16:22:39 +08:00
use App\Http\Requests\User\TicketSave;
2020-05-10 18:38:02 +08:00
use App\Http\Requests\User\TicketWithdraw;
2020-05-25 15:48:12 +08:00
use App\Jobs\SendTelegramJob;
use App\Models\User;
2019-12-12 19:47:32 +08:00
use Illuminate\Http\Request;
use App\Models\Ticket;
use App\Models\TicketMessage;
use Illuminate\Support\Facades\DB;
class TicketController extends Controller
{
2020-01-11 13:36:52 +08:00
public function fetch(Request $request)
{
2019-12-12 20:08:20 +08:00
if ($request->input('id')) {
$ticket = Ticket::where('id', $request->input('id'))
->where('user_id', $request->session()->get('id'))
->first();
if (!$ticket) {
abort(500, '工单不存在');
}
$ticket['message'] = TicketMessage::where('ticket_id', $ticket->id)->get();
2019-12-12 20:27:24 +08:00
for ($i = 0; $i < count($ticket['message']); $i++) {
2019-12-13 22:30:45 +08:00
if ($ticket['message'][$i]['user_id'] == $ticket->user_id) {
2019-12-12 20:26:56 +08:00
$ticket['message'][$i]['is_me'] = true;
} else {
$ticket['message'][$i]['is_me'] = false;
}
}
2019-12-12 20:08:20 +08:00
return response([
'data' => $ticket
]);
}
2019-12-13 17:13:10 +08:00
$ticket = Ticket::where('user_id', $request->session()->get('id'))
->orderBy('created_at', 'DESC')
->get();
for ($i = 0; $i < count($ticket); $i++) {
2019-12-13 17:16:53 +08:00
if ($ticket[$i]['last_reply_user_id'] == $request->session()->get('id')) {
2019-12-13 17:13:10 +08:00
$ticket[$i]['reply_status'] = 0;
} else {
$ticket[$i]['reply_status'] = 1;
}
}
2019-12-12 19:47:32 +08:00
return response([
2019-12-13 17:13:10 +08:00
'data' => $ticket
2019-12-12 19:47:32 +08:00
]);
}
2020-01-11 13:36:52 +08:00
public function save(TicketSave $request)
{
2019-12-12 19:47:32 +08:00
DB::beginTransaction();
2020-04-07 01:19:52 +08:00
if ((int)Ticket::where('status', 0)->where('user_id', $request->session()->get('id'))->count()) {
2020-04-07 00:40:52 +08:00
abort(500, '存在其他工单尚未处理');
}
2019-12-12 19:47:32 +08:00
$ticket = Ticket::create(array_merge($request->only([
'subject',
'level'
]), [
2019-12-13 17:07:46 +08:00
'user_id' => $request->session()->get('id'),
'last_reply_user_id' => $request->session()->get('id')
2019-12-12 19:47:32 +08:00
]));
if (!$ticket) {
DB::rollback();
abort(500, '工单创建失败');
}
$ticketMessage = TicketMessage::create([
'user_id' => $request->session()->get('id'),
'ticket_id' => $ticket->id,
'message' => $request->input('message')
]);
if (!$ticketMessage) {
DB::rollback();
abort(500, '工单创建失败');
}
DB::commit();
2020-05-25 15:48:12 +08:00
$this->sendNotify($ticket, $ticketMessage);
2019-12-12 19:47:32 +08:00
return response([
'data' => true
]);
}
2019-12-12 20:33:14 +08:00
2020-01-11 13:36:52 +08:00
public function reply(Request $request)
{
2019-12-13 15:16:44 +08:00
if (empty($request->input('id'))) {
2019-12-12 20:33:14 +08:00
abort(500, '参数错误');
}
2019-12-13 15:16:44 +08:00
if (empty($request->input('message'))) {
abort(500, '消息不能为空');
}
2019-12-12 20:33:14 +08:00
$ticket = Ticket::where('id', $request->input('id'))
->where('user_id', $request->session()->get('id'))
->first();
if (!$ticket) {
abort(500, '工单不存在');
}
2019-12-13 17:37:51 +08:00
if ($ticket->status) {
abort(500, '工单已关闭,无法回复');
}
2019-12-13 16:17:01 +08:00
if ($request->session()->get('id') == $this->getLastMessage($ticket->id)->user_id) {
2019-12-13 16:16:20 +08:00
abort(500, '请等待技术支持回复');
2019-12-13 16:16:09 +08:00
}
2019-12-13 17:07:46 +08:00
DB::beginTransaction();
2019-12-12 20:33:14 +08:00
$ticketMessage = TicketMessage::create([
'user_id' => $request->session()->get('id'),
'ticket_id' => $ticket->id,
'message' => $request->input('message')
]);
2019-12-13 17:07:46 +08:00
$ticket->last_reply_user_id = $request->session()->get('id');
if (!$ticketMessage || !$ticket->save()) {
DB::rollback();
2019-12-12 20:33:14 +08:00
abort(500, '工单回复失败');
}
2019-12-13 17:07:46 +08:00
DB::commit();
2020-05-25 15:48:12 +08:00
$this->sendNotify($ticket, $ticketMessage);
2019-12-12 20:33:14 +08:00
return response([
'data' => true
]);
}
2019-12-13 16:16:09 +08:00
2019-12-13 17:29:55 +08:00
2020-01-11 13:36:52 +08:00
public function close(Request $request)
{
2019-12-13 17:29:55 +08:00
if (empty($request->input('id'))) {
abort(500, '参数错误');
}
$ticket = Ticket::where('id', $request->input('id'))
->where('user_id', $request->session()->get('id'))
->first();
if (!$ticket) {
abort(500, '工单不存在');
}
$ticket->status = 1;
if (!$ticket->save()) {
abort(500, '关闭失败');
}
return response([
'data' => true
]);
}
2020-01-11 13:36:52 +08:00
private function getLastMessage($ticketId)
{
2019-12-13 16:16:09 +08:00
return TicketMessage::where('ticket_id', $ticketId)
->orderBy('id', 'DESC')
->first();
}
2020-05-10 18:38:02 +08:00
public function withdraw(TicketWithdraw $request)
{
DB::beginTransaction();
$subject = '[提现申请]本工单由系统发出';
$ticket = Ticket::create([
'subject' => $subject,
'level' => 2,
'user_id' => $request->session()->get('id'),
'last_reply_user_id' => $request->session()->get('id')
]);
if (!$ticket) {
DB::rollback();
abort(500, '工单创建失败');
}
$methodText = [
'alipay' => '支付宝',
'paypal' => '贝宝(Paypal)',
'usdt' => 'USDT',
'btc' => '比特币'
];
$message = "提现方式:{$methodText[$request->input('withdraw_method')]}\r\n提现账号:{$request->input('withdraw_account')}\r\n";
$ticketMessage = TicketMessage::create([
'user_id' => $request->session()->get('id'),
'ticket_id' => $ticket->id,
'message' => $message
]);
if (!$ticketMessage) {
DB::rollback();
abort(500, '工单创建失败');
}
DB::commit();
2020-05-25 16:01:52 +08:00
$this->sendNotify($ticket, $ticketMessage);
2020-05-10 18:38:02 +08:00
return response([
'data' => true
]);
}
2020-05-12 20:03:41 +08:00
private function sendNotify(Ticket $ticket, TicketMessage $ticketMessage)
{
2020-05-25 15:50:10 +08:00
if (!config('v2board.telegram_bot_enable', 0)) return;
2020-05-25 15:48:12 +08:00
$users = User::where('is_admin', 1)
->where('telegram_id', '!=', NULL)
->get();
foreach ($users as $user) {
2020-05-25 16:39:35 +08:00
$text = "📮工单提醒 #{$ticket->id}\n———————————————\n主题:\n`{$ticket->subject}`\n内容:\n`{$ticketMessage->message}`";
2020-05-25 15:48:12 +08:00
SendTelegramJob::dispatch($user->telegram_id, $text);
}
2020-05-12 20:03:41 +08:00
}
2019-12-12 19:47:32 +08:00
}