Files
myapp-full/myapp/ns_api/page.py
2022-05-03 22:34:52 +03:00

140 lines
3.1 KiB
Python

__author__ = 'RemiZOffAlex'
__email__ = 'remizoffalex@mail.ru'
from . import jsonrpc, login_required
from .. import app, lib, models
@jsonrpc.method('page')
def page_id(id: int) -> dict:
"""Статья
"""
page = models.db_session.query(
models.Page
).filter(
models.Page.id == id
).first()
if page is None:
raise ValueError
result = page.as_dict()
result['user'] = page.user.as_dict()
result['tags'] = []
for tagLink in page.tags:
result['tags'].append(tagLink.tag.as_dict())
return result
@jsonrpc.method('page.add')
@login_required
def page_add(title: str, body: str) -> dict:
"""Добавление новой статьи
"""
newPage = models.Page(
lib.get_user(),
title
)
newPage.body = body
models.db_session.add(newPage)
models.db_session.commit()
result = newPage.as_dict()
result['user'] = newPage.user.as_dict()
result['tags'] = []
return result
@jsonrpc.method('page.destroy')
@login_required
def page_destroy(id: int) -> bool:
"""Полное уничтожение статьи
Аргументы:
id -- ID статьи
"""
page = models.db_session.query(
models.Page
).filter(
models.Page.id == id
).first()
if page is None:
raise ValueError
models.db_session.delete(page)
models.db_session.commit()
return True
@jsonrpc.method('page.update')
@login_required
def page_update(id: int, title: str, text: str) -> dict:
"""Обновить статью
"""
page = models.db_session.query(
models.Page
).filter(
models.Page.id == id
).first()
if page is None:
raise ValueError
page.title = title
page.text = text
result = page.as_dict()
result['user'] = page.user.as_dict()
result['tags'] = []
for tagLink in page.tags:
result['tags'].append(tagLink.tag.as_dict())
return result
@jsonrpc.method('pages')
def pages_list(
page: int = 1,
order_by: dict = {'field': 'title', 'order': 'asc'}
) -> list:
"""Список статей
"""
pages = models.db_session.query(
models.Page
)
# Сортировка
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,
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
@jsonrpc.method('pages.count')
def pages_count() -> int:
"""Общее количество статей
"""
result = models.db_session.query(
models.Page
).count()
return result