summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTimotej Lazar <timotej.lazar@fri.uni-lj.si>2015-12-10 17:42:03 +0100
committerTimotej Lazar <timotej.lazar@fri.uni-lj.si>2015-12-11 16:11:15 +0100
commit8139494300d3ddef1eb4ff60f6a10c5023d91bd0 (patch)
treee6bf3c10c72d1c939426cef898aee3d653e32755
parentb73cb3fa7117570843a15d8e86c491c5d9ad54fd (diff)
Return is_admin field on login
-rw-r--r--server/handlers.py14
-rw-r--r--server/user_session.py6
2 files changed, 15 insertions, 5 deletions
diff --git a/server/handlers.py b/server/handlers.py
index 918067f..56d07cd 100644
--- a/server/handlers.py
+++ b/server/handlers.py
@@ -61,12 +61,22 @@ class Login(CodeqService):
else:
session = request.session
try:
- name, email, date_joined, last_login = session.login(username, password)
+ name, email, is_admin, date_joined, last_login = session.login(username, password)
except AuthenticationFailed:
request.reply({'code': 3, 'message': 'Username or password do not match'})
else:
settings = session.get_settings()
- request.reply({'code': 0, 'message': 'OK', 'username': username, 'name': name, 'email' : email, 'joined' : date_joined.isoformat(), 'last-login' : last_login.isoformat(), 'settings': settings})
+ request.reply({
+ 'code': 0,
+ 'message': 'OK',
+ 'username': username,
+ 'name': name,
+ 'email': email,
+ 'admin': is_admin,
+ 'joined': date_joined.isoformat(),
+ 'last-login': last_login.isoformat(),
+ 'settings': settings
+ })
class Logout(CodeqService):
diff --git a/server/user_session.py b/server/user_session.py
index 906f610..900238c 100644
--- a/server/user_session.py
+++ b/server/user_session.py
@@ -85,7 +85,7 @@ class UserSession(object):
try:
cur = conn.cursor()
try:
- cur.execute('select id, password, name, email, date_joined, gui_lang, robot_address, gui_layout from codeq_user where username = %s', (username,))
+ cur.execute('select id, password, name, email, is_admin, date_joined, gui_lang, robot_address, gui_layout from codeq_user where username = %s', (username,))
row = cur.fetchone()
if row is None:
raise AuthenticationFailed('No such user: {}'.format(username))
@@ -93,8 +93,8 @@ class UserSession(object):
cur.execute('update codeq_user set last_login = %s where id = %s', (str(now), row[0],))
self.uid = row[0]
self.username = username
- self.settings = {'gui_lang': row[5], 'robot_address': row[6], 'gui_layout': row[7]}
- return row[2], row[3], row[4], now
+ self.settings = {'gui_lang': row[6], 'robot_address': row[7], 'gui_layout': row[8]}
+ return row[2], row[3], row[4], row[5], now
else:
raise AuthenticationFailed('Password mismatch')
finally: