blob: b571e4705ca4a9100c6a73e728a30f73623d395f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
package FS::AuthCookieHandler;
use base qw( Apache2::AuthCookie );
use strict;
use FS::UID qw( adminsuidsetup preuser_setup );
use FS::CurrentUser;
use FS::Auth;
sub authen_cred {
my( $self, $r, $username, $password ) = @_;
preuser_setup();
my $info = {};
unless ( FS::Auth->authenticate($username, $password, $info) ) {
warn "failed auth $username from ". $r->connection->remote_ip. "\n";
return undef;
}
warn "authenticated $username from ". $r->connection->remote_ip. "\n";
FS::CurrentUser->load_user( $username,
'autocreate' => FS::Auth->auth_class->autocreate,
%$info,
);
FS::CurrentUser->new_session;
}
sub authen_ses_key {
my( $self, $r, $sessionkey ) = @_;
preuser_setup();
my $curuser = FS::CurrentUser->load_user_session( $sessionkey );
unless ( $curuser ) {
warn "bad session $sessionkey from ". $r->connection->remote_ip. "\n";
return undef;
}
$curuser->username;
}
1;
|