TicketController.php 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  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 index (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'] == $request->session()->get('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_replay_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 ($request->session()->get('id') == $this->getLastMessage($ticket->id)->user_id) {
  87. abort(500, '请等待技术支持回复');
  88. }
  89. DB::beginTransaction();
  90. $ticketMessage = TicketMessage::create([
  91. 'user_id' => $request->session()->get('id'),
  92. 'ticket_id' => $ticket->id,
  93. 'message' => $request->input('message')
  94. ]);
  95. $ticket->last_reply_user_id = $request->session()->get('id');
  96. if (!$ticketMessage || !$ticket->save()) {
  97. DB::rollback();
  98. abort(500, '工单回复失败');
  99. }
  100. DB::commit();
  101. return response([
  102. 'data' => true
  103. ]);
  104. }
  105. private function getLastMessage ($ticketId) {
  106. return TicketMessage::where('ticket_id', $ticketId)
  107. ->orderBy('id', 'DESC')
  108. ->first();
  109. }
  110. }