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

137 lines
3.1 KiB
Python
Raw Normal View History

2019-10-27 19:40:03 +03:00
__author__ = 'RemiZOffAlex'
__email__ = 'remizoffalex@mail.ru'
from . import jsonrpc, login_required
2020-02-08 05:04:27 +03:00
from .. import app, lib, models
2020-07-03 11:35:08 +03:00
@jsonrpc.method('page')
2020-08-17 19:57:37 +03:00
def page_id(id: int) -> dict:
2020-07-03 11:35:08 +03:00
"""Статья
2020-02-08 05:04:27 +03:00
"""
page = models.db_session.query(
models.Page
).filter(
2020-08-17 19:57:37 +03:00
models.Page.id == id
2020-02-08 05:04:27 +03:00
).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
2019-10-27 19:40:03 +03:00
2020-07-03 11:35:08 +03:00
@jsonrpc.method('page.add')
2020-02-08 05:04:27 +03:00
@login_required
2020-08-17 19:57:37 +03:00
def page_add(title: str, body: str) -> dict:
2020-07-03 11:35:08 +03:00
"""Добавление новой статьи
2020-02-08 05:04:27 +03:00
"""
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
2020-07-03 11:35:08 +03:00
@jsonrpc.method('page.destroy')
2020-02-08 05:04:27 +03:00
@login_required
2020-08-17 19:57:37 +03:00
def page_destroy(id: int) -> bool:
2020-02-08 05:04:27 +03:00
"""Полное уничтожение статьи
Аргументы:
id -- ID статьи
"""
page = models.db_session.query(
models.Page
).filter(
2020-08-17 19:57:37 +03:00
models.Page.id == id
2020-02-08 05:04:27 +03:00
).first()
if page is None:
raise ValueError
models.db_session.delete(page)
models.db_session.commit()
2020-07-03 11:35:08 +03:00
return True
2020-02-08 05:04:27 +03:00
@jsonrpc.method('page.update')
@login_required
2020-08-17 19:57:37 +03:00
def page_update(id: int, title: str, text: str) -> dict:
"""Обновить статью
"""
page = models.db_session.query(
models.Page
).filter(
2020-08-17 19:57:37 +03:00
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
2020-07-03 11:35:08 +03:00
@jsonrpc.method('pages')
def pages_list(page: int, order_by: dict = {'field': 'title', 'order': 'asc'}) -> list:
2020-07-03 11:35:08 +03:00
"""Список статей
2020-02-08 05:04:27 +03:00
"""
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()
)
2020-02-08 05:04:27 +03:00
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')
2020-08-17 19:57:37 +03:00
def pages_count() -> int:
2020-02-08 05:04:27 +03:00
"""Общее количество статей
"""
result = models.db_session.query(
models.Page
).count()
2019-10-27 19:40:03 +03:00
return result