2019-10-27 19:40:03 +03:00
|
|
|
__author__ = 'RemiZOffAlex'
|
|
|
|
|
__email__ = 'remizoffalex@mail.ru'
|
|
|
|
|
__url__ = 'https://remizoffalex.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')
|
|
|
|
|
def page_id(id: int)->dict:
|
|
|
|
|
"""Статья
|
2020-02-08 05:04:27 +03:00
|
|
|
"""
|
|
|
|
|
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
|
2019-10-27 19:40:03 +03:00
|
|
|
|
|
|
|
|
|
2020-07-03 11:35:08 +03:00
|
|
|
@jsonrpc.method('page.update')
|
2019-10-27 19:40:03 +03:00
|
|
|
@login_required
|
2020-07-03 11:35:08 +03:00
|
|
|
def page_update(title: str, text: str)->dict:
|
|
|
|
|
"""Обновить статью
|
2019-10-27 19:40:03 +03:00
|
|
|
"""
|
2020-02-08 05:04:27 +03:00
|
|
|
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
|
|
|
|
|
|
|
|
|
|
|
2020-07-03 11:35:08 +03:00
|
|
|
@jsonrpc.method('page.add')
|
2020-02-08 05:04:27 +03:00
|
|
|
@login_required
|
2020-07-03 11:35:08 +03:00
|
|
|
def page_add(title: str, body: str)->dict:
|
|
|
|
|
"""Добавление новой статьи
|
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-07-03 11:35:08 +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(
|
|
|
|
|
models.Page.id==id
|
|
|
|
|
).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
|
|
|
|
|
|
|
|
|
2020-07-03 11:35:08 +03:00
|
|
|
@jsonrpc.method('pages')
|
|
|
|
|
def pages_list(page: int)->list:
|
|
|
|
|
"""Список статей
|
2020-02-08 05:04:27 +03:00
|
|
|
"""
|
|
|
|
|
pages = models.db_session.query(
|
|
|
|
|
models.Page
|
|
|
|
|
).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
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@jsonrpc.method('pages.count')
|
2020-07-03 11:35:08 +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
|