TicketController.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <?php
  2. namespace App\Http\Controllers\User;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\User\TicketSave;
  5. use Illuminate\Http\Request;
  6. use App\Models\Ticket;
  7. use App\Models\TicketMessage;
  8. use App\Utils\Helper;
  9. use Illuminate\Support\Facades\DB;
  10. class TicketController extends Controller
  11. {
  12. public function fetch(Request $request)
  13. {
  14. if ($request->input('id')) {
  15. $ticket = Ticket::where('id', $request->input('id'))
  16. ->where('user_id', $request->session()->get('id'))
  17. ->first();
  18. if (!$ticket) {
  19. abort(500, '工单不存在');
  20. }
  21. $ticket['message'] = TicketMessage::where('ticket_id', $ticket->id)->get();
  22. for ($i = 0; $i < count($ticket['message']); $i++) {
  23. if ($ticket['message'][$i]['user_id'] == $ticket->user_id) {
  24. $ticket['message'][$i]['is_me'] = true;
  25. } else {
  26. $ticket['message'][$i]['is_me'] = false;
  27. }
  28. }
  29. return response([
  30. 'data' => $ticket
  31. ]);
  32. }
  33. $ticket = Ticket::where('user_id', $request->session()->get('id'))
  34. ->orderBy('created_at', 'DESC')
  35. ->get();
  36. for ($i = 0; $i < count($ticket); $i++) {
  37. if ($ticket[$i]['last_reply_user_id'] == $request->session()->get('id')) {
  38. $ticket[$i]['reply_status'] = 0;
  39. } else {
  40. $ticket[$i]['reply_status'] = 1;
  41. }
  42. }
  43. return response([
  44. 'data' => $ticket
  45. ]);
  46. }
  47. public function save(TicketSave $request)
  48. {
  49. DB::beginTransaction();
  50. if ((int)Ticket::where('status', 0)->where('user_id', $request->session()->get('id'))->count()) {
  51. abort(500, '存在其他工单尚未处理');
  52. }
  53. $ticket = Ticket::create(array_merge($request->only([
  54. 'subject',
  55. 'level'
  56. ]), [
  57. 'user_id' => $request->session()->get('id'),
  58. 'last_reply_user_id' => $request->session()->get('id')
  59. ]));
  60. if (!$ticket) {
  61. DB::rollback();
  62. abort(500, '工单创建失败');
  63. }
  64. $ticketMessage = TicketMessage::create([
  65. 'user_id' => $request->session()->get('id'),
  66. 'ticket_id' => $ticket->id,
  67. 'message' => $request->input('message')
  68. ]);
  69. if (!$ticketMessage) {
  70. DB::rollback();
  71. abort(500, '工单创建失败');
  72. }
  73. DB::commit();
  74. return response([
  75. 'data' => true
  76. ]);
  77. }
  78. public function reply(Request $request)
  79. {
  80. if (empty($request->input('id'))) {
  81. abort(500, '参数错误');
  82. }
  83. if (empty($request->input('message'))) {
  84. abort(500, '消息不能为空');
  85. }
  86. $ticket = Ticket::where('id', $request->input('id'))
  87. ->where('user_id', $request->session()->get('id'))
  88. ->first();
  89. if (!$ticket) {
  90. abort(500, '工单不存在');
  91. }
  92. if ($ticket->status) {
  93. abort(500, '工单已关闭,无法回复');
  94. }
  95. if ($request->session()->get('id') == $this->getLastMessage($ticket->id)->user_id) {
  96. abort(500, '请等待技术支持回复');
  97. }
  98. DB::beginTransaction();
  99. $ticketMessage = TicketMessage::create([
  100. 'user_id' => $request->session()->get('id'),
  101. 'ticket_id' => $ticket->id,
  102. 'message' => $request->input('message')
  103. ]);
  104. $ticket->last_reply_user_id = $request->session()->get('id');
  105. if (!$ticketMessage || !$ticket->save()) {
  106. DB::rollback();
  107. abort(500, '工单回复失败');
  108. }
  109. DB::commit();
  110. return response([
  111. 'data' => true
  112. ]);
  113. }
  114. public function close(Request $request)
  115. {
  116. if (empty($request->input('id'))) {
  117. abort(500, '参数错误');
  118. }
  119. $ticket = Ticket::where('id', $request->input('id'))
  120. ->where('user_id', $request->session()->get('id'))
  121. ->first();
  122. if (!$ticket) {
  123. abort(500, '工单不存在');
  124. }
  125. $ticket->status = 1;
  126. if (!$ticket->save()) {
  127. abort(500, '关闭失败');
  128. }
  129. return response([
  130. 'data' => true
  131. ]);
  132. }
  133. private function getLastMessage($ticketId)
  134. {
  135. return TicketMessage::where('ticket_id', $ticketId)
  136. ->orderBy('id', 'DESC')
  137. ->first();
  138. }
  139. }