TicketController.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  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. return response([
  33. 'data' => Ticket::where('user_id', $request->session()->get('id'))
  34. ->orderBy('created_at', 'DESC')
  35. ->get()
  36. ]);
  37. }
  38. public function save (TicketSave $request) {
  39. DB::beginTransaction();
  40. $ticket = Ticket::create(array_merge($request->only([
  41. 'subject',
  42. 'level'
  43. ]), [
  44. 'user_id' => $request->session()->get('id'),
  45. 'last_reply_user_id' => $request->session()->get('id')
  46. ]));
  47. if (!$ticket) {
  48. DB::rollback();
  49. abort(500, '工单创建失败');
  50. }
  51. $ticketMessage = TicketMessage::create([
  52. 'user_id' => $request->session()->get('id'),
  53. 'ticket_id' => $ticket->id,
  54. 'message' => $request->input('message')
  55. ]);
  56. if (!$ticketMessage) {
  57. DB::rollback();
  58. abort(500, '工单创建失败');
  59. }
  60. DB::commit();
  61. return response([
  62. 'data' => true
  63. ]);
  64. }
  65. public function reply (Request $request) {
  66. if (empty($request->input('id'))) {
  67. abort(500, '参数错误');
  68. }
  69. if (empty($request->input('message'))) {
  70. abort(500, '消息不能为空');
  71. }
  72. $ticket = Ticket::where('id', $request->input('id'))
  73. ->where('user_id', $request->session()->get('id'))
  74. ->first();
  75. if (!$ticket) {
  76. abort(500, '工单不存在');
  77. }
  78. if ($request->session()->get('id') == $this->getLastMessage($ticket->id)->user_id) {
  79. abort(500, '请等待技术支持回复');
  80. }
  81. DB::beginTransaction();
  82. $ticketMessage = TicketMessage::create([
  83. 'user_id' => $request->session()->get('id'),
  84. 'ticket_id' => $ticket->id,
  85. 'message' => $request->input('message')
  86. ]);
  87. $ticket->last_reply_user_id = $request->session()->get('id');
  88. if (!$ticketMessage || !$ticket->save()) {
  89. DB::rollback();
  90. abort(500, '工单回复失败');
  91. }
  92. DB::commit();
  93. return response([
  94. 'data' => true
  95. ]);
  96. }
  97. private function getLastMessage ($ticketId) {
  98. return TicketMessage::where('ticket_id', $ticketId)
  99. ->orderBy('id', 'DESC')
  100. ->first();
  101. }
  102. }