give_user_ban.py 4.7 KB

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