From 9032c3765182bb03d1c4f002af6a6d4365794a90 Mon Sep 17 00:00:00 2001 From: uralm1 Date: Fri, 28 Jan 2022 08:58:24 +0500 Subject: [PATCH] Organization attribute in config file --- CHANGELOG.md | 2 ++ adup.conf_empty | 2 ++ lib/Adup.pm | 4 ++-- lib/Adup/Ural/SyncAttributesCreateMoveUsers.pm | 3 ++- 4 files changed, 8 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 72fa11a..5d2562f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,8 @@ All notable changes to this project will be documented in this file. ## [Unreleased] +- Значение аттрибута организация сделано настраиваемым через конфигурационный файл. +- Исправлен баг из-за которого наименования подразделений с разным количеством пробелов считались одинаковыми в процедуре расчета перемещения пользователей. ## [1.20] - 2022-01-27 - Исправлен поиск "0". diff --git a/adup.conf_empty b/adup.conf_empty index 66a8796..c0eaa5f 100644 --- a/adup.conf_empty +++ b/adup.conf_empty @@ -35,6 +35,8 @@ log_lines_on_page => 12, changes_on_page => 10, + organization_attr => 'MY FIRM', + smb_share => '//smbserver/dbf', smb_file => 'persons.dbf', smb_user => 'user', diff --git a/lib/Adup.pm b/lib/Adup.pm index 529c1ba..c7fbde9 100644 --- a/lib/Adup.pm +++ b/lib/Adup.pm @@ -8,7 +8,7 @@ use Adup::Command::smbload; use Adup::Command::zupload; use Adup::Command::cron; -our $VERSION = '1.20'; +our $VERSION = '1.21'; # This method will run once at server start sub startup { @@ -135,7 +135,7 @@ sub validate_config { my $c = $self->config; my $e = undef; - for (qw/personnel_ldap_base flatgroups_ldap_base dismissed_ou_dn/) { + for (qw/personnel_ldap_base flatgroups_ldap_base dismissed_ou_dn organization_attr/) { unless ($c->{$_}) { $e = "Config parameter $_ is not defined!"; last; diff --git a/lib/Adup/Ural/SyncAttributesCreateMoveUsers.pm b/lib/Adup/Ural/SyncAttributesCreateMoveUsers.pm index 8e81057..202451b 100644 --- a/lib/Adup/Ural/SyncAttributesCreateMoveUsers.pm +++ b/lib/Adup/Ural/SyncAttributesCreateMoveUsers.pm @@ -58,6 +58,7 @@ sub do_sync { my $ldapbase = $args{job}->app->config->{ldap_base}; my $pers_ldapbase = $args{job}->app->config->{personnel_ldap_base}; my $fg_ldapbase = $args{job}->app->config->{flatgroups_ldap_base}; + my $organization_attr = $args{job}->app->config->{organization_attr}; my @attributes = qw/givenName sn middleName displayName initials title company department description employeeID/; while (my $next = $res->hash) { @@ -76,7 +77,7 @@ sub do_sync { $refhash->{displayName} = substr($next->{fio}, 0, 256); $refhash->{initials} = _abbr($next->{fio}); $refhash->{title} = substr($next->{dolj}, 0, 128) if $next->{dolj}; - $refhash->{company} = 'МУП "Уфаводоканал"'; + $refhash->{company} = $organization_attr; $refhash->{department} = substr($next->{dept}, 0, 64) if $next->{dept}; $refhash->{description} = substr($next->{otdel}, 0, 1024) if $next->{otdel}; $refhash->{employeeID} = substr($next->{tabn}, 0, 16) if $next->{tabn};