mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-07 03:47:32 -08:00
Merge branch 'develop'
This commit is contained in:
commit
ea4bfdc51d
|
@ -16,7 +16,7 @@ class LdapSync extends Command
|
||||||
*
|
*
|
||||||
* @var string
|
* @var string
|
||||||
*/
|
*/
|
||||||
protected $signature = 'snipeit:ldap-sync {--location=} {--location_id=} {--summary}';
|
protected $signature = 'snipeit:ldap-sync {--location=} {--location_id=} {--summary} {--json_summary}';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The console command description.
|
* The console command description.
|
||||||
|
@ -55,14 +55,14 @@ class LdapSync extends Command
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$ldapconn = Ldap::connectToLdap();
|
$ldapconn = Ldap::connectToLdap();
|
||||||
} catch (\Exception $e) {
|
|
||||||
LOG::error($e);
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
Ldap::bindAdminToLdap($ldapconn);
|
Ldap::bindAdminToLdap($ldapconn);
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
|
if ($this->option('json_summary')) {
|
||||||
|
$json_summary = [ "error" => true, "error_message" => $e->getMessage(), "summary" => [] ];
|
||||||
|
$this->info(json_encode($json_summary));
|
||||||
|
}
|
||||||
LOG::error($e);
|
LOG::error($e);
|
||||||
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
$summary = array();
|
$summary = array();
|
||||||
|
@ -70,12 +70,12 @@ class LdapSync extends Command
|
||||||
$results = Ldap::findLdapUsers();
|
$results = Ldap::findLdapUsers();
|
||||||
|
|
||||||
$ldap_ou_locations = Location::whereNotNull('ldap_ou')->get();
|
$ldap_ou_locations = Location::whereNotNull('ldap_ou')->get();
|
||||||
|
|
||||||
if (sizeof($ldap_ou_locations) > 0) {
|
if (sizeof($ldap_ou_locations) > 0) {
|
||||||
LOG::debug('Some locations have special OUs set. Locations will be automatically set for users in those OUs.');
|
LOG::debug('Some locations have special OUs set. Locations will be automatically set for users in those OUs.');
|
||||||
}
|
}
|
||||||
|
|
||||||
$results = Ldap::findLdapUsers();
|
// Inject location information fields
|
||||||
for ($i = 0; $i < $results["count"]; $i++) {
|
for ($i = 0; $i < $results["count"]; $i++) {
|
||||||
$results[$i]["ldap_location_override"] = false;
|
$results[$i]["ldap_location_override"] = false;
|
||||||
$results[$i]["location_id"] = 0;
|
$results[$i]["location_id"] = 0;
|
||||||
|
@ -90,8 +90,8 @@ class LdapSync extends Command
|
||||||
LOG::debug('Location ID '.$this->option('location_id').' passed');
|
LOG::debug('Location ID '.$this->option('location_id').' passed');
|
||||||
LOG::debug('Importing to '.$location->name.' ('.$location->id.')');
|
LOG::debug('Importing to '.$location->name.' ('.$location->id.')');
|
||||||
} else {
|
} else {
|
||||||
$location = NULL;
|
$location = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!isset($location)) {
|
if (!isset($location)) {
|
||||||
LOG::debug('That location is invalid or a location was not provided, so no location will be assigned by default.');
|
LOG::debug('That location is invalid or a location was not provided, so no location will be assigned by default.');
|
||||||
|
@ -135,6 +135,14 @@ class LdapSync extends Command
|
||||||
$item["ldap_location_override"] = isset($results[$i]["ldap_location_override"]) ? $results[$i]["ldap_location_override"]:"";
|
$item["ldap_location_override"] = isset($results[$i]["ldap_location_override"]) ? $results[$i]["ldap_location_override"]:"";
|
||||||
$item["location_id"] = isset($results[$i]["location_id"]) ? $results[$i]["location_id"]:"";
|
$item["location_id"] = isset($results[$i]["location_id"]) ? $results[$i]["location_id"]:"";
|
||||||
|
|
||||||
|
if ( array_key_exists('useraccountcontrol', $results[$i]) ) {
|
||||||
|
$enabled_accounts = [
|
||||||
|
'512', '544', '66048', '66080', '262656', '262688', '328192', '328224'
|
||||||
|
];
|
||||||
|
$item['activated'] = ( in_array($results[$i]['useraccountcontrol'][0], $enabled_accounts) ) ? 1 : 0;
|
||||||
|
} else {
|
||||||
|
$item['activated'] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
// User exists
|
// User exists
|
||||||
$item["createorupdate"] = 'updated';
|
$item["createorupdate"] = 'updated';
|
||||||
|
@ -145,14 +153,12 @@ class LdapSync extends Command
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create the user if they don't exist.
|
// Create the user if they don't exist.
|
||||||
|
|
||||||
|
|
||||||
$user->first_name = e($item["firstname"]);
|
$user->first_name = e($item["firstname"]);
|
||||||
$user->last_name = e($item["lastname"]);
|
$user->last_name = e($item["lastname"]);
|
||||||
$user->username = e($item["username"]);
|
$user->username = e($item["username"]);
|
||||||
$user->email = e($item["email"]);
|
$user->email = e($item["email"]);
|
||||||
$user->employee_num = e($item["employee_number"]);
|
$user->employee_num = e($item["employee_number"]);
|
||||||
$user->activated = 1;
|
$user->activated = $item['activated'];
|
||||||
|
|
||||||
if ($item['ldap_location_override'] == true) {
|
if ($item['ldap_location_override'] == true) {
|
||||||
$user->location_id = $item['location_id'];
|
$user->location_id = $item['location_id'];
|
||||||
|
@ -190,11 +196,11 @@ class LdapSync extends Command
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
} else if ($this->option('json_summary')) {
|
||||||
|
$json_summary = [ "error" => false, "error_message" => "", "summary" => $summary ];
|
||||||
|
$this->info(json_encode($json_summary));
|
||||||
} else {
|
} else {
|
||||||
return $summary;
|
return $summary;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@ use App\Models\Company;
|
||||||
use Config;
|
use Config;
|
||||||
use App\Helpers\Helper;
|
use App\Helpers\Helper;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
use App\Http\Requests\ImageUploadRequest;
|
||||||
|
|
||||||
use Symfony\Component\HttpFoundation\JsonResponse;
|
use Symfony\Component\HttpFoundation\JsonResponse;
|
||||||
|
|
||||||
|
@ -68,7 +69,7 @@ class AssetModelsController extends Controller
|
||||||
* @since [v1.0]
|
* @since [v1.0]
|
||||||
* @return Redirect
|
* @return Redirect
|
||||||
*/
|
*/
|
||||||
public function store(Request $request)
|
public function store(ImageUploadRequest $request)
|
||||||
{
|
{
|
||||||
|
|
||||||
// Create a new asset model
|
// Create a new asset model
|
||||||
|
@ -90,14 +91,21 @@ class AssetModelsController extends Controller
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Input::file('image')) {
|
if (Input::file('image')) {
|
||||||
|
|
||||||
$image = Input::file('image');
|
$image = Input::file('image');
|
||||||
$file_name = str_random(25).".".$image->getClientOriginalExtension();
|
$file_name = str_random(25) . "." . $image->getClientOriginalExtension();
|
||||||
$path = public_path('uploads/models/'.$file_name);
|
$path = public_path('uploads/models/');
|
||||||
Image::make($image->getRealPath())->resize(500, null, function ($constraint) {
|
|
||||||
$constraint->aspectRatio();
|
if ($image->getClientOriginalExtension()!='svg') {
|
||||||
$constraint->upsize();
|
Image::make($image->getRealPath())->resize(500, null, function ($constraint) {
|
||||||
})->save($path);
|
$constraint->aspectRatio();
|
||||||
|
$constraint->upsize();
|
||||||
|
})->save($path.'/'.$file_name);
|
||||||
|
} else {
|
||||||
|
$image->move($path, $file_name);
|
||||||
|
}
|
||||||
$model->image = $file_name;
|
$model->image = $file_name;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Was it created?
|
// Was it created?
|
||||||
|
|
|
@ -33,6 +33,7 @@ use URL;
|
||||||
use View;
|
use View;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Gate;
|
use Gate;
|
||||||
|
use Artisan;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This controller handles all actions related to Users for
|
* This controller handles all actions related to Users for
|
||||||
|
@ -1029,128 +1030,20 @@ class UsersController extends Controller
|
||||||
*/
|
*/
|
||||||
public function postLDAP(Request $request)
|
public function postLDAP(Request $request)
|
||||||
{
|
{
|
||||||
$this->authorize('update', User::class);
|
// Call Artisan LDAP import command.
|
||||||
ini_set('max_execution_time', 600); //600 seconds = 10 minutes
|
$location_id = $request->input('location_id');
|
||||||
ini_set('memory_limit', '500M');
|
Artisan::call('snipeit:ldap-sync', ['--location_id' => $location_id, '--json_summary' => true]);
|
||||||
|
|
||||||
$ldap_result_username = Setting::getSettings()->ldap_username_field;
|
// Collect and parse JSON summary.
|
||||||
$ldap_result_last_name = Setting::getSettings()->ldap_lname_field;
|
$ldap_results_json = Artisan::output();
|
||||||
$ldap_result_first_name = Setting::getSettings()->ldap_fname_field;
|
$ldap_results = json_decode($ldap_results_json, true);
|
||||||
|
|
||||||
$ldap_result_active_flag = Setting::getSettings()->ldap_active_flag_field;
|
// Direct user to appropriate status page.
|
||||||
$ldap_result_emp_num = Setting::getSettings()->ldap_emp_num;
|
if ($ldap_results['error']) {
|
||||||
$ldap_result_email = Setting::getSettings()->ldap_email;
|
return redirect()->back()->withInput()->with('error', $ldap_results['error_message']);
|
||||||
|
} else {
|
||||||
try {
|
return redirect()->route('ldap/user')->with('success', "LDAP Import successful.")->with('summary', $ldap_results['summary']);
|
||||||
$ldapconn = Ldap::connectToLdap();
|
|
||||||
} catch (\Exception $e) {
|
|
||||||
return redirect()->back()->withInput()->with('error', $e->getMessage());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
|
||||||
Ldap::bindAdminToLdap($ldapconn);
|
|
||||||
} catch (\Exception $e) {
|
|
||||||
return redirect()->back()->withInput()->with('error', $e->getMessage());
|
|
||||||
}
|
|
||||||
|
|
||||||
$summary = array();
|
|
||||||
|
|
||||||
$ldap_ou_locations = Location::whereNotNull('ldap_ou')->get();
|
|
||||||
|
|
||||||
$results = Ldap::findLdapUsers();
|
|
||||||
|
|
||||||
// Inject location information fields
|
|
||||||
for ($i = 0; $i < $results["count"]; $i++) {
|
|
||||||
$results[$i]["ldap_location_override"] = false;
|
|
||||||
$results[$i]["location_id"] = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Grab subsets based on location-specific DNs, and overwrite location for these users.
|
|
||||||
foreach ($ldap_ou_locations as $ldap_loc) {
|
|
||||||
$location_users = Ldap::findLdapUsers($ldap_loc->ldap_ou);
|
|
||||||
$usernames = array();
|
|
||||||
for ($i = 0; $i < $location_users["count"]; $i++) {
|
|
||||||
$location_users[$i]["ldap_location_override"] = true;
|
|
||||||
$location_users[$i]["location_id"] = $ldap_loc->id;
|
|
||||||
$usernames[] = $location_users[$i][$ldap_result_username][0];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Delete located users from the general group.
|
|
||||||
foreach ($results as $key => $generic_entry) {
|
|
||||||
if (in_array($generic_entry[$ldap_result_username][0], $location_users)) {
|
|
||||||
unset($results[$key]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$global_count = $results['count'];
|
|
||||||
$results = array_merge($location_users, $results);
|
|
||||||
$results['count'] = $global_count;
|
|
||||||
}
|
|
||||||
|
|
||||||
$tmp_pass = substr(str_shuffle("0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"), 0, 20);
|
|
||||||
$pass = bcrypt($tmp_pass);
|
|
||||||
|
|
||||||
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] : "" ;
|
|
||||||
$item["ldap_location_override"] = isset($results[$i]["ldap_location_override"]) ? $results[$i]["ldap_location_override"]:"";
|
|
||||||
$item["location_id"] = isset($results[$i]["location_id"]) ? $results[$i]["location_id"]:"";
|
|
||||||
|
|
||||||
if( array_key_exists('useraccountcontrol', $results[$i]) ) {
|
|
||||||
$enabled_accounts = [
|
|
||||||
'512', '544', '66048', '66080', '262656', '262688', '328192', '328224'
|
|
||||||
];
|
|
||||||
$item['activated'] = ( in_array($results[$i]['useraccountcontrol'][0], $enabled_accounts) ) ? 1 : 0;
|
|
||||||
} else {
|
|
||||||
$item['activated'] = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// User exists
|
|
||||||
$item["createorupdate"] = 'updated';
|
|
||||||
if (!$user = User::where('username', $item["username"])->first()) {
|
|
||||||
$user = new User;
|
|
||||||
$user->password = $pass;
|
|
||||||
$item["createorupdate"] = 'created';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create the user if they don't exist.
|
|
||||||
$user->first_name = $item["firstname"];
|
|
||||||
$user->last_name = $item["lastname"];
|
|
||||||
$user->username = $item["username"];
|
|
||||||
$user->email = $item["email"];
|
|
||||||
$user->employee_num = e($item["employee_number"]);
|
|
||||||
$user->activated = $item['activated'];
|
|
||||||
|
|
||||||
if ($item['ldap_location_override'] == true) {
|
|
||||||
$user->location_id = $item['location_id'];
|
|
||||||
} else if ($request->input('location_id')!='') {
|
|
||||||
$user->location_id = e($request->input('location_id'));
|
|
||||||
}
|
|
||||||
$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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return redirect()->route('ldap/user')->with('success', "LDAP Import successful.")->with('summary', $summary);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -83,6 +83,11 @@ class Location extends SnipeModel
|
||||||
// return $this->hasMany('\App\Models\Asset', 'assigned_to')->withTrashed();
|
// return $this->hasMany('\App\Models\Asset', 'assigned_to')->withTrashed();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function setLdapOuAttribute($ldap_ou)
|
||||||
|
{
|
||||||
|
return $this->attributes['ldap_ou'] = empty($ldap_ou) ? null : $ldap_ou;
|
||||||
|
}
|
||||||
|
|
||||||
public static function getLocationHierarchy($locations, $parent_id = null)
|
public static function getLocationHierarchy($locations, $parent_id = null)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
|
@ -47,11 +47,11 @@
|
||||||
|
|
||||||
<!-- LDAP Search OU -->
|
<!-- LDAP Search OU -->
|
||||||
@if ($snipeSettings->ldap_enabled == 1)
|
@if ($snipeSettings->ldap_enabled == 1)
|
||||||
<div class="form-group {{ $errors->has('currency') ? ' has-error' : '' }}">
|
<div class="form-group {{ $errors->has('ldap_ou') ? ' has-error' : '' }}">
|
||||||
<label for="ldap_ou" class="col-md-3 control-label">
|
<label for="ldap_ou" class="col-md-3 control-label">
|
||||||
{{ trans('admin/locations/table.ldap_ou') }}
|
{{ trans('admin/locations/table.ldap_ou') }}
|
||||||
</label>
|
</label>
|
||||||
<div class="col-md-7{{ (\App\Helpers\Helper::checkIfRequired($item, 'currency')) ? ' required' : '' }}">
|
<div class="col-md-7{{ (\App\Helpers\Helper::checkIfRequired($item, 'ldap_ou')) ? ' required' : '' }}">
|
||||||
{{ Form::text('ldap_ou', Input::old('ldap_ou', $item->ldap_ou), array('class' => 'form-control')) }}
|
{{ Form::text('ldap_ou', Input::old('ldap_ou', $item->ldap_ou), array('class' => 'form-control')) }}
|
||||||
{!! $errors->first('ldap_ou', '<span class="alert-msg">:message</span>') !!}
|
{!! $errors->first('ldap_ou', '<span class="alert-msg">:message</span>') !!}
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in a new issue