brotherton-erpnext/erpnext/startup/event_handlers.py

58 lines
2.0 KiB
Python
Raw Normal View History

2013-11-20 07:29:58 +00:00
# Copyright (c) 2013, Web Notes Technologies Pvt. Ltd. and Contributors
# License: GNU General Public License v3. See license.txt"
2013-01-09 11:09:27 +00:00
2012-02-23 07:05:32 +00:00
from __future__ import unicode_literals
import webnotes
def on_session_creation(login_manager):
2012-01-17 12:47:06 +00:00
"""
called after login
update login_from and delete parallel sessions
"""
2012-01-03 10:41:04 +00:00
# Clear previous sessions i.e. logout previous log-in attempts
allow_multiple_sessions = ['demo@erpnext.com', 'Administrator', 'Guest']
if webnotes.session['user'] not in allow_multiple_sessions:
from webnotes.sessions import clear_sessions
clear_sessions(webnotes.session.user, keep_current=True)
2012-01-20 10:02:18 +00:00
2012-04-27 10:00:23 +00:00
# check if account is expired
check_if_expired()
if webnotes.session['user'] not in ('Guest', 'demo@erpnext.com'):
2012-02-03 07:26:12 +00:00
# create feed
from webnotes.utils import nowtime
from webnotes.profile import get_user_fullname
webnotes.conn.begin()
make_feed('Login', 'Profile', login_manager.user, login_manager.user,
2012-10-15 10:00:56 +00:00
'%s logged in at %s' % (get_user_fullname(login_manager.user), nowtime()),
login_manager.user=='Administrator' and '#8CA2B3' or '#1B750D')
webnotes.conn.commit()
2012-04-27 10:00:23 +00:00
def check_if_expired():
"""check if account is expired. If expired, do not allow login"""
2013-09-21 09:46:47 +00:00
from webnotes import conf
2012-04-27 10:00:23 +00:00
# check if expires_on is specified
2013-09-24 11:47:39 +00:00
if not 'expires_on' in conf: return
2012-04-27 10:00:23 +00:00
# check if expired
from datetime import datetime, date
expires_on = datetime.strptime(conf.expires_on, '%Y-%m-%d').date()
if date.today() <= expires_on: return
# if expired, stop user from logging in
from webnotes.utils import formatdate
2012-09-28 10:39:49 +00:00
msg = """Oops! Your subscription expired on <b>%s</b>.<br>""" % formatdate(conf.expires_on)
2012-09-28 10:36:06 +00:00
if 'System Manager' in webnotes.user.get_roles():
2012-09-28 10:36:06 +00:00
msg += """Just drop in a mail at <b>support@erpnext.com</b> and
we will guide you to get your account re-activated."""
2012-04-27 10:00:23 +00:00
else:
2012-09-28 10:36:06 +00:00
msg += """Just ask your System Manager to drop in a mail at <b>support@erpnext.com</b> and
we will guide him to get your account re-activated."""
webnotes.msgprint(msg)
2012-04-27 10:00:23 +00:00
webnotes.response['message'] = 'Account Expired'
raise webnotes.AuthenticationError