2017-01-12 19:40:20 -08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Http\Controllers\Api;
|
|
|
|
|
|
|
|
use Illuminate\Http\Request;
|
|
|
|
use App\Http\Controllers\Controller;
|
2017-01-12 23:42:39 -08:00
|
|
|
use App\Http\Transformers\UsersTransformer;
|
2017-01-13 04:50:20 -08:00
|
|
|
use App\Models\Company;
|
2017-01-12 23:42:39 -08:00
|
|
|
use App\Models\User;
|
2017-08-03 19:50:18 -07:00
|
|
|
use App\Helpers\Helper;
|
2017-08-22 20:32:39 -07:00
|
|
|
use App\Http\Requests\SaveUserRequest;
|
2017-08-26 15:21:38 -07:00
|
|
|
use App\Models\Asset;
|
2017-10-24 19:18:20 -07:00
|
|
|
use App\Http\Transformers\AssetsTransformer;
|
2017-10-26 21:50:01 -07:00
|
|
|
use App\Http\Transformers\SelectlistTransformer;
|
2017-01-12 19:40:20 -08:00
|
|
|
|
|
|
|
class UsersController extends Controller
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Display a listing of the resource.
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v4.0]
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
2017-01-13 04:50:20 -08:00
|
|
|
public function index(Request $request)
|
2017-01-12 19:40:20 -08:00
|
|
|
{
|
2017-01-12 23:42:39 -08:00
|
|
|
$this->authorize('view', User::class);
|
2017-01-13 04:50:20 -08:00
|
|
|
|
|
|
|
$users = User::select([
|
2018-02-24 19:01:34 -08:00
|
|
|
'users.activated',
|
2017-10-30 18:57:00 -07:00
|
|
|
'users.address',
|
2018-02-24 19:01:34 -08:00
|
|
|
'users.avatar',
|
2017-10-30 18:57:00 -07:00
|
|
|
'users.city',
|
2018-02-24 19:01:34 -08:00
|
|
|
'users.company_id',
|
2017-10-30 18:57:00 -07:00
|
|
|
'users.country',
|
2017-01-13 04:50:20 -08:00
|
|
|
'users.created_at',
|
|
|
|
'users.deleted_at',
|
2017-05-23 02:46:55 -07:00
|
|
|
'users.department_id',
|
2018-02-24 19:01:34 -08:00
|
|
|
'users.email',
|
|
|
|
'users.employee_num',
|
|
|
|
'users.first_name',
|
|
|
|
'users.id',
|
|
|
|
'users.jobtitle',
|
|
|
|
'users.last_login',
|
|
|
|
'users.last_name',
|
|
|
|
'users.location_id',
|
|
|
|
'users.manager_id',
|
|
|
|
'users.notes',
|
|
|
|
'users.permissions',
|
|
|
|
'users.phone',
|
|
|
|
'users.state',
|
|
|
|
'users.two_factor_enrolled',
|
|
|
|
'users.updated_at',
|
|
|
|
'users.username',
|
|
|
|
'users.zip',
|
2017-10-24 09:51:07 -07:00
|
|
|
|
2017-11-02 11:06:15 -07:00
|
|
|
])->with('manager', 'groups', 'userloc', 'company', 'department','assets','licenses','accessories','consumables')
|
2018-07-24 22:40:05 -07:00
|
|
|
->withCount('assets as assets_count','licenses as licneses_count','accessories as accessories_count','consumables as consumables_count');
|
2017-01-13 04:50:20 -08:00
|
|
|
$users = Company::scopeCompanyables($users);
|
|
|
|
|
|
|
|
|
2018-07-24 22:51:31 -07:00
|
|
|
if (($request->filled('deleted')) && ($request->input('deleted')=='true')) {
|
2017-09-06 17:11:43 -07:00
|
|
|
$users = $users->GetDeleted();
|
|
|
|
}
|
|
|
|
|
2018-07-24 22:51:31 -07:00
|
|
|
if ($request->filled('company_id')) {
|
2017-12-11 22:50:55 -08:00
|
|
|
$users = $users->where('users.company_id', '=', $request->input('company_id'));
|
2017-06-12 17:39:03 -07:00
|
|
|
}
|
|
|
|
|
2018-07-24 22:51:31 -07:00
|
|
|
if ($request->filled('location_id')) {
|
2017-12-11 22:50:55 -08:00
|
|
|
$users = $users->where('users.location_id', '=', $request->input('location_id'));
|
2017-02-08 08:48:41 -08:00
|
|
|
}
|
2018-02-24 19:01:34 -08:00
|
|
|
|
2018-07-24 22:51:31 -07:00
|
|
|
if ($request->filled('group_id')) {
|
2017-10-24 04:39:47 -07:00
|
|
|
$users = $users->ByGroup($request->get('group_id'));
|
2017-10-17 21:43:57 -07:00
|
|
|
}
|
2017-02-08 08:48:41 -08:00
|
|
|
|
2018-07-24 22:51:31 -07:00
|
|
|
if ($request->filled('department_id')) {
|
2017-11-03 14:29:04 -07:00
|
|
|
$users = $users->where('users.department_id','=',$request->input('department_id'));
|
2017-05-23 01:09:03 -07:00
|
|
|
}
|
|
|
|
|
2018-07-24 22:51:31 -07:00
|
|
|
if ($request->filled('search')) {
|
2018-01-11 15:17:34 -08:00
|
|
|
$users = $users->TextSearch($request->input('search'));
|
|
|
|
}
|
|
|
|
|
2017-01-13 04:50:20 -08:00
|
|
|
$order = $request->input('order') === 'asc' ? 'asc' : 'desc';
|
|
|
|
$offset = request('offset', 0);
|
2017-11-02 11:19:34 -07:00
|
|
|
$limit = request('limit', 20);
|
2017-01-13 04:50:20 -08:00
|
|
|
|
|
|
|
switch ($request->input('sort')) {
|
|
|
|
case 'manager':
|
|
|
|
$users = $users->OrderManager($order);
|
|
|
|
break;
|
|
|
|
case 'location':
|
|
|
|
$users = $users->OrderLocation($order);
|
|
|
|
break;
|
2017-05-23 02:46:55 -07:00
|
|
|
case 'department':
|
|
|
|
$users = $users->OrderDepartment($order);
|
|
|
|
break;
|
2017-01-13 04:50:20 -08:00
|
|
|
default:
|
|
|
|
$allowed_columns =
|
|
|
|
[
|
|
|
|
'last_name','first_name','email','jobtitle','username','employee_num',
|
|
|
|
'assets','accessories', 'consumables','licenses','groups','activated','created_at',
|
2017-10-19 17:15:21 -07:00
|
|
|
'two_factor_enrolled','two_factor_optin','last_login', 'assets_count', 'licenses_count',
|
2017-10-30 18:57:00 -07:00
|
|
|
'consumables_count', 'accessories_count', 'phone', 'address', 'city', 'state',
|
2018-07-23 06:46:50 -07:00
|
|
|
'country', 'zip', 'id'
|
2017-01-13 04:50:20 -08:00
|
|
|
];
|
|
|
|
|
|
|
|
$sort = in_array($request->get('sort'), $allowed_columns) ? $request->get('sort') : 'first_name';
|
|
|
|
$users = $users->orderBy($sort, $order);
|
|
|
|
break;
|
|
|
|
}
|
2018-01-11 15:17:34 -08:00
|
|
|
|
|
|
|
|
2017-05-23 14:30:07 -07:00
|
|
|
$total = $users->count();
|
2017-01-13 04:50:20 -08:00
|
|
|
$users = $users->skip($offset)->take($limit)->get();
|
2017-05-23 14:30:07 -07:00
|
|
|
return (new UsersTransformer)->transformUsers($users, $total);
|
2017-01-12 19:40:20 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-10-24 19:24:35 -07:00
|
|
|
/**
|
2017-10-26 21:50:01 -07:00
|
|
|
* Gets a paginated collection for the select2 menus
|
2017-10-24 19:24:35 -07:00
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
2017-10-26 21:50:01 -07:00
|
|
|
* @since [v4.0.16]
|
|
|
|
* @see \App\Http\Transformers\SelectlistTransformer
|
2017-10-24 19:24:35 -07:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function selectlist(Request $request)
|
|
|
|
{
|
|
|
|
|
|
|
|
$users = User::select(
|
|
|
|
[
|
|
|
|
'users.id',
|
2018-01-19 23:47:37 -08:00
|
|
|
'users.username',
|
2017-10-24 19:24:35 -07:00
|
|
|
'users.employee_num',
|
|
|
|
'users.first_name',
|
|
|
|
'users.last_name',
|
|
|
|
'users.gravatar',
|
|
|
|
'users.avatar',
|
|
|
|
'users.email',
|
|
|
|
]
|
2018-07-18 03:59:02 -07:00
|
|
|
)->where('show_in_list', '=', '1');
|
2017-10-24 19:24:35 -07:00
|
|
|
|
|
|
|
$users = Company::scopeCompanyables($users);
|
|
|
|
|
2018-07-24 22:51:31 -07:00
|
|
|
if ($request->filled('search')) {
|
2017-10-28 11:17:52 -07:00
|
|
|
$users = $users->where('first_name', 'LIKE', '%'.$request->get('search').'%')
|
2017-10-24 19:24:35 -07:00
|
|
|
->orWhere('last_name', 'LIKE', '%'.$request->get('search').'%')
|
|
|
|
->orWhere('username', 'LIKE', '%'.$request->get('search').'%')
|
2017-10-28 11:17:52 -07:00
|
|
|
->orWhere('employee_num', 'LIKE', '%'.$request->get('search').'%');
|
2017-10-24 19:24:35 -07:00
|
|
|
}
|
|
|
|
|
2017-10-28 11:17:52 -07:00
|
|
|
$users = $users->orderBy('last_name', 'asc')->orderBy('first_name', 'asc');
|
2017-10-24 19:24:35 -07:00
|
|
|
$users = $users->paginate(50);
|
2017-10-26 21:50:01 -07:00
|
|
|
|
2017-10-24 19:24:35 -07:00
|
|
|
foreach ($users as $user) {
|
|
|
|
$name_str = '';
|
|
|
|
if ($user->last_name!='') {
|
|
|
|
$name_str .= e($user->last_name).', ';
|
|
|
|
}
|
|
|
|
$name_str .= e($user->first_name);
|
|
|
|
|
2018-01-19 23:47:37 -08:00
|
|
|
if ($user->username!='') {
|
|
|
|
$name_str .= ' ('.e($user->username).')';
|
|
|
|
}
|
|
|
|
|
2017-10-24 19:24:35 -07:00
|
|
|
if ($user->employee_num!='') {
|
2018-01-19 23:47:37 -08:00
|
|
|
$name_str .= ' - #'.e($user->employee_num);
|
2017-10-24 19:24:35 -07:00
|
|
|
}
|
|
|
|
|
2017-10-26 21:50:01 -07:00
|
|
|
$user->use_text = $name_str;
|
|
|
|
$user->use_image = ($user->present()->gravatar) ? $user->present()->gravatar : null;
|
2017-10-24 19:24:35 -07:00
|
|
|
}
|
2017-10-26 03:43:28 -07:00
|
|
|
|
2017-10-26 21:50:01 -07:00
|
|
|
return (new SelectlistTransformer)->transformSelectlist($users);
|
|
|
|
|
2017-10-24 19:24:35 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2017-01-12 19:40:20 -08:00
|
|
|
/**
|
|
|
|
* Store a newly created resource in storage.
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v4.0]
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
2017-08-22 20:32:39 -07:00
|
|
|
public function store(SaveUserRequest $request)
|
2017-01-12 19:40:20 -08:00
|
|
|
{
|
2018-07-12 18:28:02 -07:00
|
|
|
$this->authorize('create', User::class);
|
|
|
|
|
2017-08-03 19:50:18 -07:00
|
|
|
$user = new User;
|
|
|
|
$user->fill($request->all());
|
2018-04-20 14:02:52 -07:00
|
|
|
|
|
|
|
$tmp_pass = substr(str_shuffle("0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"), 0, 20);
|
|
|
|
$user->password = bcrypt($request->get('password', $tmp_pass));
|
2017-08-03 19:50:18 -07:00
|
|
|
|
2018-07-27 12:01:59 -07:00
|
|
|
|
2017-08-03 19:50:18 -07:00
|
|
|
if ($user->save()) {
|
2018-07-27 12:01:59 -07:00
|
|
|
if ($request->filled('groups')) {
|
|
|
|
$user->groups()->sync($request->input('groups'));
|
2018-09-19 17:24:29 -07:00
|
|
|
} else {
|
|
|
|
$user->groups()->sync(array());
|
2018-07-27 12:01:59 -07:00
|
|
|
}
|
2017-10-24 19:17:30 -07:00
|
|
|
return response()->json(Helper::formatStandardApiResponse('success', (new UsersTransformer)->transformUser($user), trans('admin/users/message.success.create')));
|
2017-08-03 19:50:18 -07:00
|
|
|
}
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, $user->getErrors()));
|
2017-01-12 19:40:20 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Display the specified resource.
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @param int $id
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function show($id)
|
|
|
|
{
|
2017-01-12 23:42:39 -08:00
|
|
|
$this->authorize('view', User::class);
|
|
|
|
$user = User::findOrFail($id);
|
|
|
|
return (new UsersTransformer)->transformUser($user);
|
2017-01-12 19:40:20 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update the specified resource in storage.
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v4.0]
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
* @param int $id
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
2017-08-22 20:32:39 -07:00
|
|
|
public function update(SaveUserRequest $request, $id)
|
2017-01-12 19:40:20 -08:00
|
|
|
{
|
2018-07-12 18:28:02 -07:00
|
|
|
$this->authorize('update', User::class);
|
|
|
|
|
2017-08-03 19:50:18 -07:00
|
|
|
$user = User::findOrFail($id);
|
|
|
|
$user->fill($request->all());
|
|
|
|
|
2017-11-03 12:48:00 -07:00
|
|
|
if ($user->id == $request->input('manager_id')) {
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, 'You cannot be your own manager'));
|
|
|
|
}
|
|
|
|
|
2018-07-24 22:51:31 -07:00
|
|
|
if ($request->filled('password')) {
|
2017-08-08 14:41:58 -07:00
|
|
|
$user->password = bcrypt($request->input('password'));
|
|
|
|
}
|
|
|
|
|
2017-10-30 19:33:52 -07:00
|
|
|
// Update the location of any assets checked out to this user
|
|
|
|
Asset::where('assigned_type', User::class)
|
|
|
|
->where('assigned_to', $user->id)->update(['location_id' => $request->input('location_id', null)]);
|
2017-08-08 14:41:58 -07:00
|
|
|
|
2017-08-03 19:50:18 -07:00
|
|
|
if ($user->save()) {
|
2018-07-27 12:01:59 -07:00
|
|
|
if ($request->filled('groups')) {
|
|
|
|
$user->groups()->sync($request->input('groups'));
|
|
|
|
}
|
2017-08-03 19:50:18 -07:00
|
|
|
return response()->json(Helper::formatStandardApiResponse('success', (new UsersTransformer)->transformUser($user), trans('admin/users/message.success.update')));
|
|
|
|
}
|
|
|
|
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, $user->getErrors()));
|
2017-01-12 19:40:20 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove the specified resource from storage.
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v4.0]
|
|
|
|
* @param int $id
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function destroy($id)
|
|
|
|
{
|
2017-08-03 19:50:18 -07:00
|
|
|
$this->authorize('delete', User::class);
|
|
|
|
$user = User::findOrFail($id);
|
|
|
|
$this->authorize('delete', $user);
|
|
|
|
|
|
|
|
|
|
|
|
if ($user->assets()->count() > 0) {
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, trans('admin/users/message.error.delete_has_assets')));
|
|
|
|
}
|
|
|
|
|
2018-09-29 21:33:52 -07:00
|
|
|
// Remove the user's avatar if they have one
|
|
|
|
if (Storage::disk('public')->exists('avatars/'.$user->avatar)) {
|
|
|
|
try {
|
|
|
|
Storage::disk('public')->delete('avatars/'.$user->avatar);
|
|
|
|
} catch (\Exception $e) {
|
|
|
|
\Log::debug($e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-03 19:50:18 -07:00
|
|
|
if ($user->delete()) {
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('success', null, trans('admin/users/message.success.delete')));
|
|
|
|
}
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, trans('admin/users/message.error.delete')));
|
2017-01-12 19:40:20 -08:00
|
|
|
}
|
2017-08-26 15:21:38 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return JSON containing a list of assets assigned to a user.
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v3.0]
|
|
|
|
* @param $userId
|
|
|
|
* @return string JSON
|
|
|
|
*/
|
|
|
|
public function assets($id)
|
|
|
|
{
|
|
|
|
$this->authorize('view', User::class);
|
2018-07-12 18:28:02 -07:00
|
|
|
$this->authorize('view', Asset::class);
|
2018-07-25 21:40:33 -07:00
|
|
|
$assets = Asset::where('assigned_to', '=', $id)->where('assigned_type', '=', User::class)->with('model')->get();
|
2017-10-24 19:18:20 -07:00
|
|
|
return (new AssetsTransformer)->transformAssets($assets, $assets->count());
|
2017-08-26 15:21:38 -07:00
|
|
|
}
|
2018-02-26 15:43:49 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Reset the user's two-factor status
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v3.0]
|
|
|
|
* @param $userId
|
|
|
|
* @return string JSON
|
|
|
|
*/
|
|
|
|
public function postTwoFactorReset(Request $request)
|
|
|
|
{
|
|
|
|
|
2018-07-12 18:28:02 -07:00
|
|
|
$this->authorize('update', User::class);
|
2018-02-26 15:43:49 -08:00
|
|
|
|
2018-07-24 22:51:31 -07:00
|
|
|
if ($request->filled('id')) {
|
2018-02-26 15:43:49 -08:00
|
|
|
try {
|
|
|
|
$user = User::find($request->get('id'));
|
|
|
|
$user->two_factor_secret = null;
|
|
|
|
$user->two_factor_enrolled = 0;
|
|
|
|
$user->save();
|
|
|
|
return response()->json(['message' => trans('admin/settings/general.two_factor_reset_success')], 200);
|
|
|
|
} catch (\Exception $e) {
|
|
|
|
return response()->json(['message' => trans('admin/settings/general.two_factor_reset_error')], 500);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return response()->json(['message' => 'No ID provided'], 500);
|
|
|
|
|
|
|
|
}
|
2018-07-02 20:35:10 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get info on the current user.
|
|
|
|
*
|
|
|
|
* @author [Juan Font] [<juanfontalonso@gmail.com>]
|
|
|
|
* @since [v4.4.2]
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function getCurrentUserInfo(Request $request)
|
|
|
|
{
|
|
|
|
return response()->json($request->user());
|
|
|
|
}
|
2017-01-12 19:40:20 -08:00
|
|
|
}
|