summaryrefslogtreecommitdiffstats
path: root/funcweb/funcweb/identity/pamprovider.py
blob: 9f3ecf6f9de71a2082cabaed276f8447fc2ed907 (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
53
54
55
# -*- coding: utf-8 -*-
#
# Copyright © 2008  Red Hat, Inc. All rights reserved.
#
# This copyrighted material is made available to anyone wishing to use, modify,
# copy, or redistribute it subject to the terms and conditions of the GNU
# General Public License v.2.  This program is distributed in the hope that it
# will be useful, but WITHOUT ANY WARRANTY expressed or implied, including the
# implied warranties of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
# See the GNU General Public License for more details.  You should have
# received a copy of the GNU General Public License along with this program; if
# not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
# Floor, Boston, MA 02110-1301, USA. Any Red Hat trademarks that are
# incorporated in the source code or documentation are not subject to the GNU
# General Public License and may only be used or replicated with the express
# permission of Red Hat, Inc.
#
# Author(s): Luke Macken <lmacken@redhat.com>

import logging

from model import *
from turbogears.identity.saprovider import *

log = logging.getLogger(__name__)

visit_identity_class = None

class PAMIdentityProvider(SqlAlchemyIdentityProvider):
    """
        IdentityProvider that authenticates users against PAM.
    """
    def validate_identity(self, user_name, password, visit_key):
        if not self.validate_password(user_name, password):
            log.warning("Invalid password for %s" % user_name)
            return None

        log.info("Login successful for %s" % user_name)

        try:
            link = VisitIdentity.by_visit_key(visit_key)
            #link.user_id = user.id
            log.debug("Found visit!")
        except Exception, e:
            log.debug("Cannot find visit")
            link = VisitIdentity(visit_key=visit_key, user_id=user_name)
            print "Exception: %s" % str(e)

        return SqlAlchemyIdentity(visit_key, user)

    def validate_password(self,user_name, password):
        import pam
        log.debug("Authenticating user '%s' against PAM" % user_name)
        assert pam
        return pam.authenticate(user_name, password)