input('id')) { $ticket = Ticket::where('id', $request->input('id')) ->where('user_id', $request->session()->get('id')) ->first(); if (!$ticket) { abort(500, '工单不存在'); } $ticket['message'] = TicketMessage::where('ticket_id', $ticket->id)->get(); return response([ 'data' => $ticket ]); } return response([ 'data' => Ticket::where('user_id', $request->session()->get('id')) ->orderBy('created_at', 'DESC') ->get() ]); } public function save (TicketSave $request) { DB::beginTransaction(); $ticket = Ticket::create(array_merge($request->only([ 'subject', 'level' ]), [ 'user_id' => $request->session()->get('id') ])); if (!$ticket) { DB::rollback(); abort(500, '工单创建失败'); } $ticketMessage = TicketMessage::create([ 'user_id' => $request->session()->get('id'), 'ticket_id' => $ticket->id, 'message' => $request->input('message') ]); if (!$ticketMessage) { DB::rollback(); abort(500, '工单创建失败'); } DB::commit(); return response([ 'data' => true ]); } }