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(); for ($i = 0; $i <= count($ticket['message']); $i++) { if ($ticket['message'][$i]['user_id'] == $request->session()->get('id')) { $ticket['message'][$i]['is_me'] = true; } else { $ticket['message'][$i]['is_me'] = false; } } 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 ]); } }