2
0

bbs_w_pinned.py 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. from .tool.func import *
  2. from .go_api_bbs_w import api_bbs_w
  3. async def bbs_w_pinned(bbs_num = '', post_num = ''):
  4. with get_db_connect() as conn:
  5. curs = conn.cursor()
  6. curs.execute(db_change('select set_data from bbs_set where set_id = ? and set_name = "bbs_name"'), [bbs_num])
  7. db_data = curs.fetchall()
  8. if not db_data:
  9. return redirect(conn, '/bbs/main')
  10. bbs_name = db_data[0][0]
  11. bbs_num_str = str(bbs_num)
  12. post_num_str = str(post_num)
  13. if await acl_check('', 'bbs_auth', '', '') == 1:
  14. return redirect(conn, '/bbs/in/' + bbs_num_str)
  15. temp_dict = await api_bbs_w(bbs_num_str + '-' + post_num_str)
  16. if not 'user_id' in temp_dict:
  17. return redirect(conn, '/bbs/main')
  18. if flask.request.method == 'POST':
  19. curs.execute(db_change('select set_data from bbs_data where set_code = ? and set_id = ? and set_name = "pinned"'), [post_num_str, bbs_num_str])
  20. if not curs.fetchall():
  21. curs.execute(db_change("insert into bbs_data (set_name, set_code, set_id, set_data) values ('pinned', ?, ?, ?)"), [post_num_str, bbs_num_str, get_time()])
  22. else:
  23. curs.execute(db_change('delete from bbs_data where set_code = ? and set_id = ? and set_name = "pinned"'), [post_num_str, bbs_num_str])
  24. return redirect(conn, '/bbs/in/' + bbs_num_str)
  25. else:
  26. curs.execute(db_change('select set_data from bbs_data where set_code = ? and set_id = ? and set_name = "pinned"'), [post_num_str, bbs_num_str])
  27. pinned = await get_lang('pinned') if not curs.fetchall() else await get_lang('pinned_release')
  28. return await render_template(
  29. await get_lang('bbs_post_pinned'),
  30. await render_simple_set('''
  31. <form method="post">
  32. <button class="__ON_BUTTON__" type="submit">''' + pinned + '''</button>
  33. </form>
  34. '''),
  35. '(' + bbs_name + ')' + ' (' + post_num_str + ')',
  36. [['bbs/w/' + bbs_num_str + '/' + post_num_str, await get_lang('return')]]
  37. )