TicketController.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Components\Helpers;
  4. use App\Components\PushNotification;
  5. use App\Http\Controllers\Controller;
  6. use App\Mail\closeTicket;
  7. use App\Mail\replyTicket;
  8. use App\Models\Ticket;
  9. use App\Models\TicketReply;
  10. use App\Models\User;
  11. use Auth;
  12. use Illuminate\Http\JsonResponse;
  13. use Illuminate\Http\Request;
  14. use Mail;
  15. use Response;
  16. /**
  17. * 工单控制器
  18. *
  19. * Class TicketController
  20. *
  21. * @package App\Http\Controllers\Controller
  22. */
  23. class TicketController extends Controller
  24. {
  25. // 工单列表
  26. public function ticketList(Request $request)
  27. {
  28. $email = $request->input('email');
  29. $query = Ticket::whereIn('admin_id', [0, Auth::id()]);
  30. if (isset($email)) {
  31. $query->whereHas(
  32. 'user',
  33. static function ($q) use ($email) {
  34. $q->where('email', 'like', '%' . $email . '%');
  35. }
  36. );
  37. }
  38. $view['ticketList'] = $query->latest()->paginate(10)->appends(
  39. $request->except('page')
  40. );
  41. return view('admin.ticket.ticketList', $view);
  42. }
  43. // 创建工单
  44. public function createTicket(Request $request): ?JsonResponse
  45. {
  46. $id = $request->input('id');
  47. $email = $request->input('email');
  48. $title = $request->input('title');
  49. $content = $request->input('content');
  50. $user = User::find($id) ?: User::whereEmail($email)->first();
  51. if ( ! $user) {
  52. return Response::json(['status' => 'fail', 'message' => '用户不存在']);
  53. }
  54. if ($user == Auth::user()) {
  55. return Response::json(
  56. ['status' => 'fail', 'message' => '不能对自己发起工单']
  57. );
  58. }
  59. if (empty($title) || empty($content)) {
  60. return Response::json(
  61. ['status' => 'fail', 'message' => '请输入标题和内容']
  62. );
  63. }
  64. $obj = new Ticket();
  65. $obj->user_id = $user->id;
  66. $obj->admin_id = Auth::id();
  67. $obj->title = $title;
  68. $obj->content = $content;
  69. $obj->status = 0;
  70. $obj->save();
  71. if ($obj->id) {
  72. return Response::json(
  73. ['status' => 'success', 'message' => '工单创建成功']
  74. );
  75. }
  76. return Response::json(['status' => 'fail', 'message' => '工单创建失败']);
  77. }
  78. // 回复工单
  79. public function replyTicket(Request $request)
  80. {
  81. $id = $request->input('id');
  82. if ($request->isMethod('POST')) {
  83. $content = clean($request->input('content'));
  84. $content = str_replace(["atob", "eval"], "", $content);
  85. $content = substr($content, 0, 300);
  86. $obj = new TicketReply();
  87. $obj->ticket_id = $id;
  88. $obj->admin_id = Auth::id();
  89. $obj->content = $content;
  90. $obj->save();
  91. if ($obj->id) {
  92. // 将工单置为已回复
  93. $ticket = Ticket::with('user')->whereId($id)->firstOrFail();
  94. Ticket::whereId($id)->update(['status' => 1]);
  95. $title = "工单回复提醒";
  96. $content = "标题:" . $ticket->title . "<br>管理员回复:" . $content;
  97. // 发通知邮件
  98. if ( ! Auth::getUser()->is_admin) {
  99. if (sysConfig('webmaster_email')) {
  100. $logId = Helpers::addNotificationLog(
  101. $title,
  102. $content,
  103. 1,
  104. sysConfig(
  105. 'webmaster_email'
  106. )
  107. );
  108. Mail::to(sysConfig('webmaster_email'))->send(
  109. new replyTicket($logId, $title, $content)
  110. );
  111. }
  112. // 推送通知管理员
  113. PushNotification::send($title, $content);
  114. } else {
  115. $logId = Helpers::addNotificationLog(
  116. $title,
  117. $content,
  118. 1,
  119. $ticket->user->email
  120. );
  121. Mail::to($ticket->user->email)->send(
  122. new replyTicket($logId, $title, $content)
  123. );
  124. }
  125. return Response::json(
  126. ['status' => 'success', 'message' => '回复成功']
  127. );
  128. }
  129. return Response::json(['status' => 'fail', 'message' => '回复失败']);
  130. }
  131. $view['ticket'] = Ticket::find($id);
  132. $view['replyList'] = TicketReply::whereTicketId($id)->oldest()->get();
  133. return view('admin.ticket.replyTicket', $view);
  134. }
  135. // 关闭工单
  136. public function closeTicket(Request $request): JsonResponse
  137. {
  138. $id = $request->input('id');
  139. $ticket = Ticket::with('user')->whereId($id)->first();
  140. if ( ! $ticket) {
  141. return Response::json(['status' => 'fail', 'message' => '关闭失败']);
  142. }
  143. $ret = Ticket::whereId($id)->update(['status' => 2]);
  144. if ( ! $ret) {
  145. return Response::json(['status' => 'fail', 'message' => '关闭失败']);
  146. }
  147. $title = "工单关闭提醒";
  148. $content = "工单【" . $ticket->title . "】已关闭";
  149. // 发邮件通知用户
  150. $logId = Helpers::addNotificationLog(
  151. $title,
  152. $content,
  153. 1,
  154. $ticket->user->email
  155. );
  156. Mail::to($ticket->user->email)->send(
  157. new closeTicket($logId, $title, $content)
  158. );
  159. return Response::json(['status' => 'success', 'message' => '关闭成功']);
  160. }
  161. }