Добавлена сортировка для статей и пользователей

This commit is contained in:
RemiZOffAlex
2021-06-08 14:29:17 +03:00
parent 5f19dad9be
commit 1663f94b0e
2 changed files with 72 additions and 4 deletions

View File

@@ -91,14 +91,24 @@ def page_update(id: int, title: str, text: str) -> dict:
@jsonrpc.method('pages')
def pages_list(page: int) -> list:
def pages_list(page: int, order_by: dict = {'field': 'title', 'order': 'asc'}) -> list:
"""Список статей
"""
pages = models.db_session.query(
models.Page
).order_by(
models.Page.title.asc()
)
# Сортировка
if order_by['field'] not in ['title', 'created', 'updated']:
raise ValueError
if order_by['order'] not in ['asc', 'desc']:
raise ValueError
field = getattr(models.Page, order_by['field'])
order = getattr(field, order_by['order'])
pages = pages.order_by(
order()
)
pages = lib.getpage(
pages,
page,

View File

@@ -6,6 +6,52 @@ from . import jsonrpc
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()
@jsonrpc.method('user.pages')
def user_pages_list(id: int, page: int) -> list:
"""Список статей пользователя
@@ -61,12 +107,24 @@ def user_pages_count(id: int) -> int:
@jsonrpc.method('users')
def users_list(page: int) -> list:
def users_list(page: int, order_by: dict = {'field': 'name', 'order': 'asc'}) -> list:
"""Показать список пользователей
"""
users = models.db_session.query(
models.User
)
# Сортировка
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()
)
users = lib.getpage(
users,
page,