Files
entropy/libraries/entropy/services/authenticators.py
T
lxnay 8165dafa9a Entropy:
- move all the code inside the entropy package
- add compat modules outside
Entropy/Transceivers/FtpInterface:
- fix is_file_available to work on more systems


git-svn-id: http://svn.sabayonlinux.org/projects/entropy/trunk@3146 cd1c1023-2f26-0410-ae45-c471fc1f0318
2009-03-11 00:10:08 +00:00

125 lines
4.3 KiB
Python

# -*- coding: utf-8 -*-
'''
# DESCRIPTION:
# Entropy Object Oriented Interface
Copyright (C) 2007-2009 Fabio Erculiani
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
'''
from __future__ import with_statement
from entropy.services.skel import Authenticator
from entropy.services.auth_interfaces import phpBB3Auth
from entropy.services.skel import SocketAuthenticator
from entropy.exceptions import *
# Authenticator that can be used by SocketHostInterface based instances
class phpBB3(phpBB3Auth,SocketAuthenticator):
import entropy.tools as entropyTools
def __init__(self, HostInterface, *args, **kwargs):
SocketAuthenticator.__init__(self, HostInterface)
phpBB3Auth.__init__(self)
self.set_connection_data(kwargs)
self.connect()
def set_session(self, session):
self.session = session
session_data = self.HostInterface.sessions.get(self.session)
if not session_data:
return
auth_id = session_data['auth_uid']
if auth_id:
self.logged_in = True
# fill login_data with fake information
self.login_data = {'username': self.FAKE_USERNAME, 'password': 'look elsewhere, this is not a password', 'user_id': auth_id}
ip_address = session_data.get('ip_address')
if ip_address and self.do_update_session_table:
self._update_session_table(auth_id, ip_address)
def docmd_login(self, arguments):
# filter n00bs
if not arguments or (len(arguments) != 2):
return False,None,None,'wrong arguments'
ip_address = None
session_data = self.HostInterface.sessions.get(self.session)
if session_data:
ip_address = session_data.get('ip_address')
user = arguments[0]
password = arguments[1]
if ip_address:
if self._is_ip_banned(ip_address):
return False,user,None,"banned IP"
login_data = {'username': user, 'password': password}
self.set_login_data(login_data)
rc = False
try:
rc = self.login()
except PermissionDenied, e:
return rc,user,None,e.value
if rc:
uid = self.get_user_id()
is_admin = self.is_administrator()
is_dev = self.is_developer()
is_mod = self.is_moderator()
is_user = self.is_user()
self.HostInterface.sessions[self.session]['admin'] = is_admin
self.HostInterface.sessions[self.session]['developer'] = is_dev
self.HostInterface.sessions[self.session]['moderator'] = is_mod
self.HostInterface.sessions[self.session]['user'] = is_user
if ip_address and uid and self.do_update_session_table:
self._update_session_table(uid, ip_address)
return True,user,uid,"ok"
return rc,user,None,"login failed"
# if we get here it means we are logged in
def docmd_userdata(self):
data = self.get_user_data()
return True, data, 'ok'
def docmd_logout(self, myargs):
# filter n00bs
if (len(myargs) < 1) or (len(myargs) > 1):
return False,None,'wrong arguments'
user = myargs[0]
# filter n00bs
if not user or not isinstance(user,basestring):
return False,None,"wrong user"
if not self.is_logged_in():
return False,user,"already logged out"
return True,user,"ok"
def set_exc_permissions(self, *args, **kwargs):
pass
def hide_login_data(self, args):
myargs = args[:]
myargs[-1] = 'hidden'
return myargs
def terminate_instance(self):
self.disconnect()