inter_wiki_plus.py 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. from .tool.func import *
  2. def inter_wiki_plus_2(conn, tools, name):
  3. curs = conn.cursor()
  4. if flask.request.method == 'POST':
  5. if tools == 'plus_inter_wiki':
  6. if name:
  7. curs.execute(db_change("delete from inter where title = ?"), [name])
  8. curs.execute(db_change('insert into inter (title, link, icon) values (?, ?, ?)'), [
  9. flask.request.form.get('title', 'test'),
  10. flask.request.form.get('link', 'test'),
  11. flask.request.form.get('icon', '')
  12. ])
  13. admin_check(None, 'inter_wiki_plus')
  14. elif tools == 'plus_edit_filter':
  15. if admin_check(1, 'edit_filter edit') != 1:
  16. return re_error('/error/3')
  17. if flask.request.form.get('second', '0') == '0':
  18. end = 'X'
  19. else:
  20. end = flask.request.form.get('second', 'X')
  21. try:
  22. re.compile(flask.request.form.get('content', 'test'))
  23. curs.execute(db_change("delete from filter where name = ?"), [name])
  24. curs.execute(db_change("insert into filter (name, regex, sub) values (?, ?, ?)"), [
  25. name,
  26. flask.request.form.get('content', 'test'),
  27. end
  28. ])
  29. except:
  30. return re_error('/error/23')
  31. else:
  32. plus_d = ''
  33. if tools == 'plus_name_filter':
  34. try:
  35. re.compile(flask.request.form.get('title', 'test'))
  36. except:
  37. return re_error('/error/23')
  38. admin_check(None, 'name_filter edit')
  39. type_d = 'name'
  40. elif tools == 'plus_file_filter':
  41. try:
  42. re.compile(flask.request.form.get('title', 'test'))
  43. except:
  44. return re_error('/error/23')
  45. admin_check(None, 'file_filter edit')
  46. type_d = 'file'
  47. elif tools == 'plus_email_filter':
  48. admin_check(None, 'email_filter edit')
  49. type_d = 'email'
  50. elif tools == 'plus_image_license':
  51. admin_check(None, 'image_license edit')
  52. type_d = 'image_license'
  53. elif tools == 'plus_extension_filter':
  54. admin_check(None, 'extension_filter edit')
  55. type_d = 'extension'
  56. else:
  57. admin_check(None, 'edit_top edit')
  58. type_d = 'edit_top'
  59. plus_d = flask.request.form.get('markup', 'test')
  60. if name:
  61. curs.execute(db_change("delete from html_filter where html = ? and kind = ?"), [
  62. name,
  63. type_d
  64. ])
  65. curs.execute(db_change('insert into html_filter (html, kind, plus) values (?, ?, ?)'), [
  66. flask.request.form.get('title', 'test'),
  67. type_d,
  68. plus_d
  69. ])
  70. conn.commit()
  71. return redirect('/' + re.sub(r'^plus_', '', tools))
  72. else:
  73. get_sub = 0
  74. if admin_check(1) != 1:
  75. stat = 'disabled'
  76. else:
  77. stat = ''
  78. if tools == 'plus_inter_wiki':
  79. if name:
  80. curs.execute(db_change("select title, link, icon from inter where title = ?"), [name])
  81. exist = curs.fetchall()
  82. if exist:
  83. value = exist[0]
  84. else:
  85. value = ['', '', '']
  86. else:
  87. value = ['', '', '']
  88. title = load_lang('interwiki_add')
  89. form_data = '''
  90. ''' + load_lang('name') + '''
  91. <hr class="main_hr">
  92. <input value="''' + html.escape(value[0]) + '''" type="text" name="title">
  93. <hr class="main_hr">
  94. ''' + load_lang('link') + '''
  95. <hr class="main_hr">
  96. <input value="''' + html.escape(value[1]) + '''" type="text" name="link">
  97. <hr class="main_hr">
  98. ''' + load_lang('icon') + ''' (HTML)
  99. <hr class="main_hr">
  100. <input value="''' + html.escape(value[2]) + '''" type="text" name="icon">
  101. '''
  102. elif tools == 'plus_edit_filter':
  103. curs.execute(db_change("select regex, sub from filter where name = ?"), [name])
  104. exist = curs.fetchall()
  105. if exist:
  106. textarea = exist[0][0]
  107. if exist[0][1] == 'X':
  108. time_check = 'checked="checked"'
  109. time_data = ''
  110. else:
  111. time_check = ''
  112. time_data = exist[0][1]
  113. else:
  114. textarea = ''
  115. time_check = ''
  116. time_data = ''
  117. insert_data = ''
  118. if stat == '':
  119. t_data = [
  120. ['86400', load_lang('1_day')],
  121. ['432000‬', load_lang('5_day')],
  122. ['2592000', load_lang('30_day')],
  123. ['15552000', load_lang('180_day')],
  124. ['31104000‬', load_lang('360_day')],
  125. ['0', load_lang('limitless')]
  126. ]
  127. for i in t_data:
  128. insert_data += '<a href="javascript:insert_v(\'second\', \'' + i[0] + '\')">(' + i[1] + ')</a> '
  129. title = load_lang('edit_filter_add')
  130. form_data = '''
  131. <script>function insert_v(name, data) { document.getElementById(name).value = data; }</script>''' + insert_data + '''
  132. <hr class="main_hr">
  133. <input ''' + stat + ''' placeholder="''' + load_lang('second') + '''" id="second" name="second" type="text" value="''' + html.escape(time_data) + '''">
  134. <hr class="main_hr">
  135. <input ''' + stat + ''' placeholder="''' + load_lang('regex') + '''" name="content" value="''' + html.escape(textarea) + '''" type="text">
  136. '''
  137. elif tools == 'plus_name_filter':
  138. title = load_lang('id_filter_add')
  139. form_data = '' + \
  140. load_lang('regex') + \
  141. '<hr class="main_hr">' + \
  142. '<input value="' + html.escape(name if name else '') + '" type="text" name="title">' + \
  143. ''
  144. elif tools == 'plus_file_filter':
  145. title = load_lang('file_filter_add')
  146. form_data = '' + \
  147. load_lang('regex') + \
  148. '<hr class="main_hr">' + \
  149. '<input value="' + html.escape(name if name else '') + '" type="text" name="title">' + \
  150. ''
  151. elif tools == 'plus_email_filter':
  152. title = load_lang('email_filter_add')
  153. form_data = '' + \
  154. load_lang('email') + \
  155. '<hr class="main_hr">' + \
  156. '<input value="' + html.escape(name if name else '') + '" type="text" name="title">' + \
  157. ''
  158. elif tools == 'plus_image_license':
  159. title = load_lang('image_license_add')
  160. form_data = '' + \
  161. load_lang('license') + \
  162. '<hr class="main_hr">' + \
  163. '<input value="' + html.escape(name if name else '') + '" type="text" name="title">' + \
  164. ''
  165. elif tools == 'plus_extension_filter':
  166. title = load_lang('extension_filter_add')
  167. form_data = '' + \
  168. load_lang('extension') + \
  169. '<hr class="main_hr">' + \
  170. '<input value="' + html.escape(name if name else '') + '" type="text" name="title">' + \
  171. ''
  172. else:
  173. title = load_lang('edit_tool_add')
  174. if name:
  175. curs.execute(db_change("select plus from html_filter where html = ? and kind = 'edit_top'"), [name])
  176. exist = curs.fetchall()
  177. if exist:
  178. value = exist[0][0]
  179. else:
  180. value = ''
  181. else:
  182. value = ''
  183. form_data = '''
  184. ''' + load_lang('title') + '''
  185. <hr class="main_hr">
  186. <input value="''' + html.escape(name if name else '') + '''" type="text" name="title">
  187. <hr class="main_hr">
  188. ''' + load_lang('markup') + '''
  189. <hr class="main_hr">
  190. <input value="''' + html.escape(value) + '''" type="text" name="markup">
  191. '''
  192. return easy_minify(flask.render_template(skin_check(),
  193. imp = [title, wiki_set(), custom(), other2([get_sub, 0])],
  194. data = '''
  195. <form method="post">
  196. ''' + form_data + '''
  197. <hr class="main_hr">
  198. <button ''' + stat + ''' type="submit">''' + load_lang('add') + '''</button>
  199. </form>
  200. ''',
  201. menu = [[re.sub('^plus_', '', tools), load_lang('return')]]
  202. ))