give_user_ban.py 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. from .tool.func import *
  2. def give_user_ban_2(conn, name):
  3. curs = conn.cursor()
  4. band = flask.request.args.get('type', '')
  5. ip = ip_check()
  6. if ban_check(ip = ip, tool = 'login') == 1:
  7. if ip_or_user(ip) == 1 or admin_check('all', None, ip) == 0:
  8. return re_error('/ban')
  9. else:
  10. if admin_check(1, None, ip) !=1:
  11. return re_error('/error/3')
  12. if flask.request.method == 'POST':
  13. end = flask.request.form.get('second', '0')
  14. end = end if end else '0'
  15. name = name if name else flask.request.form.get('name', 'test')
  16. regex_get = flask.request.form.get('regex', None)
  17. login = flask.request.form.get('login', '')
  18. why = flask.request.form.get('why', '')
  19. if regex_get or band != '':
  20. type_d = 'regex' if regex_get else band
  21. try:
  22. re.compile(name)
  23. except:
  24. return re_error('/error/23')
  25. else:
  26. type_d = None
  27. if type_d:
  28. if admin_check(None, 'ban' + (' ' + type_d if type_d else '') + ' (' + name + ')') != 1:
  29. return re_error('/error/3')
  30. else:
  31. if name == ip:
  32. if admin_check('all', 'ban (' + name + ')') != 1:
  33. return re_error('/error/3')
  34. else:
  35. if admin_check(1, 'ban (' + name + ')') != 1:
  36. return re_error('/error/3')
  37. ban_insert(
  38. name,
  39. end,
  40. why,
  41. login,
  42. ip_check(),
  43. type_d
  44. )
  45. return redirect('/block_log')
  46. else:
  47. curs.execute(db_change("select end, why from rb where block = ? and ongoing = '1' and band = ?"), [name, band])
  48. end = curs.fetchall()
  49. if end:
  50. main_name = name
  51. b_now = load_lang('release')
  52. now = '(' + b_now + ')'
  53. action = 'action="/ban/' + url_pas(name) + ('?type=' + band if band != '' else '') + '"'
  54. if end[0][0] == '':
  55. data = '<ul class="inside_ul"><li>' + load_lang('limitless') + '</li>'
  56. else:
  57. data = '<ul class="inside_ul"><li>' + load_lang('period') + ' : ' + end[0][0] + '</li>'
  58. curs.execute(db_change("select block from rb where block = ? and login = 'O' and ongoing = '1'"), [name])
  59. if curs.fetchall():
  60. data += '<li>' + load_lang('login_able') + '</li>'
  61. if end[0][1] != '':
  62. data += '<li>' + load_lang('why') + ' : ' + end[0][1] + '</li></ul><hr class="main_hr">'
  63. else:
  64. data += '</ul><hr class="main_hr">'
  65. else:
  66. main_name = load_lang('ban')
  67. n_name = '<input placeholder="' + load_lang('name_or_ip_or_regex') + '" value="' + (name if name else '') + '" name="name" type="text"><hr class="main_hr">'
  68. regex = '<input type="checkbox" name="regex" ' + ('checked' if band == 'regex' else '') + '> ' + load_lang('regex') + '<hr class="main_hr">'
  69. plus = '<input type="checkbox" name="login"> ' + load_lang('login_able') + '<hr class="main_hr">'
  70. now = 0
  71. b_now = load_lang('ban')
  72. action = 'action="/ban"'
  73. time_data = [
  74. ['86400', load_lang('1_day')],
  75. ['432000', load_lang('5_day')],
  76. ['2592000', load_lang('30_day')],
  77. ['15552000', load_lang('180_day')],
  78. ['31104000', load_lang('360_day')],
  79. ['0', load_lang('limitless')]
  80. ]
  81. insert_data = ''
  82. for i in time_data:
  83. insert_data += '<a href="javascript:insert_v(\'second\', \'' + i[0] + '\')">(' + i[1] + ')</a> '
  84. data = n_name + '''
  85. ''' + regex + '''
  86. <script>function insert_v(name, data) { document.getElementById(name).value = data; }</script>''' + insert_data + '''
  87. <hr class="main_hr">
  88. <input placeholder="''' + load_lang('ban_period') + ''' (''' + load_lang('second') + ''')" name="second" id="second" type="text">
  89. <hr class="main_hr">
  90. <input placeholder="''' + load_lang('why') + '''" name="why" type="text">
  91. <hr class="main_hr">
  92. ''' + plus
  93. return easy_minify(flask.render_template(skin_check(),
  94. imp = [main_name, wiki_set(), wiki_custom(), wiki_css([now, 0])],
  95. data = '''
  96. <form method="post" ''' + action + '''>
  97. ''' + data + '''
  98. <button type="submit">''' + b_now + '''</button>
  99. </form>
  100. ''',
  101. menu = [['manager', load_lang('return')]]
  102. ))