##// END OF EJS Templates
updated setup dependencies
updated setup dependencies

File last commit:

r96:f24b9a29 default
r170:f9e89209 default
Show More
auth.py
83 lines | 3.0 KiB | text/x-python | PythonLexer
Marcin Kuzminski
Added app basic auth....
r41 import logging
from datetime import datetime
import crypt
implemented autentication
r52 from pylons import session, url
from pylons.controllers.util import abort, redirect
from decorator import decorator
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 from sqlalchemy.exc import OperationalError
Marcin Kuzminski
Added app basic auth....
r41 log = logging.getLogger(__name__)
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 from pylons_app.model import meta
from pylons_app.model.db import Users, UserLogs
from sqlalchemy.orm.exc import NoResultFound, MultipleResultsFound
Marcin Kuzminski
Added app basic auth....
r41
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 def get_crypt_password(password):
return crypt.crypt(password, '6a')
Marcin Kuzminski
Static files for production fixed...
r46
def admin_auth(username, password):
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 sa = meta.Session
password_crypt = get_crypt_password(password)
Marcin Kuzminski
Static files for production fixed...
r46
try:
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 user = sa.query(Users).filter(Users.username == username).one()
except (NoResultFound, MultipleResultsFound, OperationalError) as e:
Marcin Kuzminski
Static files for production fixed...
r46 log.error(e)
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 user = None
Marcin Kuzminski
Static files for production fixed...
r46
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 if user:
if user.active:
if user.username == username and user.password == password_crypt and user.admin:
Marcin Kuzminski
Static files for production fixed...
r46 log.info('user %s authenticated correctly', username)
return True
else:
log.error('user %s is disabled', username)
return False
Marcin Kuzminski
Added app basic auth....
r41 def authfunc(environ, username, password):
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 sa = meta.Session
password_crypt = get_crypt_password(password)
try except error on non existing user table
r42 try:
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 user = sa.query(Users).filter(Users.username == username).one()
except (NoResultFound, MultipleResultsFound, OperationalError) as e:
try except error on non existing user table
r42 log.error(e)
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 user = None
if user:
if user.active:
if user.username == username and user.password == password_crypt:
Marcin Kuzminski
Added app basic auth....
r41 log.info('user %s authenticated correctly', username)
implemented admin page login
r45 if environ:
http_accept = environ.get('HTTP_ACCEPT')
if http_accept.startswith('application/mercurial') or \
environ['PATH_INFO'].find('raw-file') != -1:
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 repo = environ['PATH_INFO']
implemented admin page login
r45 for qry in environ['QUERY_STRING'].split('&'):
if qry.startswith('cmd'):
Marcin Kuzminski
Added app basic auth....
r41
implemented admin page login
r45 try:
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 user_log = UserLogs()
user_log.user_id = user.user_id
user_log.action = qry
user_log.repository = repo
user_log.action_date = datetime.now()
sa.add(user_log)
sa.commit()
log.info('Adding user %s, action %s', username, qry)
implemented admin page login
r45 except Exception as e:
Marcin Kuzminski
Changed auth lib for sqlalchemy
r64 sa.rollback()
implemented admin page login
r45 log.error(e)
Marcin Kuzminski
Added app basic auth....
r41 return True
else:
log.error('user %s is disabled', username)
return False
implemented autentication
r52
@decorator
def authenticate(fn, *args, **kwargs):
if not session.get('admin_user', False):
redirect(url('admin_home'), 301)
return fn(*args, **kwargs)