collect(); return $this->response->paginator($users, new Transformer()); } /** * Display the specified resource. * * @param int $id * @return \Dingo\Api\Http\Response */ public function show($id) { $user = User::with(['roles', 'permissions'])->findOrFail($id); return $this->response->item($user, new Transformer()); } /** * Store a newly created resource in storage. * * @param $request * @return \Dingo\Api\Http\Response */ public function store(Request $request) { $user = User::create($request->input()); if ($request->has('roles')) { $user->roles()->attach($request->get('roles')); } if ($request->has('companies')) { $user->companies()->attach($request->get('companies')); } return $this->response->created(url('api/users/'.$user->id)); } /** * Update the specified resource in storage. * * @param $user * @param $request * @return \Dingo\Api\Http\Response */ public function update(User $user, Request $request) { // Except password as we don't want to let the users change a password from this endpoint $user->update($request->except('password')); if ($request->has('roles')) { $user->roles()->attach($request->get('roles')); } if ($request->has('companies')) { $user->companies()->attach($request->get('companies')); } return $this->response->item($user->fresh(), new Transformer()); } /** * Remove the specified resource from storage. * * @param User $user * @return \Dingo\Api\Http\Response */ public function destroy(User $user) { $user->delete(); return $this->response->noContent(); } }