Files
myapp-full/myapp/ns_api/user.py

152 lines
3.7 KiB
Python
Raw Normal View History

__author__ = 'RemiZOffAlex'
__copyright__ = '(c) RemiZOffAlex'
__email__ = 'remizoffalex@mail.ru'
2020-08-17 19:57:37 +03:00
from . import jsonrpc
2020-02-17 01:05:56 +03:00
from .. import app, lib, models
@jsonrpc.method('user.add')
def user_add(username: str, password: str) -> dict:
"""Новый пользователь
"""
if username is None or len(username) < 4 or len(username) > 25:
raise ValueError('Длина логина должна быть от 4 до 25 символов')
if password is None or len(password) < 4 or len(password) > 25:
raise ValueError('Длина пароля должна быть от 4 до 25 символов')
user = models.db_session.query(
models.User
).filter(
models.User.name == username
).first()
if user:
raise ValueError('Пользователь с таким логином уже существует')
newuser = models.User(
username
)
newuser.password = lib.get_hash_password(
password,
app.config['SECRET_KEY']
)
models.db_session.add(newuser)
models.db_session.commit()
result = newuser.as_dict()
return result
@jsonrpc.method('user.enable')
def user_enable(id: int) -> dict:
"""Разблокировать пользователя
"""
userRow = models.db_session.query(
models.User
).filter(
models.User.id == id
).first()
if userRow is None:
raise ValueError
userRow.disable = False
models.db_session.commit()
return userRow.as_dict()
2020-07-03 11:35:08 +03:00
@jsonrpc.method('user.pages')
2020-08-17 19:57:37 +03:00
def user_pages_list(id: int, page: int) -> list:
2020-02-17 01:05:56 +03:00
"""Список статей пользователя
"""
user = models.db_session.query(
models.User
).filter(
2020-08-17 19:57:37 +03:00
models.User.id == id
2020-02-17 01:05:56 +03:00
).first()
if user is None:
raise ValueError
pages = models.db_session.query(
models.Page
).filter(
2020-08-17 19:57:37 +03:00
models.Page.user_id == id
2020-02-17 01:05:56 +03:00
).order_by(
models.Page.title.asc()
)
pages = lib.getpage(
pages,
page,
app.config['ITEMS_ON_PAGE']
).all()
result = []
for page in pages:
newRow = page.as_dict()
newRow['user'] = page.user.as_dict()
newRow['tags'] = []
for tagLink in page.tags:
newRow['tags'].append(tagLink.tag.as_dict())
result.append(newRow)
return result
2020-07-03 11:35:08 +03:00
@jsonrpc.method('user.pages.count')
2020-08-17 19:57:37 +03:00
def user_pages_count(id: int) -> int:
2020-02-17 01:05:56 +03:00
"""Общее количество статей
"""
user = models.db_session.query(
models.User
).filter(
2020-08-17 19:57:37 +03:00
models.User.id == id
2020-02-17 01:05:56 +03:00
).first()
if user is None:
raise ValueError
result = models.db_session.query(
models.Page
).filter(
2020-08-17 19:57:37 +03:00
models.Page.user_id == id
2020-02-17 01:05:56 +03:00
).count()
return result
2020-07-03 11:35:08 +03:00
@jsonrpc.method('users')
2022-05-03 22:34:52 +03:00
def users_list(
page: int = 1,
order_by: dict = {'field': 'name', 'order': 'asc'}
) -> list:
2020-07-03 11:35:08 +03:00
"""Показать список пользователей
"""
users = models.db_session.query(
models.User
2020-02-17 01:05:56 +03:00
)
# Сортировка
if order_by['field'] not in ['name', 'created']:
raise ValueError
if order_by['order'] not in ['asc', 'desc']:
raise ValueError
field = getattr(models.User, order_by['field'])
order = getattr(field, order_by['order'])
users = users.order_by(
order()
)
2020-02-17 01:05:56 +03:00
users = lib.getpage(
users,
page,
app.config['ITEMS_ON_PAGE']
).all()
result = []
for item in users:
result.append(item.as_dict())
return result
2020-02-08 05:04:27 +03:00
@jsonrpc.method('users.count')
2020-08-17 19:57:37 +03:00
def users_count() -> int:
2020-02-08 05:04:27 +03:00
"""Количество список пользователей
"""
result = models.db_session.query(
models.User
).count()
return result