X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/53593baa211863fbf66540cf1bcc36c8fb37257f..f217d072d76183bc07723dcc29503b732bd2022d:/SL/Auth.pm diff --git a/SL/Auth.pm b/SL/Auth.pm index 6be693382..5d97aa01f 100644 --- a/SL/Auth.pm +++ b/SL/Auth.pm @@ -12,6 +12,7 @@ use Regexp::IPv6 qw($IPv6_re); use SL::Auth::ColumnInformation; use SL::Auth::Constants qw(:all); use SL::Auth::DB; +use SL::Auth::HTTPHeaders; use SL::Auth::LDAP; use SL::Auth::Password; use SL::Auth::SessionValue; @@ -152,7 +153,7 @@ sub _read_auth_config { foreach my $module (split m{ +}, $self->{module}) { my $config_name; ($module, $config_name) = split m{:}, $module, 2; - $config_name ||= $module eq 'DB' ? 'database' : lc($module); + $config_name ||= $module eq 'DB' ? 'database' : $module eq 'HTTPHeaders' ? 'http_headers' : lc($module); my $config = $::lx_office_conf{'authentication/' . $config_name}; if (!$config) { @@ -166,6 +167,9 @@ sub _read_auth_config { } elsif ($module eq 'LDAP') { push @{ $self->{authenticators} }, SL::Auth::LDAP->new($config); + } elsif ($module eq 'HTTPHeaders') { + push @{ $self->{authenticators} }, SL::Auth::HTTPHeaders->new($config); + } else { my $locale = Locale->new('en'); $self->mini_error($locale->text('Unknown authenticantion module #1 specified in "config/kivitendo.conf".', $module)); @@ -228,6 +232,12 @@ sub authenticate_root { return $result; } +sub set_session_authenticated { + my ($self, $login, $result) = @_; + + $self->set_session_value(SESSION_KEY_USER_AUTH() => $result, login => $login, client_id => $self->client->{id}); +} + sub authenticate { my ($self, $login, $password) = @_; @@ -252,7 +262,8 @@ sub authenticate { } } - $self->set_session_value(SESSION_KEY_USER_AUTH() => $result, login => $login, client_id => $self->client->{id}); + $self->set_session_authenticated($login, $result); + return $result; } @@ -513,6 +524,9 @@ sub read_user { my %user_data; + # Set defaults for options not present in database + $user_data{follow_up_notify_by_email} = 1; + while (my $ref = $sth->fetchrow_hashref()) { $user_data{$ref->{cfg_key}} = $ref->{cfg_value}; @user_data{qw(id login)} = @{$ref}{qw(id login)};