TicketController.php 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  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. return response([
  22. 'data' => $ticket
  23. ]);
  24. }
  25. return response([
  26. 'data' => Ticket::where('user_id', $request->session()->get('id'))
  27. ->orderBy('created_at', 'DESC')
  28. ->get()
  29. ]);
  30. }
  31. public function save (TicketSave $request) {
  32. DB::beginTransaction();
  33. $ticket = Ticket::create(array_merge($request->only([
  34. 'subject',
  35. 'level'
  36. ]), [
  37. 'user_id' => $request->session()->get('id')
  38. ]));
  39. if (!$ticket) {
  40. DB::rollback();
  41. abort(500, '工单创建失败');
  42. }
  43. $ticketMessage = TicketMessage::create([
  44. 'user_id' => $request->session()->get('id'),
  45. 'ticket_id' => $ticket->id,
  46. 'message' => $request->input('message')
  47. ]);
  48. if (!$ticketMessage) {
  49. DB::rollback();
  50. abort(500, '工单创建失败');
  51. }
  52. DB::commit();
  53. return response([
  54. 'data' => true
  55. ]);
  56. }
  57. }