main.py 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621
  1. import datetime
  2. import os
  3. from flask import Flask, render_template, request, url_for
  4. from flask_login import login_user, current_user, LoginManager, logout_user, login_required
  5. from flask_wtf import CSRFProtect
  6. from flask_restful import abort
  7. from werkzeug.datastructures import CombinedMultiDict
  8. from werkzeug.utils import redirect
  9. from itsdangerous import URLSafeTimedSerializer, SignatureExpired
  10. from sqlalchemy import or_
  11. from json import loads
  12. from functions import check_password, mail, init_db_default, get_projects_data, get_user_data, save_project_logo, \
  13. overdue_quest_project, save_proof_quest, find_files_answer, file_tree
  14. from forms.edit_profile import EditProfileForm
  15. from forms.login import LoginForm
  16. from forms.find_project import FindProjectForm
  17. from forms.register import RegisterForm
  18. from forms.project import ProjectForm, AddFileProject
  19. from forms.recovery import RecoveryForm, NewPasswordForm
  20. from forms.conf_delete_project import DeleteProjectForm
  21. from forms.task import NewTask, AnswerTask
  22. from data.users import User
  23. from data.quests import Quests
  24. from data.answer import Answer
  25. from data.proof_file import FileProof
  26. from data.files import Files
  27. from data.projects import Projects
  28. from data.staff_projects import StaffProjects
  29. from waitress import serve
  30. from data import db_session
  31. app = Flask(__name__)
  32. with open('incepted.config', 'r', encoding='utf-8') as file:
  33. file = file.read()
  34. file = loads(file)
  35. key = file["encrypt_key"]
  36. app.config['SECRET_KEY'] = key
  37. csrf = CSRFProtect(app)
  38. s = URLSafeTimedSerializer(key)
  39. login_manager = LoginManager()
  40. login_manager.init_app(app)
  41. @app.route('/')
  42. def base():
  43. if not current_user.is_authenticated:
  44. return render_template('main.html', title='Главная')
  45. else:
  46. return redirect('/projects')
  47. @app.route('/project/<int:id_project>/file/<int:id_file>/delete')
  48. def delete_file(id_project, id_file):
  49. if current_user.is_authenticated:
  50. from_path = request.args.get('from') if request.args.get('from') else ''
  51. data_session = db_session.create_session()
  52. current_project = data_session.query(Projects).filter(Projects.id == id_project).first()
  53. current_file = data_session.query(Files).filter(Files.id == id_file).first()
  54. if current_project and current_file:
  55. if current_user.id in map(lambda x: x[0], data_session.query(StaffProjects.user).filter(
  56. StaffProjects.project == current_project.id).all()) or current_user.id == current_project.creator:
  57. current_proof = data_session.query(FileProof).filter(FileProof.file == id_file).all()
  58. os.remove(current_file.path)
  59. data_session.delete(current_file)
  60. if current_proof:
  61. quest = data_session.query(Answer.quest).filter(Answer.id == current_proof[0].answer).first()
  62. for i in current_proof:
  63. data_session.delete(i)
  64. data_session.commit()
  65. if from_path == 'project':
  66. return redirect(f'/project/{current_project.id}')
  67. return redirect(f'/project/{current_project.id}/quest/{quest[0]}')
  68. data_session.commit()
  69. return redirect(f'/project/{current_project.id}')
  70. else:
  71. abort(403)
  72. else:
  73. abort(404)
  74. else:
  75. return redirect('/login')
  76. @app.route('/project/<int:id_project>/quest/<int:id_task>', methods=['GET', 'POST'])
  77. def task_project(id_project, id_task):
  78. if current_user.is_authenticated:
  79. data_session = db_session.create_session()
  80. current_project = data_session.query(Projects).filter(Projects.id == id_project).first()
  81. current_task = data_session.query(Quests).filter(Quests.id == id_task).first()
  82. if current_project and current_task and current_task.project == current_project.id:
  83. form = AnswerTask()
  84. current_answer = data_session.query(Answer).filter(Answer.quest == current_task.id).first()
  85. list_files = None
  86. if form.validate_on_submit():
  87. if form.deadline_date.data and form.deadline_time.data:
  88. deadline = datetime.datetime.combine(form.deadline_date.data, form.deadline_time.data)
  89. else:
  90. deadline = None
  91. current_task.deadline = deadline
  92. if current_answer:
  93. current_answer.text = form.text.data if form.text.data else None
  94. current_answer.date_edit = datetime.datetime.now()
  95. current_task.realized = form.realized.data
  96. data_session.commit()
  97. if form.file.data[0].filename:
  98. files = list(
  99. map(lambda x: save_proof_quest(current_project, x, current_user.id), form.file.data))
  100. for i in files:
  101. if not data_session.query(FileProof).filter(FileProof.answer == current_answer.id,
  102. FileProof.file == i).first():
  103. proof_file = FileProof(
  104. answer=current_answer.id,
  105. file=i
  106. )
  107. data_session.add(proof_file)
  108. data_session.commit()
  109. else:
  110. if form.file.data[0].filename:
  111. files = list(
  112. map(lambda x: save_proof_quest(current_project, x, current_user.id), form.file.data))
  113. else:
  114. files = False
  115. current_task.realized = form.realized.data
  116. current_answer = Answer(
  117. quest=current_task.id,
  118. text=form.text.data if form.text.data else None,
  119. creator=current_user.id,
  120. date_create=datetime.datetime.now(),
  121. date_edit=datetime.datetime.now()
  122. )
  123. data_session.add(current_answer)
  124. data_session.flush()
  125. data_session.refresh(current_answer)
  126. if files:
  127. for i in files:
  128. proof_file = FileProof(
  129. proof=current_answer.id,
  130. file=i
  131. )
  132. data_session.add(proof_file)
  133. data_session.commit()
  134. return redirect(f'/project/{current_project.id}')
  135. if current_answer:
  136. form.text.data = current_answer.text
  137. form.realized.data = current_task.realized
  138. files = data_session.query(FileProof).filter(FileProof.answer == current_answer.id).all()
  139. if files:
  140. list_files = list(map(lambda x: find_files_answer(x.file), files))
  141. if current_task.deadline and current_task.deadline:
  142. form.deadline_date.data = current_task.deadline.date()
  143. form.deadline_time.data = current_task.deadline.time()
  144. return render_template('answer.html', title='Решение', project=current_project, task=current_task,
  145. form=form, list_files=list_files)
  146. else:
  147. abort(404)
  148. else:
  149. return redirect('/login')
  150. @app.route('/project/<int:id_project>/quest/new', methods=['GET', 'POST'])
  151. def new_task_project(id_project):
  152. if current_user.is_authenticated:
  153. data_session = db_session.create_session()
  154. current_project = data_session.query(Projects).filter(Projects.id == id_project).first()
  155. if current_project:
  156. form = NewTask()
  157. if form.validate_on_submit():
  158. if form.deadline_date.data and form.deadline_time.data:
  159. deadline = datetime.datetime.combine(form.deadline_date.data, form.deadline_time.data)
  160. else:
  161. deadline = None
  162. quest = Quests(
  163. project=current_project.id,
  164. creator=current_user.id,
  165. name=form.name.data if form.name.data else None,
  166. description=form.description.data if form.description.data else None,
  167. date_create=datetime.datetime.now(),
  168. deadline=deadline,
  169. realized=False
  170. )
  171. data_session.add(quest)
  172. data_session.commit()
  173. return redirect(f'/project/{str(current_project.id)}')
  174. return render_template('new_task.html', title='Новая задача', form=form, porject=current_project)
  175. else:
  176. abort(404)
  177. else:
  178. return redirect('/login')
  179. @app.route('/project/<int:id_project>/edit', methods=['GET', 'POST'])
  180. def edit_project(id_project):
  181. if current_user.is_authenticated:
  182. data_session = db_session.create_session()
  183. current_project = data_session.query(Projects).filter(Projects.id == id_project).first()
  184. if current_project:
  185. staff = data_session.query(StaffProjects).filter(StaffProjects.project == current_project.id).all()
  186. if current_user.id == current_project.creator or current_user.id in list(map(lambda x: x.user, staff)):
  187. list_users = list(
  188. map(lambda x: get_user_data(x), data_session.query(User).filter(User.id != current_user.id).all()))
  189. staff = list(map(lambda x: get_user_data(x), data_session.query(User).filter(
  190. User.id.in_(list(map(lambda x: x.user, staff)))).all())) if staff else []
  191. form = ProjectForm()
  192. if form.save.data:
  193. new_staff = []
  194. for i in list_users:
  195. if request.form.getlist(f"choose_{i['login']}") and i['id'] != current_user.id:
  196. new_staff.append(i)
  197. if i not in staff:
  198. new_staffer = StaffProjects(
  199. user=i['id'],
  200. project=current_project.id,
  201. role='user',
  202. permission=3
  203. )
  204. data_session.add(new_staffer)
  205. data_session.commit()
  206. if sorted(new_staff, key=lambda x: x['id']) != sorted(staff, key=lambda x: x['id']):
  207. for i in staff:
  208. if i not in new_staff:
  209. data_session.delete(data_session.query(StaffProjects).filter(
  210. StaffProjects.user == i['id'], StaffProjects.project == current_project.id).first())
  211. data_session.commit()
  212. if form.logo.data:
  213. current_project.photo = save_project_logo(form.logo.data)
  214. data_session.commit()
  215. current_project.name = form.name.data
  216. current_project.description = form.description.data
  217. data_session.commit()
  218. return redirect(f'/project/{current_project.id}')
  219. if form.del_photo.data:
  220. os.remove(current_project.photo)
  221. current_project.photo = 'static/images/none_project.png'
  222. data_session.commit()
  223. return redirect(f'/project/{current_project.id}/edit')
  224. form.name.data = current_project.name
  225. form.description.data = current_project.description
  226. return render_template('edit_project.html', title='Изменение проекта', form=form, list_users=list_users,
  227. staff=staff, project=current_project)
  228. else:
  229. abort(403)
  230. else:
  231. abort(404)
  232. else:
  233. return redirect('/login')
  234. @app.route('/project/<int:id_project>', methods=['POST', 'GET'])
  235. def project(id_project):
  236. if current_user.is_authenticated:
  237. data_session = db_session.create_session()
  238. current_project = data_session.query(Projects).filter(Projects.id == id_project).first()
  239. if current_project:
  240. staff = data_session.query(StaffProjects).filter(StaffProjects.project == current_project.id).all()
  241. if current_user.id == current_project.creator or current_user.id in list(map(lambda x: x.user, staff)):
  242. staff = list(map(lambda x: get_user_data(x), data_session.query(User).filter(
  243. User.id.in_(list(map(lambda x: x.user, staff)))).all())) if staff else []
  244. quests = data_session.query(Quests).filter(Quests.project == current_project.id).all()
  245. if quests:
  246. quests_sort = sorted(list(filter(lambda x: x.deadline is not None, quests)),
  247. key=lambda x: (x.realized, x.deadline))
  248. quests = list(filter(lambda x: x.realized == 0, quests_sort)) + list(
  249. filter(lambda x: x.deadline is None, quests)) + list(
  250. filter(lambda x: x.realized == 1, quests_sort))
  251. quests = list(map(lambda x: overdue_quest_project(x), quests))
  252. files_list = file_tree(f'static/app_files/all_projects/{current_project.id}')
  253. form_file = AddFileProject()
  254. if form_file.validate_on_submit():
  255. if form_file.file.data[0].filename:
  256. files = list(
  257. map(lambda x: save_proof_quest(current_project, x, current_user.id), form_file.file.data))
  258. return render_template('project.html',
  259. project=current_project,
  260. title=current_project.name,
  261. staff=staff,
  262. quests=quests,
  263. file_tree=files_list,
  264. form_file=form_file)
  265. else:
  266. abort(403)
  267. else:
  268. abort(404)
  269. else:
  270. return redirect('/login')
  271. @app.route('/recovery/confirmation/<token>', methods=['GET', 'POST'])
  272. def conf_recovery(token):
  273. try:
  274. user_email = s.loads(token, max_age=86400)
  275. data_session = db_session.create_session()
  276. user = data_session.query(User).filter(User.email == user_email).first()
  277. if user:
  278. form = NewPasswordForm()
  279. if form.validate_on_submit():
  280. if form.password.data != form.repeat_password.data:
  281. return render_template('recovery.html', title='Восстановление', form=form, recovery=0,
  282. message='Пароли не совпадают')
  283. status_password = check_password(form.password.data)
  284. if status_password != 'OK':
  285. return render_template('recovery.html', title='Восстановление', form=form, recovery=0,
  286. message=str(status_password))
  287. user.set_password(form.password.data)
  288. data_session.commit()
  289. mail(f'Для аккаунта {user.login}, успешно был обновлен пароль', user.email,
  290. 'Изменение пароля')
  291. return redirect('/login?message=Пароль обновлен')
  292. return render_template('recovery.html', title='Восстановление', form=form, recovery=0, message='')
  293. else:
  294. return redirect('/login?message=Пользователь не найден&danger=True')
  295. except SignatureExpired:
  296. return redirect('/login?message=Срок действия ссылки истек&danger=True')
  297. @app.route('/recovery', methods=['GET', 'POST'])
  298. def recovery():
  299. if not current_user.is_authenticated:
  300. form = RecoveryForm()
  301. if form.validate_on_submit():
  302. token = s.dumps(form.email.data)
  303. link_conf = url_for('conf_recovery', token=token, _external=True)
  304. mail(f'Для сбросы пароля пройдите по ссылке: {link_conf}', form.email.data,
  305. 'Восстановление доступа')
  306. return redirect('/login?message=Мы выслали ссылку для сброса вам на почту')
  307. return render_template('recovery.html', title='Восстановление пароля', form=form, recovery=True, message='')
  308. else:
  309. return redirect('/')
  310. @app.route('/project/<int:id_project>/delete', methods=['GET', 'POST'])
  311. def delete_project(id_project):
  312. if current_user.is_authenticated:
  313. data_session = db_session.create_session()
  314. project_del = data_session.query(Projects).filter(Projects.id == id_project).first()
  315. if project_del:
  316. if project_del.creator == current_user.id:
  317. form = DeleteProjectForm()
  318. if form.validate_on_submit():
  319. if form.conf.data != f'delete/{project_del.name}':
  320. return render_template('delete_project.html', title='Удаление проекта', form=form,
  321. project=project_del,
  322. message='Вы не правильно ввели фразу')
  323. staff = data_session.query(StaffProjects).filter(StaffProjects.project == id_project).all()
  324. for i in staff:
  325. data_session.delete(i)
  326. if 'none_project' not in project_del.photo:
  327. os.remove(project_del.photo)
  328. shutil.rmtree(f'static/app_files/all_projects/{str(project_del.id)}')
  329. data_session.delete(project_del)
  330. data_session.commit()
  331. return redirect('/projects')
  332. return render_template('delete_project.html', title='Удаление проекта', form=form, project=project_del,
  333. message='')
  334. else:
  335. abort(403)
  336. else:
  337. abort(404)
  338. else:
  339. return redirect('/login')
  340. @app.route('/user/<string:_login>', methods=['GET', 'POST'])
  341. def user_view(_login):
  342. if current_user.is_authenticated:
  343. data_session = db_session.create_session()
  344. user = data_session.query(User).filter(User.login == _login).first()
  345. if user:
  346. current_projects = data_session.query(Projects).filter(or_(Projects.creator == user.id, Projects.id.in_(
  347. list(map(lambda x: x[0], data_session.query(
  348. StaffProjects.project).filter(
  349. StaffProjects.user == user.id).all()))))).all()
  350. resp = list(map(lambda x: get_projects_data(x), current_projects))
  351. return render_template('user_view.html', title=user.name + ' ' + user.surname, user=user,
  352. list_projects=resp)
  353. else:
  354. abort(404)
  355. else:
  356. return redirect('/login')
  357. @app.route('/projects/new', methods=['GET', 'POST'])
  358. def new_project():
  359. if current_user.is_authenticated:
  360. form = ProjectForm()
  361. data_session = db_session.create_session()
  362. list_users = list(
  363. map(lambda x: get_user_data(x), data_session.query(User).filter(User.id != current_user.id).all()))
  364. if form.validate_on_submit():
  365. currnet_project = Projects(
  366. name=form.name.data,
  367. description=form.description.data,
  368. date_create=datetime.datetime.now(),
  369. creator=current_user.id
  370. )
  371. currnet_project.photo = save_project_logo(
  372. form.logo.data) if form.logo.data else 'static/images/none_project.png'
  373. data_session.add(currnet_project)
  374. data_session.flush()
  375. data_session.refresh(currnet_project)
  376. for i in list_users:
  377. if request.form.getlist(f"choose_{i['login']}") and i['id'] != current_user.id:
  378. new_staffer = StaffProjects(
  379. user=i['id'],
  380. project=currnet_project.id,
  381. role='user',
  382. permission=3
  383. )
  384. data_session.add(new_staffer)
  385. data_session.commit()
  386. os.mkdir(f'static/app_files/all_projects/{str(currnet_project.id)}')
  387. return redirect('/projects')
  388. return render_template('new_project.html', title='Новый проект', form=form, list_users=list_users)
  389. else:
  390. return redirect('/login')
  391. @app.route('/projects', methods=['GET', 'POST'])
  392. def projects():
  393. if current_user.is_authenticated:
  394. find = False
  395. form = FindProjectForm()
  396. data_session = db_session.create_session()
  397. resp = []
  398. current_projects = \
  399. data_session.query(Projects).filter(or_(Projects.creator == current_user.id,
  400. Projects.id.in_(
  401. list(map(lambda x: x[0],
  402. data_session.query(
  403. StaffProjects.project).filter(
  404. StaffProjects.user
  405. == current_user.id).all()))))).all()
  406. if form.validate_on_submit():
  407. new_resp = []
  408. for i in range(len(current_projects)):
  409. if str(form.project.data).lower().strip() in str(current_projects[i].name).lower().strip():
  410. new_resp.append(current_projects[i])
  411. current_projects = new_resp
  412. find = True
  413. resp = list(map(lambda x: get_projects_data(x), current_projects))
  414. return render_template('projects.html', title='Проекты', list_projects=resp, form=form, find=find)
  415. else:
  416. return redirect('/login')
  417. @app.route('/profile', methods=['GET', 'POST'])
  418. def profile():
  419. if current_user.is_authenticated:
  420. form = EditProfileForm(
  421. CombinedMultiDict((request.files, request.form)),
  422. email=current_user.email,
  423. name=current_user.name,
  424. surname=current_user.surname,
  425. about=current_user.about,
  426. birthday=current_user.birthday
  427. )
  428. if form.del_photo.data:
  429. data_session = db_session.create_session()
  430. user = data_session.query(User).filter(User.id == current_user.id).first()
  431. if not user:
  432. return render_template('profile.html', title='Профиль', form=form,
  433. message='Ошибка, пользователь ненайден')
  434. os.remove(current_user.photo)
  435. user.photo = 'static/images/none_logo.png'
  436. data_session.commit()
  437. if form.validate_on_submit():
  438. data_session = db_session.create_session()
  439. user = data_session.query(User).filter(User.id == current_user.id).first()
  440. if not user:
  441. return render_template('profile.html', title='Профиль', form=form,
  442. message='Ошибка, пользователь ненайден')
  443. if form.email.data != current_user.email:
  444. token = s.dumps(form.email.data)
  445. link_conf = url_for('confirmation', token=token, _external=True)
  446. mail(f'Для изменения почты пройдите по ссылке: {link_conf}', form.email.data,
  447. 'Изменение почты')
  448. user.activated = False
  449. user.email = form.email.data
  450. if form.photo.data:
  451. with open(f'static/app_files/user_logo/{current_user.login}.png', 'wb') as file:
  452. form.photo.data.save(file)
  453. user.photo = f'static/app_files/user_logo/{current_user.login}.png'
  454. user.name = form.name.data
  455. user.surname = form.surname.data
  456. user.about = form.about.data
  457. user.birthday = form.birthday.data
  458. data_session.commit()
  459. return redirect('/profile')
  460. return render_template('profile.html', title='Профиль', form=form, message='')
  461. else:
  462. return redirect('/login')
  463. @login_manager.user_loader
  464. def load_user(user_id):
  465. db_sess = db_session.create_session()
  466. return db_sess.query(User).get(user_id)
  467. @app.route('/login', methods=['GET', 'POST'])
  468. def login():
  469. if not current_user.is_authenticated:
  470. message = request.args.get('message') if request.args.get('message') else ''
  471. danger = request.args.get('danger') if request.args.get('danger') else False
  472. form = LoginForm()
  473. if form.validate_on_submit():
  474. data_session = db_session.create_session()
  475. user = data_session.query(User).filter(User.email == form.login.data).first()
  476. if not user:
  477. user = data_session.query(User).filter(User.login == form.login.data).first()
  478. if user and user.check_password(form.password.data):
  479. if user.activated:
  480. login_user(user, remember=form.remember_me.data)
  481. return redirect('/projects')
  482. else:
  483. return render_template('login.html',
  484. message="Ваша почта не подтверждена",
  485. danger=True,
  486. form=form)
  487. return render_template('login.html',
  488. message="Неправильный логин или пароль",
  489. danger=True,
  490. form=form)
  491. return render_template('login.html', title='Авторизация', form=form, message=message,
  492. danger=danger)
  493. else:
  494. return redirect('/projects')
  495. @app.route('/logout')
  496. @login_required
  497. def logout():
  498. logout_user()
  499. return redirect("/")
  500. @app.route('/register', methods=['GET', 'POST'])
  501. def register():
  502. if not current_user.is_authenticated:
  503. form = RegisterForm()
  504. if form.validate_on_submit():
  505. data_session = db_session.create_session()
  506. if data_session.query(User).filter(User.login == form.login.data).first():
  507. return render_template('register.html', form=form, message="Такой пользователь уже есть",
  508. title='Регистрация')
  509. if data_session.query(User).filter(User.email == form.email.data).first():
  510. return render_template('register.html', form=form, message="Такая почта уже есть", title='Регистрация')
  511. status_password = check_password(form.password.data)
  512. if status_password != 'OK':
  513. return render_template('register.html', form=form, message=status_password, title='Регистрация')
  514. user = User(
  515. email=form.email.data,
  516. name=form.name.data,
  517. login=form.login.data,
  518. activity=datetime.datetime.now(),
  519. data_reg=datetime.date.today(),
  520. photo='static/images/none_logo.png',
  521. role=1
  522. )
  523. user.set_password(form.password.data)
  524. data_session.add(user)
  525. data_session.commit()
  526. token = s.dumps(form.email.data)
  527. link_conf = url_for('confirmation', token=token, _external=True)
  528. mail(f'Для завершения регистрации пройдите по ссылке: {link_conf}', form.email.data,
  529. 'Подтверждение регистрации')
  530. return redirect('/login?message=Мы выслали ссылку для подтверждения почты')
  531. return render_template('register.html', form=form, message='', title='Регистрация')
  532. else:
  533. return redirect('/projects')
  534. @app.route('/confirmation/<token>')
  535. def confirmation(token):
  536. try:
  537. user_email = s.loads(token, max_age=86400)
  538. data_session = db_session.create_session()
  539. user = data_session.query(User).filter(User.email == user_email).first()
  540. if user:
  541. user.activated = True
  542. data_session.commit()
  543. return redirect('/login?message=Почта успешно подтверждена')
  544. else:
  545. return redirect('/login?message=Пользователь не найден&danger=True')
  546. except SignatureExpired:
  547. data_session = db_session.create_session()
  548. users = data_session.query(User).filter(
  549. User.activated == 0 and User.activated < datetime.datetime.now() - datetime.timedelta(days=1)).all()
  550. if users:
  551. list(map(lambda x: data_session.delete(x), users))
  552. data_session.commit()
  553. return redirect('/login?message=Срок действия ссылки истек, данные удалены&danger=True')
  554. @app.errorhandler(500)
  555. def internal_server_error(error):
  556. return render_template('page_error.html', title='Ошибка сервера', error='500', message='Технические шоколадки')
  557. @app.errorhandler(404)
  558. def page_not_found(error):
  559. return render_template('page_error.html', title='Страница не найдена', error='404', message='Страница не найдена')
  560. @app.errorhandler(403)
  561. def access_error(error):
  562. return render_template('page_error.html', title='Ошибка доступа', error='403', message='Доступ сюда запрещен')
  563. def main():
  564. db_path = 'db/incepted.db'
  565. db = os.path.exists(db_path)
  566. db_session.global_init(db_path)
  567. if not db:
  568. init_db_default()
  569. serve(app, host='0.0.0.0', port=5000)
  570. if __name__ == '__main__':
  571. main()