Files
Xboard/app/Http/Controllers/V1/User/TicketController.php

159 lines
5.6 KiB
PHP
Raw Normal View History

2023-11-17 14:44:01 +08:00
<?php
namespace App\Http\Controllers\V1\User;
use App\Http\Controllers\Controller;
use App\Http\Requests\User\TicketSave;
use App\Http\Requests\User\TicketWithdraw;
use App\Http\Resources\TicketResource;
2023-11-17 14:44:01 +08:00
use App\Models\Ticket;
use App\Models\TicketMessage;
use App\Models\User;
use App\Services\TicketService;
use App\Utils\Dict;
use Illuminate\Http\Request;
use App\Services\Plugin\HookManager;
use Illuminate\Support\Facades\Log;
2023-11-17 14:44:01 +08:00
class TicketController extends Controller
{
public function fetch(Request $request)
{
if ($request->input('id')) {
$ticket = Ticket::where('id', $request->input('id'))
2025-01-21 14:57:54 +08:00
->where('user_id', $request->user()->id)
->first()
->load('message');
2023-11-17 14:44:01 +08:00
if (!$ticket) {
return $this->fail([400, __('Ticket does not exist')]);
2023-11-17 14:44:01 +08:00
}
$ticket['message'] = TicketMessage::where('ticket_id', $ticket->id)->get();
$ticket['message']->each(function ($message) use ($ticket) {
$message['is_me'] = ($message['user_id'] == $ticket->user_id);
});
return $this->success(TicketResource::make($ticket)->additional(['message' => true]));
2023-11-17 14:44:01 +08:00
}
2025-01-21 14:57:54 +08:00
$ticket = Ticket::where('user_id', $request->user()->id)
2023-11-17 14:44:01 +08:00
->orderBy('created_at', 'DESC')
->get();
return $this->success(TicketResource::collection($ticket));
2023-11-17 14:44:01 +08:00
}
public function save(TicketSave $request)
{
try {
$ticketService = new TicketService();
$ticket = $ticketService->createTicket(
$request->user()->id,
$request->input('subject'),
$request->input('level'),
$request->input('message')
);
HookManager::call('ticket.create.after', $ticket);
return $this->success(true);
} catch (\Exception $e) {
Log::error($e);
return $this->fail([400, $e->getMessage()]);
2023-11-17 14:44:01 +08:00
}
}
public function reply(Request $request)
{
if (empty($request->input('id'))) {
return $this->fail([400, __('Invalid parameter')]);
2023-11-17 14:44:01 +08:00
}
if (empty($request->input('message'))) {
return $this->fail([400, __('Message cannot be empty')]);
2023-11-17 14:44:01 +08:00
}
$ticket = Ticket::where('id', $request->input('id'))
2025-01-21 14:57:54 +08:00
->where('user_id', $request->user()->id)
2023-11-17 14:44:01 +08:00
->first();
if (!$ticket) {
return $this->fail([400, __('Ticket does not exist')]);
2023-11-17 14:44:01 +08:00
}
if ($ticket->status) {
return $this->fail([400, __('The ticket is closed and cannot be replied')]);
2023-11-17 14:44:01 +08:00
}
2025-01-21 14:57:54 +08:00
if ($request->user()->id == $this->getLastMessage($ticket->id)->user_id) {
return $this->fail(codeResponse: [400, __('Please wait for the technical enginneer to reply')]);
2023-11-17 14:44:01 +08:00
}
$ticketService = new TicketService();
if (
!$ticketService->reply(
$ticket,
$request->input('message'),
$request->user()->id
)
) {
return $this->fail([400, __('Ticket reply failed')]);
2023-11-17 14:44:01 +08:00
}
HookManager::call('ticket.reply.user.after', [$ticket, $this->getLastMessage($ticket->id)]);
return $this->success(true);
2023-11-17 14:44:01 +08:00
}
public function close(Request $request)
{
if (empty($request->input('id'))) {
return $this->fail([422, __('Invalid parameter')]);
2023-11-17 14:44:01 +08:00
}
$ticket = Ticket::where('id', $request->input('id'))
2025-01-21 14:57:54 +08:00
->where('user_id', $request->user()->id)
2023-11-17 14:44:01 +08:00
->first();
if (!$ticket) {
return $this->fail([400, __('Ticket does not exist')]);
2023-11-17 14:44:01 +08:00
}
$ticket->status = Ticket::STATUS_CLOSED;
2023-11-17 14:44:01 +08:00
if (!$ticket->save()) {
return $this->fail([500, __('Close failed')]);
2023-11-17 14:44:01 +08:00
}
return $this->success(true);
2023-11-17 14:44:01 +08:00
}
private function getLastMessage($ticketId)
{
return TicketMessage::where('ticket_id', $ticketId)
->orderBy('id', 'DESC')
->first();
}
public function withdraw(TicketWithdraw $request)
{
if ((int) admin_setting('withdraw_close_enable', 0)) {
return $this->fail([400, 'Unsupported withdraw']);
2023-11-17 14:44:01 +08:00
}
if (
!in_array(
$request->input('withdraw_method'),
admin_setting('commission_withdraw_method', Dict::WITHDRAW_METHOD_WHITELIST_DEFAULT)
)
) {
return $this->fail([422, __('Unsupported withdrawal method')]);
2023-11-17 14:44:01 +08:00
}
2025-01-21 14:57:54 +08:00
$user = User::find($request->user()->id);
2023-11-17 14:44:01 +08:00
$limit = admin_setting('commission_withdraw_limit', 100);
if ($limit > ($user->commission_balance / 100)) {
return $this->fail([422, __('The current required minimum withdrawal commission is :limit', ['limit' => $limit])]);
2023-11-17 14:44:01 +08:00
}
try {
$ticketService = new TicketService();
$subject = __('[Commission Withdrawal Request] This ticket is opened by the system');
$message = sprintf(
"%s\r\n%s",
__('Withdrawal method') . "" . $request->input('withdraw_method'),
__('Withdrawal account') . "" . $request->input('withdraw_account')
);
$ticket = $ticketService->createTicket(
$request->user()->id,
$subject,
2,
$message
);
} catch (\Exception $e) {
throw $e;
2023-11-17 14:44:01 +08:00
}
HookManager::call('ticket.create.after', $ticket);
return $this->success(true);
2023-11-17 14:44:01 +08:00
}
}