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

91 lines
2.0 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
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')
2020-08-17 19:57:37 +03:00
def users_list(page: int) -> list:
2020-07-03 11:35:08 +03:00
"""Показать список пользователей
"""
users = models.db_session.query(
models.User
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