TicketController.php 4.4 KB

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