2016-10-31 20:59:46 -07:00
< ? php
namespace App\Console\Commands ;
2024-03-16 19:51:40 -07:00
use App\Models\Asset ;
2021-04-14 10:17:57 -07:00
use App\Models\Department ;
2022-10-18 15:18:09 -07:00
use App\Models\Group ;
2020-11-30 17:11:44 -08:00
use Illuminate\Console\Command ;
2021-06-10 13:15:52 -07:00
use App\Models\Setting ;
2020-11-30 17:11:44 -08:00
use App\Models\Ldap ;
2021-06-10 13:15:52 -07:00
use App\Models\User ;
2016-10-31 20:59:46 -07:00
use App\Models\Location ;
2024-05-29 04:38:15 -07:00
use Illuminate\Support\Facades\Log ;
2020-11-30 17:11:44 -08:00
2016-10-31 20:59:46 -07:00
class LdapSync extends Command
{
/**
* The name and signature of the console command .
*
* @ var string
*/
2023-11-02 16:50:19 -07:00
protected $signature = 'snipeit:ldap-sync {--location=} {--location_id=*} {--base_dn=} {--filter=} {--summary} {--json_summary}' ;
2016-10-31 20:59:46 -07:00
/**
* The console command description .
*
* @ var string
*/
2020-11-30 17:11:44 -08:00
protected $description = 'Command line LDAP sync' ;
2020-08-14 14:45:05 -07:00
/**
* Create a new command instance .
2020-11-30 17:11:44 -08:00
*
* @ return void
2016-10-31 20:59:46 -07:00
*/
2020-11-30 17:11:44 -08:00
public function __construct ()
2016-10-31 20:59:46 -07:00
{
parent :: __construct ();
}
/**
* Execute the console command .
*
* @ return mixed
*/
public function handle ()
{
2023-02-01 16:36:30 -08:00
// If LDAP enabled isn't set to 1 (ldap_enabled!=1) then we should cut this short immediately without going any further
if ( Setting :: getSettings () -> ldap_enabled != '1' ) {
$this -> error ( 'LDAP is not enabled. Aborting. See Settings > LDAP to enable it.' );
2023-02-01 16:46:58 -08:00
exit ();
2023-02-01 16:36:30 -08:00
}
2020-11-30 17:11:44 -08:00
ini_set ( 'max_execution_time' , env ( 'LDAP_TIME_LIM' , 600 )); //600 seconds = 10 minutes
ini_set ( 'memory_limit' , env ( 'LDAP_MEM_LIM' , '500M' ));
2024-09-13 08:05:28 -07:00
$ldap_map = [
" username " => Setting :: getSettings () -> ldap_username_field ,
" last_name " => Setting :: getSettings () -> ldap_lname_field ,
" first_name " => Setting :: getSettings () -> ldap_fname_field ,
" active_flag " => Setting :: getSettings () -> ldap_active_flag ,
" emp_num " => Setting :: getSettings () -> ldap_emp_num ,
" email " => Setting :: getSettings () -> ldap_email ,
" phone " => Setting :: getSettings () -> ldap_phone_field ,
" jobtitle " => Setting :: getSettings () -> ldap_jobtitle ,
" country " => Setting :: getSettings () -> ldap_country ,
" location " => Setting :: getSettings () -> ldap_location ,
" dept " => Setting :: getSettings () -> ldap_dept ,
" manager " => Setting :: getSettings () -> ldap_manager ,
];
2022-09-12 11:40:16 -07:00
$ldap_default_group = Setting :: getSettings () -> ldap_default_group ;
2023-12-13 16:11:02 -08:00
$search_base = Setting :: getSettings () -> ldap_base_dn ;
2020-08-14 14:45:05 -07:00
2020-11-30 17:11:44 -08:00
try {
$ldapconn = Ldap :: connectToLdap ();
Ldap :: bindAdminToLdap ( $ldapconn );
} catch ( \Exception $e ) {
if ( $this -> option ( 'json_summary' )) {
2021-06-10 13:15:52 -07:00
$json_summary = [ 'error' => true , 'error_message' => $e -> getMessage (), 'summary' => []];
2020-11-30 17:11:44 -08:00
$this -> info ( json_encode ( $json_summary ));
}
2023-02-07 11:00:30 -08:00
Log :: info ( $e );
2021-06-10 13:15:52 -07:00
2020-11-30 17:11:44 -08:00
return [];
2016-10-31 20:59:46 -07:00
}
2021-06-10 13:15:52 -07:00
$summary = [];
2016-10-31 20:59:46 -07:00
2020-11-30 17:11:44 -08:00
try {
2023-12-13 16:11:02 -08:00
/**
* if a location ID has been specified , use that OU
*/
2024-01-24 03:54:29 -08:00
if ( $this -> option ( 'location_id' ) ) {
2023-11-02 16:50:19 -07:00
foreach ( $this -> option ( 'location_id' ) as $location_id ){
2023-12-13 16:11:02 -08:00
$location_ou = Location :: where ( 'id' , '=' , $location_id ) -> value ( 'ldap_ou' );
2023-11-02 16:50:19 -07:00
$search_base = $location_ou ;
Log :: debug ( 'Importing users from specified location OU: \"' . $search_base . '\".' );
}
2024-01-24 03:54:29 -08:00
}
2023-11-16 10:02:56 -08:00
2023-12-13 16:11:02 -08:00
/**
2024-01-24 03:54:29 -08:00
* if a manual base DN has been specified , use that . Allow the Base DN to override
* even if there ' s a location - based DN - if you picked it , you must have picked it for a reason .
2023-12-13 16:11:02 -08:00
*/
2024-01-24 03:54:29 -08:00
if ( $this -> option ( 'base_dn' ) != '' ) {
2020-11-30 17:11:44 -08:00
$search_base = $this -> option ( 'base_dn' );
2023-02-07 11:00:30 -08:00
Log :: debug ( 'Importing users from specified base DN: \"' . $search_base . '\".' );
2020-11-30 17:11:44 -08:00
}
2023-12-13 16:11:02 -08:00
/**
2024-09-13 08:05:48 -07:00
* If a filter has been specified , use that , otherwise default to null
2023-12-13 16:11:02 -08:00
*/
2022-06-27 19:49:59 -07:00
if ( $this -> option ( 'filter' ) != '' ) {
2024-09-13 08:05:48 -07:00
$filter = $this -> option ( 'filter' );
2022-06-27 19:49:59 -07:00
} else {
2024-09-13 08:05:48 -07:00
$filter = null ;
2022-06-27 19:49:59 -07:00
}
2024-09-13 08:05:48 -07:00
/**
* We only need to request the LDAP attributes that we process
*/
$attributes = array_values ( array_filter ( $ldap_map ));
$results = Ldap :: findLdapUsers ( $search_base , - 1 , $filter , $attributes );
2020-11-30 17:11:44 -08:00
} catch ( \Exception $e ) {
if ( $this -> option ( 'json_summary' )) {
2021-06-10 13:15:52 -07:00
$json_summary = [ 'error' => true , 'error_message' => $e -> getMessage (), 'summary' => []];
2020-11-30 17:11:44 -08:00
$this -> info ( json_encode ( $json_summary ));
2017-12-14 12:57:43 -08:00
}
2023-02-07 11:00:30 -08:00
Log :: info ( $e );
2021-06-10 13:15:52 -07:00
2020-11-30 17:11:44 -08:00
return [];
2017-12-14 12:57:43 -08:00
}
2017-01-11 23:37:14 -08:00
2020-11-30 17:11:44 -08:00
/* Determine which location to assign users to by default. */
2024-10-15 09:26:31 -07:00
$default_location = null ;
2024-01-24 03:54:29 -08:00
if ( $this -> option ( 'location' ) != '' ) {
2024-10-15 09:26:31 -07:00
if ( $default_location = Location :: where ( 'name' , '=' , $this -> option ( 'location' )) -> first ()) {
2024-01-24 03:54:29 -08:00
Log :: debug ( 'Location name ' . $this -> option ( 'location' ) . ' passed' );
2024-10-15 09:26:31 -07:00
Log :: debug ( 'Importing to ' . $default_location -> name . ' (' . $default_location -> id . ')' );
2024-01-24 03:54:29 -08:00
}
} elseif ( $this -> option ( 'location_id' )) {
2024-10-15 09:26:31 -07:00
//TODO - figure out how or why this is an array?
2024-01-24 03:54:29 -08:00
foreach ( $this -> option ( 'location_id' ) as $location_id ) {
2024-10-15 09:26:31 -07:00
if ( $default_location = Location :: where ( 'id' , '=' , $location_id ) -> first ()) {
2023-11-02 16:50:19 -07:00
Log :: debug ( 'Location ID ' . $location_id . ' passed' );
2024-10-15 09:26:31 -07:00
Log :: debug ( 'Importing to ' . $default_location -> name . ' (' . $default_location -> id . ')' );
2023-11-02 16:50:19 -07:00
}
2020-11-30 17:11:44 -08:00
2023-10-16 15:13:38 -07:00
}
2020-10-21 15:13:36 -07:00
}
2024-10-15 09:26:31 -07:00
if ( ! isset ( $default_location )) {
2023-02-07 11:00:30 -08:00
Log :: debug ( 'That location is invalid or a location was not provided, so no location will be assigned by default.' );
2016-10-31 20:59:46 -07:00
}
2020-11-30 17:11:44 -08:00
/* Process locations with explicitly defined OUs, if doing a full import. */
2022-06-27 19:49:59 -07:00
if ( $this -> option ( 'base_dn' ) == '' && $this -> option ( 'filter' ) == '' ) {
2020-11-30 17:11:44 -08:00
// Retrieve locations with a mapped OU, and sort them from the shallowest to deepest OU (see #3993)
$ldap_ou_locations = Location :: where ( 'ldap_ou' , '!=' , '' ) -> get () -> toArray ();
2021-06-10 13:15:52 -07:00
$ldap_ou_lengths = [];
2020-11-30 17:11:44 -08:00
2020-12-01 21:26:52 -08:00
foreach ( $ldap_ou_locations as $ou_loc ) {
2021-06-10 13:15:52 -07:00
$ldap_ou_lengths [] = strlen ( $ou_loc [ 'ldap_ou' ]);
2017-01-11 23:37:14 -08:00
}
2020-11-30 17:11:44 -08:00
array_multisort ( $ldap_ou_lengths , SORT_ASC , $ldap_ou_locations );
2018-01-23 18:15:36 -08:00
2021-06-10 13:15:52 -07:00
if ( count ( $ldap_ou_locations ) > 0 ) {
2023-02-07 11:00:30 -08:00
Log :: debug ( 'Some locations have special OUs set. Locations will be automatically set for users in those OUs.' );
2017-01-11 23:37:14 -08:00
}
2020-11-30 17:11:44 -08:00
// Inject location information fields
2021-06-10 13:15:52 -07:00
for ( $i = 0 ; $i < $results [ 'count' ]; $i ++ ) {
$results [ $i ][ 'ldap_location_override' ] = false ;
$results [ $i ][ 'location_id' ] = 0 ;
2018-01-23 18:15:36 -08:00
}
2016-10-31 20:59:46 -07:00
2020-11-30 17:11:44 -08:00
// Grab subsets based on location-specific DNs, and overwrite location for these users.
foreach ( $ldap_ou_locations as $ldap_loc ) {
try {
2021-06-10 13:15:52 -07:00
$location_users = Ldap :: findLdapUsers ( $ldap_loc [ 'ldap_ou' ]);
2021-11-10 11:37:10 -08:00
} catch ( \Exception $e ) { // TODO: this is stolen from line 77 or so above
2020-11-30 17:11:44 -08:00
if ( $this -> option ( 'json_summary' )) {
2021-06-10 13:15:52 -07:00
$json_summary = [ 'error' => true , 'error_message' => trans ( 'admin/users/message.error.ldap_could_not_search' ) . ' Location: ' . $ldap_loc [ 'name' ] . ' (ID: ' . $ldap_loc [ 'id' ] . ') cannot connect to "' . $ldap_loc [ 'ldap_ou' ] . '" - ' . $e -> getMessage (), 'summary' => []];
2020-11-30 17:11:44 -08:00
$this -> info ( json_encode ( $json_summary ));
}
2023-02-07 11:00:30 -08:00
Log :: info ( $e );
2021-06-10 13:15:52 -07:00
2020-11-30 17:11:44 -08:00
return [];
2016-10-31 20:59:46 -07:00
}
2021-06-10 13:15:52 -07:00
$usernames = [];
for ( $i = 0 ; $i < $location_users [ 'count' ]; $i ++ ) {
2024-09-13 08:05:28 -07:00
if ( array_key_exists ( $ldap_map [ " username " ], $location_users [ $i ])) {
2021-06-10 13:15:52 -07:00
$location_users [ $i ][ 'ldap_location_override' ] = true ;
$location_users [ $i ][ 'location_id' ] = $ldap_loc [ 'id' ];
2024-09-13 08:05:28 -07:00
$usernames [] = $location_users [ $i ][ $ldap_map [ " username " ]][ 0 ];
2020-11-30 17:11:44 -08:00
}
}
// Delete located users from the general group.
foreach ( $results as $key => $generic_entry ) {
2024-09-13 08:05:28 -07:00
if (( is_array ( $generic_entry )) && ( array_key_exists ( $ldap_map [ " username " ], $generic_entry ))) {
if ( in_array ( $generic_entry [ $ldap_map [ " username " ]][ 0 ], $usernames )) {
2020-11-30 17:11:44 -08:00
unset ( $results [ $key ]);
}
}
2016-10-31 20:59:46 -07:00
}
2020-11-30 17:11:44 -08:00
$global_count = $results [ 'count' ];
$results = array_merge ( $location_users , $results );
$results [ 'count' ] = $global_count ;
2016-10-31 20:59:46 -07:00
}
2020-08-14 14:45:05 -07:00
}
2022-10-20 16:52:40 -07:00
$manager_cache = [];
2023-01-09 15:23:19 -08:00
if ( $ldap_default_group != null ) {
$default = Group :: find ( $ldap_default_group );
if ( ! $default ) {
$ldap_default_group = null ; // un-set the default group if that group doesn't exist
}
}
2021-06-10 13:15:52 -07:00
for ( $i = 0 ; $i < $results [ 'count' ]; $i ++ ) {
2024-10-15 09:26:31 -07:00
$item = [];
$item [ 'username' ] = $results [ $i ][ $ldap_map [ " username " ]][ 0 ] ? ? '' ;
$item [ 'employee_number' ] = $results [ $i ][ $ldap_map [ " emp_num " ]][ 0 ] ? ? '' ;
$item [ 'lastname' ] = $results [ $i ][ $ldap_map [ " last_name " ]][ 0 ] ? ? '' ;
$item [ 'firstname' ] = $results [ $i ][ $ldap_map [ " first_name " ]][ 0 ] ? ? '' ;
$item [ 'email' ] = $results [ $i ][ $ldap_map [ " email " ]][ 0 ] ? ? '' ;
$item [ 'ldap_location_override' ] = $results [ $i ][ 'ldap_location_override' ] ? ? '' ;
$item [ 'location_id' ] = $results [ $i ][ 'location_id' ] ? ? '' ;
$item [ 'telephone' ] = $results [ $i ][ $ldap_map [ " phone " ]][ 0 ] ? ? '' ;
$item [ 'jobtitle' ] = $results [ $i ][ $ldap_map [ " jobtitle " ]][ 0 ] ? ? '' ;
$item [ 'country' ] = $results [ $i ][ $ldap_map [ " country " ]][ 0 ] ? ? '' ;
$item [ 'department' ] = $results [ $i ][ $ldap_map [ " dept " ]][ 0 ] ? ? '' ;
$item [ 'manager' ] = $results [ $i ][ $ldap_map [ " manager " ]][ 0 ] ? ? '' ;
$item [ 'location' ] = $results [ $i ][ $ldap_map [ " location " ]][ 0 ] ? ? '' ;
$location = $default_location ; //initially, set '$location' to the default_location (which may just be `null`)
// ONLY if you are using the "ldap_location" option *AND* you have an actual result
if ( $ldap_map [ " location " ] && $item [ 'location' ]) {
$location = Location :: firstOrCreate ([
'name' => $item [ 'location' ],
2021-04-14 10:17:57 -07:00
]);
2024-10-15 09:26:31 -07:00
}
$department = Department :: firstOrCreate ([
'name' => $item [ 'department' ],
]);
$user = User :: where ( 'username' , $item [ 'username' ]) -> first ();
if ( $user ) {
// Updating an existing user.
$item [ 'createorupdate' ] = 'updated' ;
} else {
// Creating a new user.
$user = new User ;
$user -> password = $user -> noPassword ();
$user -> locale = app () -> getLocale ();
$user -> activated = 1 ; // newly created users can log in by default, unless AD's UAC is in use, or an active flag is set (below)
$item [ 'createorupdate' ] = 'created' ;
}
2020-11-30 17:11:44 -08:00
2023-08-01 09:39:58 -07:00
//If a sync option is not filled in on the LDAP settings don't populate the user field
2024-09-13 08:05:28 -07:00
if ( $ldap_map [ " username " ] != null ){
2021-06-10 13:15:52 -07:00
$user -> username = $item [ 'username' ];
2023-08-01 09:39:58 -07:00
}
2024-09-13 08:05:28 -07:00
if ( $ldap_map [ " last_name " ] != null ){
2023-08-01 09:39:58 -07:00
$user -> last_name = $item [ 'lastname' ];
}
2024-09-13 08:05:28 -07:00
if ( $ldap_map [ " first_name " ] != null ){
2023-08-01 09:39:58 -07:00
$user -> first_name = $item [ 'firstname' ];
}
2024-09-13 08:05:28 -07:00
if ( $ldap_map [ " emp_num " ] != null ){
2021-06-10 13:15:52 -07:00
$user -> employee_num = e ( $item [ 'employee_number' ]);
2023-08-01 09:39:58 -07:00
}
2024-09-13 08:05:28 -07:00
if ( $ldap_map [ " email " ] != null ){
2023-08-01 09:39:58 -07:00
$user -> email = $item [ 'email' ];
}
2024-09-13 08:05:28 -07:00
if ( $ldap_map [ " phone " ] != null ){
2021-06-10 13:15:52 -07:00
$user -> phone = $item [ 'telephone' ];
2023-08-01 09:39:58 -07:00
}
2024-09-13 08:05:28 -07:00
if ( $ldap_map [ " jobtitle " ] != null ){
2021-06-10 13:15:52 -07:00
$user -> jobtitle = $item [ 'jobtitle' ];
2023-08-01 09:39:58 -07:00
}
2024-09-13 08:05:28 -07:00
if ( $ldap_map [ " country " ] != null ){
2021-06-10 13:15:52 -07:00
$user -> country = $item [ 'country' ];
2023-08-01 09:39:58 -07:00
}
2024-09-13 08:05:28 -07:00
if ( $ldap_map [ " dept " ] != null ){
2021-04-14 10:17:57 -07:00
$user -> department_id = $department -> id ;
2023-08-01 09:39:58 -07:00
}
2024-09-13 08:05:28 -07:00
if ( $ldap_map [ " location " ] != null ){
2024-10-15 09:26:31 -07:00
$user -> location_id = $location ? -> id ;
2023-08-15 09:28:42 -07:00
}
2020-11-30 17:11:44 -08:00
2024-09-13 08:05:28 -07:00
if ( $ldap_map [ " manager " ] != null ){
2022-05-15 09:25:28 -07:00
if ( $item [ 'manager' ] != null ) {
2022-10-20 16:52:40 -07:00
// Check Cache first
if ( isset ( $manager_cache [ $item [ 'manager' ]])) {
// found in cache; use that and avoid extra lookups
$user -> manager_id = $manager_cache [ $item [ 'manager' ]];
} else {
// Get the LDAP Manager
try {
$ldap_manager = Ldap :: findLdapUsers ( $item [ 'manager' ], - 1 , $this -> option ( 'filter' ));
} catch ( \Exception $e ) {
2024-05-29 04:38:15 -07:00
Log :: warning ( " Manager lookup caused an exception: " . $e -> getMessage () . " . Falling back to direct username lookup " );
2022-10-20 16:52:40 -07:00
// Hail-mary for Okta manager 'shortnames' - will only work if
// Okta configuration is using full email-address-style usernames
$ldap_manager = [
" count " => 1 ,
0 => [
2024-09-13 08:05:28 -07:00
$ldap_map [ " username " ] => [ $item [ 'manager' ]]
2022-10-20 16:52:40 -07:00
]
];
}
2024-09-25 08:56:49 -07:00
$add_manager_to_cache = true ;
2022-10-20 16:52:40 -07:00
if ( $ldap_manager [ " count " ] > 0 ) {
2024-09-25 08:56:49 -07:00
try {
// Get the Manager's username
// PHP LDAP returns every LDAP attribute as an array, and 90% of the time it's an array of just one item. But, hey, it's an array.
$ldapManagerUsername = $ldap_manager [ 0 ][ $ldap_map [ " username " ]][ 0 ];
// Get User from Manager username.
$ldap_manager = User :: where ( 'username' , $ldapManagerUsername ) -> first ();
if ( $ldap_manager && isset ( $ldap_manager -> id )) {
// Link user to manager id.
$user -> manager_id = $ldap_manager -> id ;
}
} catch ( \Exception $e ) {
$add_manager_to_cache = false ;
\Log :: warning ( 'Handling ldap manager ' . $item [ 'manager' ] . ' caused an exception: ' . $e -> getMessage () . '. Continuing synchronization.' );
2022-10-20 16:52:40 -07:00
}
2022-08-19 09:09:03 -07:00
}
2024-09-25 08:56:49 -07:00
if ( $add_manager_to_cache ) {
$manager_cache [ $item [ 'manager' ]] = $ldap_manager && isset ( $ldap_manager -> id ) ? $ldap_manager -> id : null ; // Store results in cache, even if 'failed'
}
2022-10-20 16:52:40 -07:00
2022-05-15 09:25:28 -07:00
}
2022-03-24 11:24:39 -07:00
}
2023-08-01 09:39:58 -07:00
}
2022-10-19 19:01:52 -07:00
2024-10-15 09:26:31 -07:00
// Sync activated state for Active Directory.
if ( ! empty ( $ldap_map [ " active_flag " ])) { // IF we have an 'active' flag set....
// ....then *most* things that are truthy will activate the user. Anything falsey will deactivate them.
// (Specifically, we don't handle a value of '0.0' correctly)
$raw_value = @ $results [ $i ][ $ldap_map [ " active_flag " ]][ 0 ];
$filter_var = filter_var ( $raw_value , FILTER_VALIDATE_BOOLEAN , FILTER_NULL_ON_FAILURE );
$boolean_cast = ( bool ) $raw_value ;
$user -> activated = $filter_var ? ? $boolean_cast ; // if filter_var() was true or false, use that. If it's null, use the $boolean_cast
} elseif ( array_key_exists ( 'useraccountcontrol' , $results [ $i ])) {
// ....otherwise, (ie if no 'active' LDAP flag is defined), IF the UAC setting exists,
// ....then use the UAC setting on the account to determine can-log-in vs. cannot-log-in
/* The following is _probably_ the correct logic , but we can ' t use it because
some users may have been dependent upon the previous behavior , and this
could cause additional access to be available to users they don ' t want
to allow to log in .
$useraccountcontrol = $results [ $i ][ 'useraccountcontrol' ][ 0 ];
if (
// based on MS docs at: https://support.microsoft.com/en-us/help/305144/how-to-use-useraccountcontrol-to-manipulate-user-account-properties
( $useraccountcontrol & 0x200 ) && // is a NORMAL_ACCOUNT
! ( $useraccountcontrol & 0x02 ) && // *and* _not_ ACCOUNTDISABLE
! ( $useraccountcontrol & 0x10 ) // *and* _not_ LOCKOUT
) {
$user -> activated = 1 ;
} else {
$user -> activated = 0 ;
} */
$enabled_accounts = [
2023-01-31 16:49:41 -08:00
'512' , // 0x200 NORMAL_ACCOUNT
'544' , // 0x220 NORMAL_ACCOUNT, PASSWD_NOTREQD
'66048' , // 0x10200 NORMAL_ACCOUNT, DONT_EXPIRE_PASSWORD
'66080' , // 0x10220 NORMAL_ACCOUNT, PASSWD_NOTREQD, DONT_EXPIRE_PASSWORD
'262656' , // 0x40200 NORMAL_ACCOUNT, SMARTCARD_REQUIRED
'262688' , // 0x40220 NORMAL_ACCOUNT, PASSWD_NOTREQD, SMARTCARD_REQUIRED
'328192' , // 0x50200 NORMAL_ACCOUNT, SMARTCARD_REQUIRED, DONT_EXPIRE_PASSWORD
'328224' , // 0x50220 NORMAL_ACCOUNT, PASSWD_NOT_REQD, SMARTCARD_REQUIRED, DONT_EXPIRE_PASSWORD
'4194816' , // 0x400200 NORMAL_ACCOUNT, DONT_REQ_PREAUTH
2021-06-10 13:15:52 -07:00
'4260352' , // 0x410200 NORMAL_ACCOUNT, DONT_EXPIRE_PASSWORD, DONT_REQ_PREAUTH
'1049088' , // 0x100200 NORMAL_ACCOUNT, NOT_DELEGATED
2023-01-31 16:49:41 -08:00
'1114624' , // 0x110200 NORMAL_ACCOUNT, DONT_EXPIRE_PASSWORD, NOT_DELEGATED,
2024-10-15 09:26:31 -07:00
];
$user -> activated = ( in_array ( $results [ $i ][ 'useraccountcontrol' ][ 0 ], $enabled_accounts )) ? 1 : 0 ;
2020-11-30 17:11:44 -08:00
// If we're not using AD, and there isn't an activated flag set, activate all users
2024-10-15 09:26:31 -07:00
} /* implied 'else' here - leave the $user -> activated flag alone . Newly - created accounts will be active .
already - existing accounts will be however the administrator has set them */
2022-08-10 12:55:30 -07:00
2020-11-30 17:11:44 -08:00
2024-10-15 09:26:31 -07:00
if ( $item [ 'ldap_location_override' ] == true ) {
$user -> location_id = $item [ 'location_id' ];
} elseif (( isset ( $location )) && ( ! empty ( $location ))) {
if (( is_array ( $location )) && ( array_key_exists ( 'id' , $location ))) {
$user -> location_id = $location [ 'id' ];
} elseif ( is_object ( $location )) {
$user -> location_id = $location -> id ; //THIS is the magic line, this should do it.
}
}
// TODO - should we be NULLING locations if $location is really `null`, and that's what we came up with?
// will that conflict with any overriding setting that the user set? Like, if they moved someone from
// the 'null' location to somewhere, we wouldn't want to try to override that, right?
$location = null ;
$user -> ldap_import = 1 ;
$errors = '' ;
if ( $user -> save ()) {
$item [ 'note' ] = $item [ 'createorupdate' ];
$item [ 'status' ] = 'success' ;
if ( $item [ 'createorupdate' ] === 'created' && $ldap_default_group ) {
$user -> groups () -> attach ( $ldap_default_group );
2020-11-30 17:11:44 -08:00
}
2024-03-19 11:58:49 -07:00
//updates assets location based on user's location
2024-12-09 09:40:10 -08:00
Asset :: where ( 'assigned_to' , '=' , $user -> id ) -> where ( 'assigned_type' , '=' , User :: class ) -> update ([ 'location_id' => $user -> location_id ]);
2022-09-13 11:40:10 -07:00
2024-10-15 09:26:31 -07:00
} else {
foreach ( $user -> getErrors () -> getMessages () as $key => $err ) {
$errors .= $err [ 0 ];
2020-11-30 17:11:44 -08:00
}
2024-10-15 09:26:31 -07:00
$item [ 'note' ] = $errors ;
$item [ 'status' ] = 'error' ;
}
2020-11-30 17:11:44 -08:00
2024-10-15 09:26:31 -07:00
array_push ( $summary , $item );
2016-10-31 20:59:46 -07:00
}
2020-11-30 17:11:44 -08:00
if ( $this -> option ( 'summary' )) {
for ( $x = 0 ; $x < count ( $summary ); $x ++ ) {
2021-06-10 13:15:52 -07:00
if ( $summary [ $x ][ 'status' ] == 'error' ) {
2020-11-30 17:11:44 -08:00
$this -> error ( 'ERROR: ' . $summary [ $x ][ 'firstname' ] . ' ' . $summary [ $x ][ 'lastname' ] . ' (username: ' . $summary [ $x ][ 'username' ] . ') was not imported: ' . $summary [ $x ][ 'note' ]);
} else {
$this -> info ( 'User ' . $summary [ $x ][ 'firstname' ] . ' ' . $summary [ $x ][ 'lastname' ] . ' (username: ' . $summary [ $x ][ 'username' ] . ') was ' . strtoupper ( $summary [ $x ][ 'createorupdate' ]) . '.' );
}
}
2021-06-10 13:15:52 -07:00
} elseif ( $this -> option ( 'json_summary' )) {
$json_summary = [ 'error' => false , 'error_message' => '' , 'summary' => $summary ]; // hardcoding the error to false and the error_message to blank seems a bit weird
2017-10-06 16:15:14 -07:00
$this -> info ( json_encode ( $json_summary ));
2020-11-30 17:11:44 -08:00
} else {
return $summary ;
2016-10-31 20:59:46 -07:00
}
}
}