2016-03-25 01:18:05 -07:00
< ? php
namespace App\Http\Controllers ;
use App\Http\Requests\AssetFileRequest ;
use App\Helpers\Helper ;
use App\Models\Accessory ;
2016-05-12 21:01:31 -07:00
use App\Models\LicenseSeat ;
2016-03-25 01:18:05 -07:00
use App\Models\Actionlog ;
use App\Models\Asset ;
2016-04-28 21:59:43 -07:00
use App\Models\Group ;
2016-03-25 01:18:05 -07:00
use App\Models\Company ;
use App\Models\Location ;
use App\Models\Setting ;
use App\Models\Statuslabel ;
2016-06-06 14:15:50 -07:00
use App\Http\Requests\SaveUserRequest ;
2016-06-06 21:02:06 -07:00
use App\Http\Requests\UpdateUserRequest ;
2016-10-25 02:41:34 -07:00
use Symfony\Component\HttpFoundation\StreamedResponse ;
2016-03-25 01:18:05 -07:00
use App\Models\User ;
2016-07-13 05:50:24 -07:00
use App\Models\Ldap ;
2016-03-25 01:18:05 -07:00
use Auth ;
use Config ;
use Crypt ;
use DB ;
use HTML ;
use Illuminate\Support\Facades\Log ;
use Input ;
use Lang ;
use League\Csv\Reader ;
use Mail ;
use Redirect ;
use Response ;
use Str ;
use Symfony\Component\HttpFoundation\JsonResponse ;
use URL ;
use View ;
2016-06-02 00:41:10 -07:00
use Illuminate\Http\Request ;
2016-07-28 08:39:28 -07:00
use Gate ;
2016-06-02 00:41:10 -07:00
2016-03-25 01:18:05 -07:00
/**
2016-04-07 13:21:09 -07:00
* This controller handles all actions related to Users for
* the Snipe - IT Asset Management application .
*
* @ version v1 . 0
2016-03-25 01:18:05 -07:00
*/
2016-06-21 12:22:10 -07:00
2016-03-25 01:18:05 -07:00
class UsersController extends Controller
{
/**
* Returns a view that invokes the ajax tables which actually contains
* the content for the users listing , which is generated in getDatatable () .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ see UsersController :: getDatatable () method that generates the JSON response
* @ since [ v1 . 0 ]
* @ return View
*/
2016-12-15 20:52:39 -08:00
public function index ()
2016-03-25 01:18:05 -07:00
{
return View :: make ( 'users/index' );
}
/**
* Returns a view that displays the user creation form .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 0 ]
* @ return View
*/
2016-12-15 20:52:39 -08:00
public function create ()
2016-03-25 01:18:05 -07:00
{
2016-05-12 15:26:48 -07:00
$groups = Group :: pluck ( 'name' , 'id' );
if ( Input :: old ( 'groups' )) {
$userGroups = Group :: whereIn ( 'id' , Input :: old ( 'groups' )) -> pluck ( 'name' , 'id' );
2016-04-28 21:59:43 -07:00
} else {
$userGroups = collect ();
}
2016-06-15 11:51:10 -07:00
2016-03-25 01:18:05 -07:00
$permissions = config ( 'permissions' );
2016-05-09 15:40:27 -07:00
$userPermissions = Helper :: selectedPermissionsArray ( $permissions , Input :: old ( 'permissions' , array ()));
2016-10-12 12:06:28 -07:00
$permissions = $this -> filterDisplayable ( $permissions );
2016-03-25 01:18:05 -07:00
$location_list = Helper :: locationsList ();
$manager_list = Helper :: managerList ();
$company_list = Helper :: companyList ();
return View :: make ( 'users/edit' , compact ( 'groups' , 'userGroups' , 'permissions' , 'userPermissions' ))
-> with ( 'location_list' , $location_list )
-> with ( 'manager_list' , $manager_list )
-> with ( 'company_list' , $company_list )
-> with ( 'user' , new User );
}
/**
* Validate and store the new user data , or return an error .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 0 ]
* @ return Redirect
*/
2016-12-15 20:52:39 -08:00
public function store ( SaveUserRequest $request )
2016-03-25 01:18:05 -07:00
{
2016-03-25 19:26:22 -07:00
$user = new User ;
2016-06-27 19:47:21 -07:00
//Username, email, and password need to be handled specially because the need to respect config values on an edit.
2016-06-06 14:15:50 -07:00
$user -> email = $data [ 'email' ] = e ( $request -> input ( 'email' ));
$user -> username = $data [ 'username' ] = e ( $request -> input ( 'username' ));
if ( $request -> has ( 'password' )) {
$user -> password = bcrypt ( $request -> input ( 'password' ));
$data [ 'password' ] = $request -> input ( 'password' );
}
2016-06-27 21:11:59 -07:00
// Update the user
$user -> first_name = e ( $request -> input ( 'first_name' ));
$user -> last_name = e ( $request -> input ( 'last_name' ));
$user -> locale = e ( $request -> input ( 'locale' ));
$user -> employee_num = e ( $request -> input ( 'employee_num' ));
$user -> activated = e ( $request -> input ( 'activated' , $user -> activated ));
$user -> jobtitle = e ( $request -> input ( 'jobtitle' ));
$user -> phone = e ( $request -> input ( 'phone' ));
$user -> location_id = e ( $request -> input ( 'location_id' ));
$user -> company_id = e ( Company :: getIdForUser ( $request -> input ( 'company_id' )));
$user -> manager_id = e ( $request -> input ( 'manager_id' ));
$user -> notes = e ( $request -> input ( 'notes' ));
2016-10-31 19:08:24 -07:00
// Strip out the superuser permission if the user isn't a superadmin
$permissions_array = $request -> input ( 'permission' );
if ( ! Auth :: user () -> isSuperUser ()) {
unset ( $permissions_array [ 'superuser' ]);
}
$user -> permissions = json_encode ( $permissions_array );
2016-06-27 21:11:59 -07:00
if ( $user -> manager_id == " " ) {
$user -> manager_id = null ;
}
if ( $user -> location_id == " " ) {
$user -> location_id = null ;
}
if ( $user -> company_id == " " ) {
$user -> company_id = null ;
}
2016-03-25 01:18:05 -07:00
2016-06-06 14:15:50 -07:00
2016-06-15 11:51:10 -07:00
if ( $user -> save ()) {
2016-05-17 21:15:29 -07:00
2016-06-15 11:51:10 -07:00
if ( $request -> has ( 'groups' )) {
$user -> groups () -> sync ( $request -> input ( 'groups' ));
} else {
$user -> groups () -> sync ( array ());
}
2016-07-28 05:49:41 -07:00
2016-06-02 00:41:10 -07:00
if (( $request -> input ( 'email_user' ) == 1 ) && ( $request -> has ( 'email' ))) {
2016-03-25 01:18:05 -07:00
// Send the credentials through email
$data = array ();
2016-06-06 14:15:50 -07:00
$data [ 'email' ] = e ( $request -> input ( 'email' ));
$data [ 'username' ] = e ( $request -> input ( 'username' ));
$data [ 'first_name' ] = e ( $request -> input ( 'first_name' ));
$data [ 'password' ] = e ( $request -> input ( 'password' ));
2016-03-25 01:18:05 -07:00
Mail :: send ( 'emails.send-login' , $data , function ( $m ) use ( $user ) {
$m -> to ( $user -> email , $user -> first_name . ' ' . $user -> last_name );
2016-09-20 07:20:10 -07:00
$m -> replyTo ( config ( 'mail.reply_to.address' ), config ( 'mail.reply_to.name' ));
2016-09-26 14:13:07 -07:00
$m -> subject ( trans ( 'mail.welcome' , [ 'name' => $user -> first_name ]));
2016-03-25 01:18:05 -07:00
});
}
return redirect :: route ( 'users' ) -> with ( 'success' , trans ( 'admin/users/message.success.create' ));
}
2016-06-22 12:27:41 -07:00
return redirect () -> back () -> withInput () -> withErrors ( $user -> getErrors ());
2016-06-06 14:15:50 -07:00
2016-03-25 01:18:05 -07:00
}
/**
2016-04-28 21:59:43 -07:00
* JSON handler for creating a user through a modal popup
2016-03-25 01:18:05 -07:00
*
2016-06-09 00:36:52 -07:00
* @ todo Handle validation more graciously
2016-04-28 21:59:43 -07:00
* @ author [ B . Wetherington ] [ < uberbrady @ gmail . com > ]
2016-03-25 01:18:05 -07:00
* @ since [ v1 . 8 ]
* @ return string JSON
*/
2016-12-15 20:52:39 -08:00
public function apiStore ()
2016-03-25 01:18:05 -07:00
{
2016-06-09 00:36:52 -07:00
$user = new User ;
2016-03-25 01:18:05 -07:00
$inputs = Input :: except ( 'csrf_token' , 'password_confirm' , 'groups' , 'email_user' );
$inputs [ 'activated' ] = true ;
2016-06-09 00:36:52 -07:00
$user -> first_name = e ( Input :: get ( 'first_name' ));
$user -> last_name = e ( Input :: get ( 'last_name' ));
$user -> username = e ( Input :: get ( 'username' ));
$user -> email = e ( Input :: get ( 'email' ));
if ( Input :: has ( 'password' )) {
$user -> password = bcrypt ( Input :: get ( 'password' ));
}
$user -> activated = true ;
2016-03-25 01:18:05 -07:00
// Was the user created?
if ( $user -> save ()) {
if ( Input :: get ( 'email_user' ) == 1 ) {
// Send the credentials through email
$data = array ();
$data [ 'email' ] = e ( Input :: get ( 'email' ));
$data [ 'first_name' ] = e ( Input :: get ( 'first_name' ));
2016-06-09 00:36:52 -07:00
$data [ 'last_name' ] = e ( Input :: get ( 'last_name' ));
2016-03-25 01:18:05 -07:00
$data [ 'password' ] = e ( Input :: get ( 'password' ));
Mail :: send ( 'emails.send-login' , $data , function ( $m ) use ( $user ) {
$m -> to ( $user -> email , $user -> first_name . ' ' . $user -> last_name );
2016-09-20 07:20:10 -07:00
$m -> replyTo ( config ( 'mail.reply_to.address' ), config ( 'mail.reply_to.name' ));
2016-09-26 14:13:07 -07:00
$m -> subject ( trans ( 'mail.welcome' , [ 'name' => $user -> first_name ]));
2016-03-25 01:18:05 -07:00
});
}
return JsonResponse :: create ( $user );
} else {
return JsonResponse :: create ([ " error " => " Failed validation: " . print_r ( $user -> getErrors (), true )], 500 );
}
}
/**
* Returns a view that displays the edit user form
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 0 ]
* @ param int $id
* @ return View
*/
2016-10-12 12:06:28 -07:00
private function filterDisplayable ( $permissions ) {
$output = null ;
foreach ( $permissions as $key => $permission ) {
$output [ $key ] = array_filter ( $permission , function ( $p ) {
return $p [ 'display' ] === true ;
});
}
return $output ;
}
2016-12-15 20:52:39 -08:00
public function edit ( $id = null )
2016-03-25 01:18:05 -07:00
{
try {
// Get the user information
$user = User :: find ( $id );
2016-04-28 21:59:43 -07:00
$permissions = config ( 'permissions' );
2016-03-25 01:18:05 -07:00
if ( ! Company :: isCurrentUserHasAccess ( $user )) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
}
2016-04-28 21:59:43 -07:00
$groups = Group :: pluck ( 'name' , 'id' );
2016-03-25 01:18:05 -07:00
2016-04-28 21:59:43 -07:00
$userGroups = $user -> groups () -> pluck ( 'name' , 'id' );
$user -> permissions = $user -> decodePermissions ();
$userPermissions = Helper :: selectedPermissionsArray ( $permissions , $user -> permissions );
2016-10-12 12:06:28 -07:00
$permissions = $this -> filterDisplayable ( $permissions );
2016-03-25 01:18:05 -07:00
$location_list = Helper :: locationsList ();
$company_list = Helper :: companyList ();
2016-05-09 15:40:27 -07:00
$manager_list = Helper :: managerList ();
2016-03-25 01:18:05 -07:00
} catch ( UserNotFoundException $e ) {
// Prepare the error message
2016-04-07 13:39:35 -07:00
$error = trans ( 'admin/users/message.user_not_found' , compact ( 'id' ));
2016-03-25 01:18:05 -07:00
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , $error );
2016-03-25 01:18:05 -07:00
}
// Show the page
return View :: make ( 'users/edit' , compact ( 'user' , 'groups' , 'userGroups' , 'permissions' , 'userPermissions' ))
-> with ( 'location_list' , $location_list )
-> with ( 'company_list' , $company_list )
-> with ( 'manager_list' , $manager_list );
}
/**
* Validate and save edited user data from edit form .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 0 ]
* @ param int $id
* @ return Redirect
*/
2016-12-15 20:52:39 -08:00
public function update ( UpdateUserRequest $request , $id = null )
2016-03-25 01:18:05 -07:00
{
// We need to reverse the UI specific logic for our
// permissions here before we update the user.
2016-06-06 14:15:50 -07:00
$permissions = $request -> input ( 'permissions' , array ());
2016-03-25 01:18:05 -07:00
app ( 'request' ) -> request -> set ( 'permissions' , $permissions );
// Only update the email address if locking is set to false
if ( config ( 'app.lock_passwords' )) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , 'Denied! You cannot update user information on the demo.' );
2016-03-25 01:18:05 -07:00
}
try {
2016-11-11 19:48:39 -08:00
2016-03-25 01:18:05 -07:00
$user = User :: find ( $id );
2016-10-31 19:37:24 -07:00
// Figure out of this user was an admin before this edit
$orig_permissions_array = $user -> decodePermissions ();
2016-11-11 19:48:39 -08:00
if ( is_array ( $orig_permissions_array )) {
if ( array_key_exists ( 'superuser' , $orig_permissions_array )) {
$orig_superuser = $orig_permissions_array [ 'superuser' ];
} else {
$orig_superuser = '0' ;
}
2016-10-31 19:37:24 -07:00
} else {
$orig_superuser = '0' ;
}
2016-03-25 01:18:05 -07:00
if ( ! Company :: isCurrentUserHasAccess ( $user )) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
}
2016-12-15 20:52:39 -08:00
2016-03-25 01:18:05 -07:00
} catch ( UserNotFoundException $e ) {
2016-04-07 13:39:35 -07:00
$error = trans ( 'admin/users/message.user_not_found' , compact ( 'id' ));
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , $error );
2016-03-25 01:18:05 -07:00
}
2016-10-31 18:57:35 -07:00
// Only save groups if the user is a super user
if ( Auth :: user () -> isSuperUser ()) {
if ( $request -> has ( 'groups' )) {
$user -> groups () -> sync ( $request -> input ( 'groups' ));
} else {
$user -> groups () -> sync ( array ());
}
2016-06-15 20:45:45 -07:00
}
2016-10-31 18:57:35 -07:00
2016-06-27 21:11:59 -07:00
// Do we want to update the user password?
if ( $request -> has ( 'password' )) {
$user -> password = bcrypt ( $request -> input ( 'password' ));
2016-03-25 01:18:05 -07:00
}
2016-06-27 21:11:59 -07:00
if ( $request -> has ( 'username' )) {
$user -> username = e ( $request -> input ( 'username' ));
2016-03-25 01:18:05 -07:00
}
2016-06-27 21:11:59 -07:00
$user -> email = e ( $request -> input ( 'email' ));
2016-03-25 01:18:05 -07:00
2016-06-27 19:47:21 -07:00
// Update the user
$user -> first_name = e ( $request -> input ( 'first_name' ));
$user -> last_name = e ( $request -> input ( 'last_name' ));
2016-10-31 16:52:25 -07:00
$user -> two_factor_optin = e ( $request -> input ( 'two_factor_optin' ));
2016-06-27 19:47:21 -07:00
$user -> locale = e ( $request -> input ( 'locale' ));
$user -> employee_num = e ( $request -> input ( 'employee_num' ));
$user -> activated = e ( $request -> input ( 'activated' , $user -> activated ));
$user -> jobtitle = e ( $request -> input ( 'jobtitle' ));
$user -> phone = e ( $request -> input ( 'phone' ));
$user -> location_id = e ( $request -> input ( 'location_id' ));
$user -> company_id = e ( Company :: getIdForUser ( $request -> input ( 'company_id' )));
$user -> manager_id = e ( $request -> input ( 'manager_id' ));
$user -> notes = e ( $request -> input ( 'notes' ));
2016-10-31 19:07:55 -07:00
// Strip out the superuser permission if the user isn't a superadmin
$permissions_array = $request -> input ( 'permission' );
if ( ! Auth :: user () -> isSuperUser ()) {
unset ( $permissions_array [ 'superuser' ]);
2016-10-31 19:37:24 -07:00
$permissions_array [ 'superuser' ] = $orig_superuser ;
}
2016-10-31 19:07:55 -07:00
$user -> permissions = json_encode ( $permissions_array );
2016-10-31 19:08:24 -07:00
2016-06-27 19:47:21 -07:00
if ( $user -> manager_id == " " ) {
$user -> manager_id = null ;
}
if ( $user -> location_id == " " ) {
$user -> location_id = null ;
}
if ( $user -> company_id == " " ) {
$user -> company_id = null ;
}
2016-06-27 21:11:59 -07:00
// Was the user updated?
if ( $user -> save ()) {
// Prepare the success message
$success = trans ( 'admin/users/message.success.update' );
// Redirect to the user page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'success' , $success );
2016-06-27 21:11:59 -07:00
}
return redirect () -> back () -> withInput () -> withErrors ( $user -> getErrors ());
2016-06-27 19:47:21 -07:00
}
2016-03-25 01:18:05 -07:00
/**
* Delete a user
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 0 ]
* @ param int $id
* @ return Redirect
*/
2016-12-15 20:52:39 -08:00
public function destroy ( $id = null )
2016-03-25 01:18:05 -07:00
{
try {
// Get user information
$user = User :: find ( $id );
// Check if we are not trying to delete ourselves
if ( $user -> id === Auth :: user () -> id ) {
// Prepare the error message
2016-04-07 13:39:35 -07:00
$error = trans ( 'admin/users/message.error.delete' );
2016-03-25 01:18:05 -07:00
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , $error );
2016-03-25 01:18:05 -07:00
}
// Do we have permission to delete this user?
if (( ! Auth :: user () -> isSuperUser ()) || ( config ( 'app.lock_passwords' ))) {
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , 'Insufficient permissions!' );
2016-03-25 01:18:05 -07:00
}
if ( count ( $user -> assets ) > 0 ) {
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , 'This user still has ' . count ( $user -> assets ) . ' assets associated with them.' );
2016-03-25 01:18:05 -07:00
}
if ( count ( $user -> licenses ) > 0 ) {
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , 'This user still has ' . count ( $user -> licenses ) . ' licenses associated with them.' );
2016-03-25 01:18:05 -07:00
}
2016-04-21 21:01:45 -07:00
if ( count ( $user -> accessories ) > 0 ) {
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , 'This user still has ' . count ( $user -> accessories ) . ' accessories associated with them.' );
2016-04-21 21:01:45 -07:00
}
2016-03-25 01:18:05 -07:00
// Delete the user
$user -> delete ();
// Prepare the success message
2016-04-07 13:39:35 -07:00
$success = trans ( 'admin/users/message.success.delete' );
2016-03-25 01:18:05 -07:00
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'success' , $success );
2016-03-25 01:18:05 -07:00
} catch ( UserNotFoundException $e ) {
// Prepare the error message
2016-04-07 13:39:35 -07:00
$error = trans ( 'admin/users/message.user_not_found' , compact ( 'id' ));
2016-03-25 01:18:05 -07:00
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , $error );
2016-03-25 01:18:05 -07:00
}
}
/**
* Returns a view that confirms the user ' s a bulk delete will be applied to .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 7 ]
* @ return View
*/
public function postBulkEdit ()
{
if (( ! Input :: has ( 'edit_user' )) || ( count ( Input :: has ( 'edit_user' )) == 0 )) {
2016-04-28 21:06:41 -07:00
return redirect () -> back () -> with ( 'error' , 'No users selected' );
2016-03-25 01:18:05 -07:00
} else {
$statuslabel_list = Helper :: statusLabelList ();
$user_raw_array = array_keys ( Input :: get ( 'edit_user' ));
2016-05-12 21:01:31 -07:00
$licenses = DB :: table ( 'license_seats' ) -> whereIn ( 'assigned_to' , $user_raw_array ) -> get ();
2016-03-25 01:18:05 -07:00
2016-05-12 21:01:31 -07:00
//print_r($licenses);
2016-06-22 12:27:41 -07:00
$users = User :: whereIn ( 'id' , $user_raw_array ) -> with ( 'groups' , 'assets' , 'licenses' , 'accessories' ) -> get ();
2016-05-12 21:01:31 -07:00
// $users = Company::scopeCompanyables($users)->get();
2016-03-25 01:18:05 -07:00
return View :: make ( 'users/confirm-bulk-delete' , compact ( 'users' , 'statuslabel_list' ));
}
}
/**
* Soft - delete bulk users
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 0 ]
* @ return Redirect
*/
public function postBulkSave ()
{
if (( ! Input :: has ( 'edit_user' )) || ( count ( Input :: has ( 'edit_user' )) == 0 )) {
2016-04-28 21:06:41 -07:00
return redirect () -> back () -> with ( 'error' , 'No users selected' );
2016-03-25 01:18:05 -07:00
} elseif (( ! Input :: has ( 'status_id' )) || ( count ( Input :: has ( 'status_id' )) == 0 )) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , 'No status selected' );
2016-03-25 01:18:05 -07:00
} else {
$user_raw_array = Input :: get ( 'edit_user' );
$asset_array = array ();
if (( $key = array_search ( Auth :: user () -> id , $user_raw_array )) !== false ) {
unset ( $user_raw_array [ $key ]);
}
if ( ! Auth :: user () -> isSuperUser ()) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , trans ( 'admin/users/message.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
}
if ( ! config ( 'app.lock_passwords' )) {
2016-05-12 21:01:31 -07:00
$users = User :: whereIn ( 'id' , $user_raw_array ) -> get ();
2016-03-25 01:18:05 -07:00
$assets = Asset :: whereIn ( 'assigned_to' , $user_raw_array ) -> get ();
$accessories = DB :: table ( 'accessories_users' ) -> whereIn ( 'assigned_to' , $user_raw_array ) -> get ();
2016-05-12 21:01:31 -07:00
$licenses = DB :: table ( 'license_seats' ) -> whereIn ( 'assigned_to' , $user_raw_array ) -> get ();
$license_array = array ();
$accessory_array = array ();
2016-03-25 01:18:05 -07:00
foreach ( $assets as $asset ) {
$asset_array [] = $asset -> id ;
// Update the asset log
$logaction = new Actionlog ();
2016-09-06 19:39:42 -07:00
$logaction -> item_id = $asset -> id ;
$logaction -> item_type = Asset :: class ;
$logaction -> target_id = $asset -> assigned_to ;
$logaction -> target_type = User :: class ;
2016-03-25 01:18:05 -07:00
$logaction -> user_id = Auth :: user () -> id ;
2016-05-12 21:01:31 -07:00
$logaction -> note = 'Bulk checkin asset and delete user' ;
$logaction -> logaction ( 'checkin from' );
2016-03-25 01:18:05 -07:00
2016-05-12 21:01:31 -07:00
Asset :: whereIn ( 'id' , $asset_array ) -> update (
2016-03-25 01:18:05 -07:00
array (
'status_id' => e ( Input :: get ( 'status_id' )),
'assigned_to' => null ,
)
);
}
foreach ( $accessories as $accessory ) {
2016-05-12 21:01:31 -07:00
$accessory_array [] = $accessory -> accessory_id ;
2016-03-25 01:18:05 -07:00
// Update the asset log
$logaction = new Actionlog ();
2016-09-06 19:39:42 -07:00
$logaction -> item_id = $accessory -> id ;
$logaction -> item_type = Accessory :: class ;
$logaction -> target_id = $accessory -> assigned_to ;
$logaction -> target_type = User :: class ;
2016-03-25 01:18:05 -07:00
$logaction -> user_id = Auth :: user () -> id ;
2016-05-12 21:01:31 -07:00
$logaction -> note = 'Bulk checkin accessory and delete user' ;
$logaction -> logaction ( 'checkin from' );
2016-03-25 01:18:05 -07:00
2016-05-12 21:01:31 -07:00
}
foreach ( $licenses as $license ) {
$license_array [] = $license -> id ;
// Update the asset log
$logaction = new Actionlog ();
2016-09-06 19:39:42 -07:00
$logaction -> item_id = $license -> id ;
$logaction -> item_type = License :: class ;
$logaction -> target_id = $license -> assigned_to ;
2016-09-20 07:20:10 -07:00
$logaction -> target_type = User :: class ;
2016-05-12 21:01:31 -07:00
$logaction -> user_id = Auth :: user () -> id ;
$logaction -> note = 'Bulk checkin license and delete user' ;
$logaction -> logaction ( 'checkin from' );
2016-03-25 01:18:05 -07:00
}
2016-06-15 11:51:10 -07:00
2016-06-22 12:27:41 -07:00
LicenseSeat :: whereIn ( 'id' , $license_array ) -> update ([ 'assigned_to' => null ]);
2016-05-12 21:01:31 -07:00
foreach ( $users as $user ) {
$user -> accessories () -> sync ( array ());
$user -> delete ();
}
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'success' , 'Your selected users have been deleted and their assets have been updated.' );
2016-03-25 01:18:05 -07:00
} else {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , 'Bulk delete is not enabled in this installation' );
2016-03-25 01:18:05 -07:00
}
}
}
/**
* Restore a deleted user
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 0 ]
* @ param int $id
* @ return Redirect
*/
public function getRestore ( $id = null )
{
2016-04-21 20:52:32 -07:00
2016-03-25 01:18:05 -07:00
// Get user information
2016-06-22 12:27:41 -07:00
if ( ! $user = User :: onlyTrashed () -> find ( $id )) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , trans ( 'admin/users/messages.user_not_found' ));
2016-06-22 12:27:41 -07:00
}
2016-04-21 21:01:45 -07:00
2016-06-22 12:27:41 -07:00
if ( ! Company :: isCurrentUserHasAccess ( $user )) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-06-22 12:27:41 -07:00
} else {
2016-03-25 01:18:05 -07:00
2016-06-22 12:27:41 -07:00
// Restore the user
if ( User :: withTrashed () -> where ( 'id' , $id ) -> restore ()) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'success' , trans ( 'admin/users/message.success.restored' ));
2016-06-22 12:27:41 -07:00
} else {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , 'User could not be restored.' );
2016-04-21 20:52:32 -07:00
}
2016-06-22 12:27:41 -07:00
}
2016-03-25 01:18:05 -07:00
}
/**
* Return a view with user detail
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 0 ]
* @ param int $userId
* @ return View
*/
2016-12-15 20:52:39 -08:00
public function show ( $userId = null )
2016-03-25 01:18:05 -07:00
{
$user = User :: with ( 'assets' , 'assets.model' , 'consumables' , 'accessories' , 'licenses' , 'userloc' ) -> withTrashed () -> find ( $userId );
2016-09-06 19:39:42 -07:00
$userlog = $user -> userlog -> load ( 'item' );
2016-03-25 01:18:05 -07:00
if ( isset ( $user -> id )) {
if ( ! Company :: isCurrentUserHasAccess ( $user )) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
} else {
return View :: make ( 'users/view' , compact ( 'user' , 'userlog' ));
}
} else {
// Prepare the error message
2016-04-07 13:39:35 -07:00
$error = trans ( 'admin/users/message.user_not_found' , compact ( 'id' ));
2016-03-25 01:18:05 -07:00
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , $error );
2016-03-25 01:18:05 -07:00
}
}
/**
* Unsuspend a user .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 0 ]
* @ param int $id
* @ return Redirect
*/
public function getUnsuspend ( $id = null )
{
try {
// Get user information
//$user = User::find($id);
// Check if we are not trying to unsuspend ourselves
if ( $user -> id === Auth :: user () -> id ) {
// Prepare the error message
2016-04-07 13:39:35 -07:00
$error = trans ( 'admin/users/message.error.unsuspend' );
2016-03-25 01:18:05 -07:00
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , $error );
2016-03-25 01:18:05 -07:00
}
// Do we have permission to unsuspend this user?
2016-07-10 20:55:44 -07:00
if ( $user -> isSuperUser () && ! Auth :: user () -> isSuperUser ()) {
2016-03-25 01:18:05 -07:00
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , 'Insufficient permissions!' );
2016-03-25 01:18:05 -07:00
}
// Prepare the success message
2016-04-07 13:39:35 -07:00
$success = trans ( 'admin/users/message.success.unsuspend' );
2016-03-25 01:18:05 -07:00
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'success' , $success );
2016-03-25 01:18:05 -07:00
} catch ( UserNotFoundException $e ) {
// Prepare the error message
2016-04-07 13:39:35 -07:00
$error = trans ( 'admin/users/message.user_not_found' , compact ( 'id' ));
2016-03-25 01:18:05 -07:00
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , $error );
2016-03-25 01:18:05 -07:00
}
}
/**
* Return a view containing a pre - populated new user form ,
* populated with some fields from an existing user .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 0 ]
* @ param int $id
* @ return Redirect
*/
public function getClone ( $id = null )
{
// We need to reverse the UI specific logic for our
// permissions here before we update the user.
$permissions = Input :: get ( 'permissions' , array ());
//$this->decodePermissions($permissions);
app ( 'request' ) -> request -> set ( 'permissions' , $permissions );
try {
// Get the user information
2016-04-21 20:52:32 -07:00
$user_to_clone = User :: withTrashed () -> find ( $id );
2016-03-25 01:18:05 -07:00
$user = clone $user_to_clone ;
$user -> first_name = '' ;
$user -> last_name = '' ;
$user -> email = substr ( $user -> email , ( $pos = strpos ( $user -> email , '@' )) !== false ? $pos : 0 );
;
$user -> id = null ;
// Get this user groups
2016-06-02 00:41:10 -07:00
$userGroups = $user_to_clone -> groups () -> lists ( 'name' , 'id' );
2016-03-25 01:18:05 -07:00
// Get a list of all the available groups
2016-06-02 00:41:10 -07:00
$groups = Group :: pluck ( 'name' , 'id' );
2016-03-25 01:18:05 -07:00
// Get all the available permissions
$permissions = config ( 'permissions' );
2016-07-10 18:43:10 -07:00
$clonedPermissions = $user_to_clone -> decodePermissions ();
$userPermissions = Helper :: selectedPermissionsArray ( $permissions , $clonedPermissions );
2016-03-25 01:18:05 -07:00
//$this->encodeAllPermissions($permissions);
$location_list = Helper :: locationsList ();
$company_list = Helper :: companyList ();
2016-05-24 18:05:48 -07:00
$manager_list = Helper :: managerList ();
2016-03-25 01:18:05 -07:00
// Show the page
return View :: make ( 'users/edit' , compact ( 'groups' , 'userGroups' , 'permissions' , 'userPermissions' ))
-> with ( 'location_list' , $location_list )
-> with ( 'company_list' , $company_list )
-> with ( 'manager_list' , $manager_list )
-> with ( 'user' , $user )
2016-06-22 12:27:41 -07:00
-> with ( 'groups' , $groups )
-> with ( 'userGroups' , $userGroups )
2016-03-25 01:18:05 -07:00
-> with ( 'clone_user' , $user_to_clone );
} catch ( UserNotFoundException $e ) {
// Prepare the error message
2016-04-07 13:39:35 -07:00
$error = trans ( 'admin/users/message.user_not_found' , compact ( 'id' ));
2016-03-25 01:18:05 -07:00
// Redirect to the user management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , $error );
2016-03-25 01:18:05 -07:00
}
}
/**
* Return user import view
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 0 ]
* @ return View
*/
public function getImport ()
{
// Get all the available groups
//$groups = Sentry::getGroupProvider()->findAll();
// Selected groups
$selectedGroups = Input :: old ( 'groups' , array ());
// Get all the available permissions
$permissions = config ( 'permissions' );
//$this->encodeAllPermissions($permissions);
// Selected permissions
$selectedPermissions = Input :: old ( 'permissions' , array ( 'superuser' => - 1 ));
//$this->encodePermissions($selectedPermissions);
// Show the page
return View :: make ( 'users/import' , compact ( 'groups' , 'selectedGroups' , 'permissions' , 'selectedPermissions' ));
}
/**
* Handle user import file
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 0 ]
* @ return Redirect
*/
public function postImport ()
{
if ( ! ini_get ( " auto_detect_line_endings " )) {
ini_set ( " auto_detect_line_endings " , '1' );
}
$csv = Reader :: createFromPath ( Input :: file ( 'user_import_csv' ));
$csv -> setNewline ( " \r \n " );
if ( Input :: get ( 'has_headers' ) == 1 ) {
$csv -> setOffset ( 1 );
}
$duplicates = '' ;
$nbInsert = $csv -> each ( function ( $row ) use ( $duplicates ) {
if ( array_key_exists ( 2 , $row )) {
if ( Input :: get ( 'activate' ) == 1 ) {
$activated = '1' ;
} else {
$activated = '0' ;
}
$pass = substr ( str_shuffle ( " 0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ " ), 0 , 15 );
// Location
if ( array_key_exists ( '4' , $row )) {
$user_location_id = trim ( $row [ 4 ]);
if ( $user_location_id == '' ) {
$user_location_id = null ;
}
}
try {
// Check if this email already exists in the system
2016-05-12 21:01:31 -07:00
$user = User :: where ( 'username' , $row [ 2 ]) -> first ();
2016-03-25 01:18:05 -07:00
if ( $user ) {
$duplicates .= $row [ 2 ] . ', ' ;
} else {
$newuser = array (
'first_name' => trim ( e ( $row [ 0 ])),
'last_name' => trim ( e ( $row [ 1 ])),
'username' => trim ( e ( $row [ 2 ])),
'email' => trim ( e ( $row [ 3 ])),
2016-06-13 11:30:47 -07:00
'password' => bcrypt ( $pass ),
2016-03-25 01:18:05 -07:00
'activated' => $activated ,
'location_id' => trim ( e ( $user_location_id )),
'phone' => trim ( e ( $row [ 5 ])),
'jobtitle' => trim ( e ( $row [ 6 ])),
'employee_num' => trim ( e ( $row [ 7 ])),
2016-10-12 12:50:30 -07:00
'company_id' => Company :: getIdForUser ( $row [ 8 ]),
2016-03-25 01:18:05 -07:00
'permissions' => '{"user":1}' ,
'notes' => 'Imported user'
);
2016-06-13 11:30:47 -07:00
//dd($newuser);
2016-03-25 01:18:05 -07:00
DB :: table ( 'users' ) -> insert ( $newuser );
if ((( Input :: get ( 'email_user' ) == 1 ) && ! config ( 'app.lock_passwords' ))) {
// Send the credentials through email
if ( $row [ 3 ] != '' ) {
$data = array ();
$data [ 'username' ] = trim ( e ( $row [ 2 ]));
$data [ 'first_name' ] = trim ( e ( $row [ 0 ]));
$data [ 'password' ] = $pass ;
if ( $newuser [ 'email' ]) {
Mail :: send ( 'emails.send-login' , $data , function ( $m ) use ( $newuser ) {
$m -> to ( $newuser [ 'email' ], $newuser [ 'first_name' ] . ' ' . $newuser [ 'last_name' ]);
2016-09-20 07:20:10 -07:00
$m -> replyTo ( config ( 'mail.reply_to.address' ), config ( 'mail.reply_to.name' ));
2016-09-26 14:13:07 -07:00
$m -> subject ( trans ( 'mail.welcome' , [ 'name' => $newuser [ 'first_name' ]]));
2016-03-25 01:18:05 -07:00
});
}
}
}
}
} catch ( Exception $e ) {
echo 'Caught exception: ' , $e -> getMessage (), " \n " ;
}
return true ;
}
});
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'duplicates' , $duplicates ) -> with ( 'success' , 'Success' );
2016-03-25 01:18:05 -07:00
}
/**
* Return JSON response with a list of user details for the getIndex () view .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 6 ]
* @ see UsersController :: getIndex () method that consumed this JSON response
* @ return string JSON
*/
2016-07-28 08:39:28 -07:00
public function getDatatable ( Request $request , $status = null )
2016-03-25 01:18:05 -07:00
{
if ( Input :: has ( 'offset' )) {
$offset = e ( Input :: get ( 'offset' ));
} else {
$offset = 0 ;
}
if ( Input :: has ( 'limit' )) {
$limit = e ( Input :: get ( 'limit' ));
} else {
$limit = 50 ;
}
if ( Input :: get ( 'sort' ) == 'name' ) {
$sort = 'first_name' ;
} else {
$sort = e ( Input :: get ( 'sort' ));
}
2016-10-29 07:21:34 -07:00
$users = User :: select ( array ( 'users.id' , 'users.employee_num' , 'users.two_factor_enrolled' , 'users.jobtitle' , 'users.email' , 'users.username' , 'users.location_id' , 'users.manager_id' , 'users.first_name' , 'users.last_name' , 'users.created_at' , 'users.notes' , 'users.company_id' , 'users.deleted_at' , 'users.activated' ))
2016-08-02 01:23:53 -07:00
-> with ( 'assets' , 'accessories' , 'consumables' , 'licenses' , 'manager' , 'groups' , 'userloc' , 'company' , 'throttle' );
2016-03-25 01:18:05 -07:00
$users = Company :: scopeCompanyables ( $users );
switch ( $status ) {
case 'deleted' :
$users = $users -> withTrashed () -> Deleted ();
break ;
}
if ( Input :: has ( 'search' )) {
$users = $users -> TextSearch ( Input :: get ( 'search' ));
}
$order = Input :: get ( 'order' ) === 'asc' ? 'asc' : 'desc' ;
switch ( Input :: get ( 'sort' )) {
case 'manager' :
$users = $users -> OrderManager ( $order );
break ;
case 'location' :
$users = $users -> OrderLocation ( $order );
break ;
default :
$allowed_columns =
[
2016-10-27 14:29:07 -07:00
'last_name' , 'first_name' , 'email' , 'jobtitle' , 'username' , 'employee_num' ,
2016-10-31 17:16:26 -07:00
'assets' , 'accessories' , 'consumables' , 'licenses' , 'groups' , 'activated' , 'created_at' ,
'two_factor_enrolled' , 'two_factor_optin'
2016-03-25 01:18:05 -07:00
];
$sort = in_array ( $sort , $allowed_columns ) ? $sort : 'first_name' ;
$users = $users -> orderBy ( $sort , $order );
break ;
}
$userCount = $users -> count ();
$users = $users -> skip ( $offset ) -> take ( $limit ) -> get ();
$rows = array ();
foreach ( $users as $user ) {
$group_names = '' ;
$inout = '' ;
$actions = '<nobr>' ;
foreach ( $user -> groups as $group ) {
2016-12-15 16:41:36 -08:00
$group_names .= '<a href="' . \url ( '/' ) . '/admin/groups/' . $group -> id . '/edit" class="label label-default">' . $group -> name . '</a> ' ;
2016-03-25 01:18:05 -07:00
}
2016-08-02 00:54:38 -07:00
if ( ! is_null ( $user -> deleted_at )) {
if ( Gate :: allows ( 'users.delete' )) {
$actions .= '<a href="' . route ( 'restore/user' ,
$user -> id ) . '" class="btn btn-warning btn-sm"><i class="fa fa-share icon-white"></i></a> ' ;
}
2016-07-28 08:39:28 -07:00
} else {
2016-03-25 01:18:05 -07:00
2016-08-02 00:54:38 -07:00
if ( Gate :: allows ( 'users.delete' )) {
if ( $user -> accountStatus () == 'suspended' ) {
$actions .= '<a href="' . route ( 'unsuspend/user' ,
$user -> id ) . '" class="btn btn-default btn-sm"><span class="fa fa-clock-o"></span></a> ' ;
}
2016-07-28 08:39:28 -07:00
}
2016-08-02 00:54:38 -07:00
if ( Gate :: allows ( 'users.edit' )) {
2016-12-15 20:52:39 -08:00
$actions .= '<a href="' . route ( 'users.edit' ,
2016-08-02 00:54:38 -07:00
$user -> id ) . '" class="btn btn-warning btn-sm"><i class="fa fa-pencil icon-white"></i></a> ' ;
2016-03-25 01:18:05 -07:00
2016-08-02 00:54:38 -07:00
$actions .= '<a href="' . route ( 'clone/user' ,
$user -> id ) . '" class="btn btn-info btn-sm"><i class="fa fa-clone"></i></a>' ;
}
if ( Gate :: allows ( 'users.delete' )) {
if (( Auth :: user () -> id !== $user -> id ) && ( ! config ( 'app.lock_passwords' ))) {
2016-12-15 20:52:39 -08:00
$actions .= '<a data-html="false" class="btn delete-asset btn-danger btn-sm" data-toggle="modal" href="' . route ( 'users.destroy' ,
2016-08-02 00:54:38 -07:00
$user -> id ) . '" data-content="Are you sure you wish to delete this user?" data-title="Delete ' . htmlspecialchars ( $user -> first_name ) . '?" onClick="return false;"><i class="fa fa-trash icon-white"></i></a> ' ;
} else {
$actions .= ' <span class="btn delete-asset btn-danger btn-sm disabled"><i class="fa fa-trash icon-white"></i></span>' ;
}
2016-07-28 08:39:28 -07:00
} else {
2016-11-11 20:09:07 -08:00
$actions .= '' ;
2016-07-28 08:39:28 -07:00
}
2016-03-25 01:18:05 -07:00
}
2016-08-02 00:54:38 -07:00
2016-03-25 01:18:05 -07:00
$actions .= '</nobr>' ;
$rows [] = array (
'id' => $user -> id ,
2016-05-12 21:01:31 -07:00
'checkbox' => ( $status != 'deleted' ) ? '<div class="text-center hidden-xs hidden-sm"><input type="checkbox" name="edit_user[' . e ( $user -> id ) . ']" class="one_required"></div>' : '' ,
2016-12-15 20:52:39 -08:00
'name' => ( string ) link_to_route ( 'users.show' , e ( $user -> fullName ()), [ 'user' => $user -> id ]),
2016-10-27 14:29:07 -07:00
'jobtitle' => e ( $user -> jobtitle ),
2016-03-25 01:18:05 -07:00
'email' => ( $user -> email != '' ) ?
2016-03-25 06:50:24 -07:00
'<a href="mailto:' . e ( $user -> email ) . '" class="hidden-md hidden-lg">' . e ( $user -> email ) . '</a>'
. '<a href="mailto:' . e ( $user -> email ) . '" class="hidden-xs hidden-sm"><i class="fa fa-envelope"></i></a>'
2016-03-25 01:18:05 -07:00
. '</span>' : '' ,
2016-03-25 06:50:24 -07:00
'username' => e ( $user -> username ),
'location' => ( $user -> userloc ) ? e ( $user -> userloc -> name ) : '' ,
2016-12-15 16:41:36 -08:00
'manager' => ( $user -> manager ) ? '<a title="' . e ( $user -> manager -> fullName ()) . '" href="' . url ( '/' ) . '/' . e ( $user -> manager -> id ) . '/view">' . e ( $user -> manager -> fullName ()) . '</a>' : '' ,
2016-03-25 01:18:05 -07:00
'assets' => $user -> assets -> count (),
2016-03-25 06:50:24 -07:00
'employee_num' => e ( $user -> employee_num ),
2016-03-25 01:18:05 -07:00
'licenses' => $user -> licenses -> count (),
'accessories' => $user -> accessories -> count (),
'consumables' => $user -> consumables -> count (),
'groups' => $group_names ,
2016-03-25 06:50:24 -07:00
'notes' => e ( $user -> notes ),
2016-10-31 17:16:26 -07:00
'two_factor_enrolled' => ( $user -> two_factor_enrolled == '1' ) ? '<i class="fa fa-check text-success"></i>' : '<i class="fa fa-times text-danger"></i>' ,
'two_factor_optin' => (( $user -> two_factor_optin == '1' ) || ( Setting :: getSettings () -> two_factor_enabled == '2' ) ) ? '<i class="fa fa-check text-success"></i>' : '<i class="fa fa-times text-danger"></i>' ,
2016-06-15 21:06:17 -07:00
'created_at' => ( $user -> created_at != '' ) ? e ( $user -> created_at -> format ( 'F j, Y h:iA' )) : '' ,
2016-10-31 17:16:26 -07:00
'activated' => ( $user -> activated == '1' ) ? '<i class="fa fa-check text-success"></i>' : '<i class="fa fa-times text-danger"></i>' ,
2016-03-25 01:18:05 -07:00
'actions' => ( $actions ) ? $actions : '' ,
'companyName' => is_null ( $user -> company ) ? '' : e ( $user -> company -> name )
);
}
$data = array ( 'total' => $userCount , 'rows' => $rows );
return $data ;
}
/**
* Return JSON response with a list of user details for the getIndex () view .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 6 ]
* @ param int $userId
* @ return string JSON
*/
public function postUpload ( AssetFileRequest $request , $userId = null )
{
$user = User :: find ( $userId );
2016-03-25 15:50:08 -07:00
$destinationPath = config ( 'app.private_uploads' ) . '/users' ;
2016-03-25 01:18:05 -07:00
if ( isset ( $user -> id )) {
if ( ! Company :: isCurrentUserHasAccess ( $user )) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
}
foreach ( Input :: file ( 'file' ) as $file ) {
$extension = $file -> getClientOriginalExtension ();
$filename = 'user-' . $user -> id . '-' . str_random ( 8 );
$filename .= '-' . str_slug ( $file -> getClientOriginalName ()) . '.' . $extension ;
$upload_success = $file -> move ( $destinationPath , $filename );
//Log the deletion of seats to the log
$logaction = new Actionlog ();
2016-09-06 19:39:42 -07:00
$logaction -> item_id = $user -> id ;
$logaction -> item_type = User :: class ;
2016-03-25 01:18:05 -07:00
$logaction -> user_id = Auth :: user () -> id ;
$logaction -> note = e ( Input :: get ( 'notes' ));
2016-09-06 19:39:42 -07:00
$logaction -> target_id = null ;
2016-09-26 22:35:51 -07:00
$logaction -> created_at = date ( " Y-m-d H:i:s " );
2016-03-25 01:18:05 -07:00
$logaction -> filename = $filename ;
$logaction -> action_type = 'uploaded' ;
$logaction -> save ();
}
return JsonResponse :: create ( $logaction );
} else {
return JsonResponse :: create ([ " error " => " Failed validation: " . print_r ( $logaction -> getErrors (), true )], 500 );
}
}
/**
* Delete file
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 6 ]
* @ param int $userId
* @ param int $fileId
* @ return Redirect
*/
public function getDeleteFile ( $userId = null , $fileId = null )
{
$user = User :: find ( $userId );
2016-03-25 15:50:08 -07:00
$destinationPath = config ( 'app.private_uploads' ) . '/users' ;
2016-03-25 01:18:05 -07:00
// the license is valid
if ( isset ( $user -> id )) {
if ( ! Company :: isCurrentUserHasAccess ( $user )) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
} else {
$log = Actionlog :: find ( $fileId );
$full_filename = $destinationPath . '/' . $log -> filename ;
if ( file_exists ( $full_filename )) {
unlink ( $destinationPath . '/' . $log -> filename );
}
$log -> delete ();
2016-04-28 21:06:41 -07:00
return redirect () -> back () -> with ( 'success' , trans ( 'admin/users/message.deletefile.success' ));
2016-03-25 01:18:05 -07:00
}
} else {
// Prepare the error message
2016-04-07 13:39:35 -07:00
$error = trans ( 'admin/users/message.does_not_exist' , compact ( 'id' ));
2016-03-25 01:18:05 -07:00
// Redirect to the licence management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , $error );
2016-03-25 01:18:05 -07:00
}
}
/**
* Display / download the uploaded file
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v1 . 6 ]
* @ param int $userId
* @ param int $fileId
* @ return mixed
*/
public function displayFile ( $userId = null , $fileId = null )
{
$user = User :: find ( $userId );
// the license is valid
if ( isset ( $user -> id )) {
if ( ! Company :: isCurrentUserHasAccess ( $user )) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , trans ( 'general.insufficient_permissions' ));
2016-03-25 01:18:05 -07:00
} else {
$log = Actionlog :: find ( $fileId );
2016-07-28 05:49:41 -07:00
$file = $log -> get_src ( 'users' );
2016-03-25 01:18:05 -07:00
return Response :: download ( $file );
}
} else {
// Prepare the error message
2016-04-07 13:39:35 -07:00
$error = trans ( 'admin/users/message.does_not_exist' , compact ( 'id' ));
2016-03-25 01:18:05 -07:00
// Redirect to the licence management page
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , $error );
2016-03-25 01:18:05 -07:00
}
}
/**
* Return view for LDAP import
*
* @ author Aladin Alaily
* @ since [ v1 . 8 ]
* @ return View
*/
2016-07-13 07:24:54 -07:00
public function getLDAP ()
2016-03-25 01:18:05 -07:00
{
$location_list = Helper :: locationsList ();
2016-07-13 05:50:24 -07:00
try {
$ldapconn = Ldap :: connectToLdap ();
} catch ( \Exception $e ) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , $e -> getMessage ());
2016-07-13 05:50:24 -07:00
}
try {
Ldap :: bindAdminToLdap ( $ldapconn );
} catch ( \Exception $e ) {
2016-12-15 20:52:39 -08:00
return redirect () -> route ( 'users.index' ) -> with ( 'error' , $e -> getMessage ());
2016-07-13 05:50:24 -07:00
}
return View :: make ( 'users/ldap' )
-> with ( 'location_list' , $location_list );
2016-03-25 01:18:05 -07:00
}
/**
* Declare the rules for the ldap fields validation .
*
* @ author Aladin Alaily
* @ since [ v1 . 8 ]
* @ var array
* @ deprecated 3.0
* @ todo remove this method in favor of other validation
* @ var array
*/
protected $ldapValidationRules = array (
'firstname' => 'required|string|min:2' ,
'employee_number' => 'string' ,
'username' => 'required|min:2|unique:users,username' ,
'email' => 'email|unique:users,email' ,
);
/**
* LDAP form processing .
*
* @ author Aladin Alaily
* @ since [ v1 . 8 ]
* @ return Redirect
*/
2016-08-02 03:45:03 -07:00
public function postLDAP ( Request $request )
2016-03-25 01:18:05 -07:00
{
2016-06-21 12:22:10 -07:00
ini_set ( 'max_execution_time' , 600 ); //600 seconds = 10 minutes
ini_set ( 'memory_limit' , '500M' );
2016-03-25 01:18:05 -07:00
$ldap_result_username = Setting :: getSettings () -> ldap_username_field ;
$ldap_result_last_name = Setting :: getSettings () -> ldap_lname_field ;
$ldap_result_first_name = Setting :: getSettings () -> ldap_fname_field ;
$ldap_result_active_flag = Setting :: getSettings () -> ldap_active_flag_field ;
$ldap_result_emp_num = Setting :: getSettings () -> ldap_emp_num ;
$ldap_result_email = Setting :: getSettings () -> ldap_email ;
2016-07-13 05:50:24 -07:00
try {
$ldapconn = Ldap :: connectToLdap ();
} catch ( \Exception $e ) {
return redirect () -> back () -> withInput () -> with ( 'error' , $e -> getMessage ());
2016-03-25 01:18:05 -07:00
}
2016-07-13 05:50:24 -07:00
try {
2016-07-13 07:24:54 -07:00
Ldap :: bindAdminToLdap ( $ldapconn );
2016-07-13 05:50:24 -07:00
} catch ( \Exception $e ) {
return redirect () -> back () -> withInput () -> with ( 'error' , $e -> getMessage ());
2016-03-25 01:18:05 -07:00
}
$summary = array ();
2016-07-13 05:50:24 -07:00
$results = Ldap :: findLdapUsers ();
2016-07-25 22:10:33 -07:00
$tmp_pass = substr ( str_shuffle ( " 0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ " ), 0 , 20 );
$pass = bcrypt ( $tmp_pass );
2016-03-25 01:18:05 -07:00
for ( $i = 0 ; $i < $results [ " count " ]; $i ++ ) {
if ( empty ( $ldap_result_active_flag ) || $results [ $i ][ $ldap_result_active_flag ][ 0 ] == " TRUE " ) {
$item = array ();
$item [ " username " ] = isset ( $results [ $i ][ $ldap_result_username ][ 0 ]) ? $results [ $i ][ $ldap_result_username ][ 0 ] : " " ;
$item [ " employee_number " ] = isset ( $results [ $i ][ $ldap_result_emp_num ][ 0 ]) ? $results [ $i ][ $ldap_result_emp_num ][ 0 ] : " " ;
$item [ " lastname " ] = isset ( $results [ $i ][ $ldap_result_last_name ][ 0 ]) ? $results [ $i ][ $ldap_result_last_name ][ 0 ] : " " ;
$item [ " firstname " ] = isset ( $results [ $i ][ $ldap_result_first_name ][ 0 ]) ? $results [ $i ][ $ldap_result_first_name ][ 0 ] : " " ;
$item [ " email " ] = isset ( $results [ $i ][ $ldap_result_email ][ 0 ]) ? $results [ $i ][ $ldap_result_email ][ 0 ] : " " ;
2016-03-25 01:38:10 -07:00
// User exists
2016-03-25 01:18:05 -07:00
$item [ " createorupdate " ] = 'updated' ;
2016-03-25 19:26:22 -07:00
if ( ! $user = User :: where ( 'username' , $item [ " username " ]) -> first ()) {
$user = new User ;
2016-07-25 22:10:33 -07:00
$user -> password = $pass ;
2016-03-25 01:18:05 -07:00
$item [ " createorupdate " ] = 'created' ;
}
// Create the user if they don't exist.
2016-07-25 22:10:33 -07:00
2016-03-25 01:18:05 -07:00
$user -> first_name = e ( $item [ " firstname " ]);
$user -> last_name = e ( $item [ " lastname " ]);
$user -> username = e ( $item [ " username " ]);
$user -> email = e ( $item [ " email " ]);
$user -> employee_num = e ( $item [ " employee_number " ]);
$user -> activated = 1 ;
2016-08-02 03:50:08 -07:00
if ( $request -> input ( 'location_id' ) != '' ) {
2016-08-02 03:45:03 -07:00
$user -> location_id = e ( $request -> input ( 'location_id' ));
}
2016-03-25 01:18:05 -07:00
$user -> notes = 'Imported from LDAP' ;
$user -> ldap_import = 1 ;
$errors = '' ;
if ( $user -> save ()) {
$item [ " note " ] = $item [ " createorupdate " ];
$item [ " status " ] = 'success' ;
} else {
foreach ( $user -> getErrors () -> getMessages () as $key => $err ) {
$errors .= '<li>' . $err [ 0 ];
}
$item [ " note " ] = $errors ;
$item [ " status " ] = 'error' ;
}
array_push ( $summary , $item );
}
}
2016-07-25 22:10:33 -07:00
return redirect () -> route ( 'ldap/user' ) -> with ( 'success' , " LDAP Import successful. " ) -> with ( 'summary' , $summary );
2016-03-25 01:18:05 -07:00
}
/**
* Return JSON containing a list of assets assigned to a user .
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v3 . 0 ]
* @ return string JSON
*/
public function getAssetList ( $userId )
{
2016-07-22 02:11:37 -07:00
$assets = Asset :: where ( 'assigned_to' , '=' , $userId ) -> with ( 'model' ) -> get ();
2016-03-25 01:18:05 -07:00
return response () -> json ( $assets );
}
2016-10-25 02:41:34 -07:00
/**
* Exports users to CSV
*
* @ author [ A . Gianotto ] [ < snipe @ snipe . net > ]
* @ since [ v3 . 5 ]
* @ return \Illuminate\Http\Response
*/
public function getExportUserCsv ()
{
\Debugbar :: disable ();
$response = new StreamedResponse ( function () {
// Open output stream
$handle = fopen ( 'php://output' , 'w' );
User :: with ( 'assets' , 'accessories' , 'consumables' , 'licenses' , 'manager' , 'groups' , 'userloc' , 'company' , 'throttle' ) -> orderBy ( 'created_at' , 'DESC' ) -> chunk ( 500 , function ( $users ) use ( $handle ) {
$headers = [
// strtolower to prevent Excel from trying to open it as a SYLK file
strtolower ( trans ( 'general.id' )),
trans ( 'admin/companies/table.title' ),
2016-10-25 02:50:23 -07:00
trans ( 'admin/users/table.title' ),
2016-10-25 02:41:34 -07:00
trans ( 'admin/users/table.employee_num' ),
trans ( 'admin/users/table.name' ),
2016-10-25 02:50:23 -07:00
trans ( 'admin/users/table.username' ),
2016-10-25 02:41:34 -07:00
trans ( 'admin/users/table.email' ),
trans ( 'admin/users/table.manager' ),
trans ( 'admin/users/table.location' ),
trans ( 'general.assets' ),
trans ( 'general.licenses' ),
trans ( 'general.accessories' ),
trans ( 'general.consumables' ),
trans ( 'admin/users/table.groups' ),
trans ( 'general.notes' ),
trans ( 'admin/users/table.activated' ),
trans ( 'general.created_at' )
];
2016-12-15 20:52:39 -08:00
2016-10-25 02:41:34 -07:00
fputcsv ( $handle , $headers );
foreach ( $users as $user ) {
$user_groups = '' ;
foreach ( $user -> groups as $user_group ) {
$user_groups .= $user_group -> name . ', ' ;
}
// Add a new row with data
$values = [
$user -> id ,
( $user -> company ) ? $user -> company -> name : '' ,
2016-10-25 02:50:23 -07:00
$user -> jobtitle ,
2016-10-25 02:41:34 -07:00
$user -> employee_num ,
$user -> fullName (),
2016-10-25 02:50:23 -07:00
$user -> username ,
2016-10-25 02:41:34 -07:00
$user -> email ,
( $user -> manager ) ? $user -> manager -> fullName () : '' ,
( $user -> location ) ? $user -> location -> name : '' ,
$user -> assets -> count (),
$user -> licenses -> count (),
$user -> accessories -> count (),
$user -> consumables -> count (),
$user_groups ,
$user -> notes ,
( $user -> activated == '1' ) ? trans ( 'general.yes' ) : trans ( 'general.no' ),
$user -> created_at ,
];
fputcsv ( $handle , $values );
}
});
// Close the output stream
fclose ( $handle );
}, 200 , [
'Content-Type' => 'text/csv' ,
'Content-Disposition' => 'attachment; filename="users-' . date ( 'Y-m-d-his' ) . '.csv"' ,
]);
return $response ;
}
2016-10-29 05:50:55 -07:00
public function postTwoFactorReset ( Request $request )
{
if ( Gate :: denies ( 'users.edit' )) {
return response () -> json ([ 'message' => trans ( 'general.insufficient_permissions' )], 500 );
}
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 );
}
}
2016-10-31 16:52:25 -07:00
2016-03-25 01:18:05 -07:00
}