summaryrefslogtreecommitdiff
path: root/FS/FS/AuthCookieHandler.pm
blob: b7d0dbf5b54f246d95d6896820189861fdbf7fb1 (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
47
48
49
50
51
52
package FS::AuthCookieHandler;
use base qw( Apache2::AuthCookie );

use strict;
use FS::UID qw( adminsuidsetup preuser_setup );
use FS::CurrentUser;
use FS::Auth;

#Apache 2.2 and below
sub useragent_ip {
  my( $self, $r ) = @_;
  $r->connection->remote_ip;
}

sub authen_cred {
  my( $self, $r, $username, $password, $totp_code ) = @_;

  preuser_setup();

  my $info = {};

  unless ( FS::Auth->authenticate($username, $password, $totp_code, $info) ) {
    warn "failed auth $username from ". $self->useragent_ip($r). "\n";
    return undef;
  }

  warn "authenticated $username from ". $self->useragent_ip($r). "\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 ". $self->useragent_ip($r). "\n";
    return undef;
  }

  $curuser->username;
}

1;