Добавлена сортировка для статей и пользователей
This commit is contained in:
@@ -91,14 +91,24 @@ def page_update(id: int, title: str, text: str) -> dict:
|
|||||||
|
|
||||||
|
|
||||||
@jsonrpc.method('pages')
|
@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(
|
pages = models.db_session.query(
|
||||||
models.Page
|
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 = lib.getpage(
|
||||||
pages,
|
pages,
|
||||||
page,
|
page,
|
||||||
|
|||||||
@@ -6,6 +6,52 @@ from . import jsonrpc
|
|||||||
from .. import app, lib, models
|
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')
|
@jsonrpc.method('user.pages')
|
||||||
def user_pages_list(id: int, page: int) -> list:
|
def user_pages_list(id: int, page: int) -> list:
|
||||||
"""Список статей пользователя
|
"""Список статей пользователя
|
||||||
@@ -61,12 +107,24 @@ def user_pages_count(id: int) -> int:
|
|||||||
|
|
||||||
|
|
||||||
@jsonrpc.method('users')
|
@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(
|
users = models.db_session.query(
|
||||||
models.User
|
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 = lib.getpage(
|
||||||
users,
|
users,
|
||||||
page,
|
page,
|
||||||
|
|||||||
Reference in New Issue
Block a user