topic_tool_acl.py 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. from .tool.func import *
  2. async def topic_tool_acl(topic_num = 1):
  3. with get_db_connect() as conn:
  4. curs = conn.cursor()
  5. if await acl_check(tool = 'toron_auth') == 1:
  6. return await re_error(conn, 3)
  7. ip = ip_check()
  8. time = get_time()
  9. topic_num = str(topic_num)
  10. curs.execute(db_change("select title, sub from rd where code = ?"), [topic_num])
  11. rd_d = curs.fetchall()
  12. if not rd_d:
  13. return redirect(conn, '/')
  14. if flask.request.method == 'POST':
  15. await acl_check(tool = 'toron_auth', memo = 'topic_acl_set (code ' + topic_num + ')')
  16. curs.execute(db_change("select id from topic where code = ? order by id + 0 desc limit 1"), [topic_num])
  17. topic_check = curs.fetchall()
  18. if topic_check:
  19. acl_data = flask.request.form.get('acl', '')
  20. acl_data_view = flask.request.form.get('acl_view', '')
  21. curs.execute(db_change("update rd set acl = ? where code = ?"), [
  22. acl_data,
  23. topic_num
  24. ])
  25. curs.execute(db_change("select set_data from topic_set where thread_code = ? and set_name = 'thread_view_acl'"), [topic_num])
  26. db_data = curs.fetchall()
  27. if db_data:
  28. curs.execute(db_change("update topic_set set set_data = ? where thread_code = ?"), [
  29. acl_data_view,
  30. topic_num
  31. ])
  32. else:
  33. curs.execute(db_change("insert into topic_set (thread_code, set_name, set_id, set_data) values (?, 'thread_view_acl', '1', ?)"), [
  34. topic_num,
  35. acl_data_view
  36. ])
  37. do_add_thread(conn,
  38. topic_num,
  39. get_lang(conn, 'acl_thread_change') + ' : ' + acl_data,
  40. '1'
  41. )
  42. do_reload_recent_thread(conn,
  43. topic_num,
  44. time
  45. )
  46. return redirect(conn, '/thread/' + topic_num)
  47. else:
  48. acl_list = await get_acl_list()
  49. acl_html_list = ''
  50. acl_html_list_view = ''
  51. curs.execute(db_change("select acl from rd where code = ?"), [topic_num])
  52. topic_acl_get = curs.fetchall()
  53. for data_list in acl_list:
  54. if topic_acl_get and topic_acl_get[0][0] == data_list:
  55. check = 'selected="selected"'
  56. else:
  57. check = ''
  58. acl_html_list += '<option value="' + data_list + '" ' + check + '>' + (data_list if data_list != '' else 'normal') + '</option>'
  59. curs.execute(db_change("select set_data from topic_set where thread_code = ? and set_name = 'thread_view_acl'"), [topic_num])
  60. db_data = curs.fetchall()
  61. for data_list in acl_list:
  62. if db_data and db_data[0][0] == data_list:
  63. check = 'selected="selected"'
  64. else:
  65. check = ''
  66. acl_html_list_view += '<option value="' + data_list + '" ' + check + '>' + (data_list if data_list != '' else 'normal') + '</option>'
  67. return easy_minify(conn, flask.render_template(skin_check(conn),
  68. imp = [get_lang(conn, 'topic_acl_setting'), wiki_set(conn), await wiki_custom(conn), wiki_css([0, 0])],
  69. data = '''
  70. <form method="post">
  71. <a href="/acl/TEST#exp">(''' + get_lang(conn, 'reference') + ''')</a>
  72. <h2>''' + get_lang(conn, 'thread_acl') + '''</h2>
  73. <select name="acl">
  74. ''' + acl_html_list + '''
  75. </select>
  76. <h2>''' + get_lang(conn, 'view_acl') + ''' (''' + get_lang(conn, 'beta') + ''')</h2>
  77. <select name="acl_view">
  78. ''' + acl_html_list_view + '''
  79. </select>
  80. <hr class="main_hr">
  81. <button type="submit">''' + get_lang(conn, 'save') + '''</button>
  82. </form>
  83. ''',
  84. menu = [['thread/' + topic_num + '/tool', get_lang(conn, 'return')]]
  85. ))