1
0
mirror of https://github.com/spl0k/supysonic.git synced 2025-01-12 19:26:18 +00:00

Implemented user management methods

This commit is contained in:
spl0k 2013-06-18 16:12:35 +02:00
parent 9b3bb99b48
commit 7042634a89
3 changed files with 94 additions and 18 deletions

View File

@ -3,6 +3,8 @@
from flask import request from flask import request
from web import app from web import app
from db import User from db import User
from . import hexdecode
from user_manager import UserManager
@app.route('/rest/getUser.view', methods = [ 'GET', 'POST' ]) @app.route('/rest/getUser.view', methods = [ 'GET', 'POST' ])
def user_info(): def user_info():
@ -10,26 +12,72 @@ def user_info():
if username is None: if username is None:
return request.error_formatter(10, 'Missing username') return request.error_formatter(10, 'Missing username')
if username != request.username and not request.user.admin:
return request.error_formatter(50, 'Admin restricted')
user = User.query.filter(User.name == username).first() user = User.query.filter(User.name == username).first()
if user is None: if user is None:
return request.error_formatter(0, 'Unknown user') return request.error_formatter(0, 'Unknown user')
return request.formatter({ return request.formatter({ 'user': user.as_subsonic_user() })
'user': {
'username': user.name, @app.route('/rest/getUsers.view', methods = [ 'GET', 'POST' ])
'email': user.mail, def users_info():
'scrobblingEnabled': user.lastfm_session is not None and user.lastfm_status, if not request.user.admin:
'adminRole': user.admin, return request.error_formatter(50, 'Admin restricted')
'settingsRole': user.admin,
'downloadRole': True, return request.formatter({ 'users': { 'user': [ u.as_subsonic_user() for u in User.query.all() ] } })
'uploadRole': False,
'playlistRole': False, @app.route('/rest/createUser.view', methods = [ 'GET', 'POST' ])
'coverArtRole': False, def user_add():
'commentRole': False, if not request.user.admin:
'podcastRole': False, return request.error_formatter(50, 'Admin restricted')
'streamRole': True,
'jukeboxRole': False, username, password, email, admin = map(request.args.get, [ 'username', 'password', 'email', 'adminRole' ])
'shareRole': False if not username or not password or not email:
} return request.error_formatter(10, 'Missing parameter')
}) admin = True if admin in (True, 'True', 'true', 1, '1') else False
if password.startswith('enc:'):
password = hexdecode(password[4:])
status = UserManager.add(username, password, email, admin)
if status == UserManager.NAME_EXISTS:
return request.error_formatter(0, 'There is already a user with that username')
return request.formatter({})
@app.route('/rest/deleteUser.view', methods = [ 'GET', 'POST' ])
def user_del():
if not request.user.admin:
return request.error_formatter(50, 'Admin restricted')
username = request.args.get('username')
user = User.query.filter(User.name == username).first()
if not user:
return request.error_formatter(70, 'Unknown user')
status = UserManager.delete(user.id)
if status != UserManager.SUCCESS:
return request.error_formatter(0, UserManager.error_str(status))
return request.formatter({})
@app.route('/rest/changePassword.view', methods = [ 'GET', 'POST' ])
def user_changepass():
username, password = map(request.args.get, [ 'username', 'password' ])
if not username or not password:
return request.error_formatter(10, 'Missing parameter')
if username != request.username and not request.user.admin:
return request.error_formatter(50, 'Admin restricted')
if password.startswith('enc:'):
password = hexdecode(password[4:])
status = UserManager.change_password2(username, password)
if status != UserManager.SUCCESS:
return request.error_formatter(0, UserManager.error_str(status))
return request.formatter({})

18
db.py
View File

@ -64,6 +64,24 @@ class User(Base):
last_play = relationship('Track') last_play = relationship('Track')
last_play_date = Column(DateTime, nullable = True) last_play_date = Column(DateTime, nullable = True)
def as_subsonic_user(self):
return {
'username': self.name,
'email': self.mail,
'scrobblingEnabled': self.lastfm_session is not None and self.lastfm_status,
'adminRole': self.admin,
'settingsRole': True,
'downloadRole': True,
'uploadRole': False,
'playlistRole': False,
'coverArtRole': False,
'commentRole': False,
'podcastRole': False,
'streamRole': True,
'jukeboxRole': False,
'shareRole': False
}
class Folder(Base): class Folder(Base):
__tablename__ = 'folder' __tablename__ = 'folder'

View File

@ -76,6 +76,16 @@ class UserManager:
session.commit() session.commit()
return UserManager.SUCCESS return UserManager.SUCCESS
@staticmethod
def change_password2(name, new_pass):
user = User.query.filter(User.name == name).first()
if not user:
return UserManager.NO_SUCH_USER
user.password = UserManager.__encrypt_password(new_pass, user.salt)[0]
session.commit()
return UserManager.SUCCESS
@staticmethod @staticmethod
def error_str(err): def error_str(err):
if err == UserManager.SUCCESS: if err == UserManager.SUCCESS: