user_setting.py 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. from .tool.func import *
  2. def user_setting_2(conn, server_init):
  3. curs = conn.cursor()
  4. support_language = ['default'] + server_init.server_init()['language']['list']
  5. ip = ip_check()
  6. if ban_check() == 1:
  7. return re_error('/ban')
  8. if ip_or_user(ip) == 0:
  9. if flask.request.method == 'POST':
  10. auto_list = [
  11. ['skin', flask.request.form.get('skin', '')],
  12. ['lang', flask.request.form.get('lang', '')]
  13. ]
  14. twofa_turn_on = 0
  15. twofa_on = flask.request.form.get('2fa', '')
  16. if twofa_on != '':
  17. twofa_turn_on = 1
  18. twofa_pw = flask.request.form.get('2fa_pw', '')
  19. if twofa_pw != '':
  20. twofa_pw = pw_encode(twofa_pw)
  21. curs.execute(db_change("select data from user_set where id = ? and name = 'encode'"), [ip])
  22. twofa_encode = curs.fetchall()[0][0]
  23. auto_list += [['2fa', 'on'], ['2fa_pw', twofa_pw], ['2fa_pw_encode', twofa_encode]]
  24. else:
  25. auto_list += [['2fa', 'on']]
  26. else:
  27. auto_list += [['2fa', '']]
  28. for auto_data in auto_list:
  29. curs.execute(db_change('select data from user_set where name = ? and id = ?'), [auto_data[0], ip])
  30. if curs.fetchall():
  31. curs.execute(db_change("update user_set set data = ? where name = ? and id = ?"), [auto_data[1], auto_data[0], ip])
  32. else:
  33. curs.execute(db_change("insert into user_set (name, id, data) values (?, ?, ?)"), [auto_data[0], ip, auto_data[1]])
  34. conn.commit()
  35. return redirect('/change')
  36. else:
  37. curs.execute(db_change('select data from user_set where name = "email" and id = ?'), [ip])
  38. data = curs.fetchall()
  39. email = data[0][0] if data else '-'
  40. curs.execute(db_change('select data from user_set where name = "skin" and id = ?'), [ip])
  41. data = curs.fetchall()
  42. div2 = load_skin(data[0][0] if data else '', 0, 1)
  43. curs.execute(db_change('select data from user_set where name = "lang" and id = ?'), [ip])
  44. data = curs.fetchall()
  45. data = [['default']] if not data else data
  46. div3 = ''
  47. for lang_data in support_language:
  48. see_data = lang_data if lang_data != 'default' else load_lang('default')
  49. if data and data[0][0] == lang_data:
  50. div3 = '<option value="' + lang_data + '">' + see_data + '</option>' + div3
  51. else:
  52. div3 += '<option value="' + lang_data + '">' + see_data + '</option>'
  53. curs.execute(db_change('select data from user_set where name = "2fa" and id = ?'), [ip])
  54. fa_data = curs.fetchall()
  55. fa_data = 'checked' if fa_data and fa_data[0][0] != '' else ''
  56. curs.execute(db_change('select data from user_set where name = "2fa_pw" and id = ?'), [ip])
  57. fa_data_pw = curs.fetchall()
  58. fa_data_pw = load_lang('2fa_password_change') if fa_data_pw else load_lang('2fa_password')
  59. return easy_minify(flask.render_template(skin_check(),
  60. imp = [load_lang('user_setting'), wiki_set(), wiki_custom(), wiki_css([0, 0])],
  61. data = '''
  62. <form method="post">
  63. <div id="get_user_info"></div>
  64. <script>load_user_info("''' + ip + '''");</script>
  65. <hr class="main_hr">
  66. <a href="/change/pw">(''' + load_lang('password_change') + ''')</a>
  67. <hr class="main_hr">
  68. <span>''' + load_lang('email') + ''' : ''' + email + '''</span> <a href="/change/email">(''' + load_lang('email_change') + ''')</a>
  69. <h2>''' + load_lang('main') + '''</h2>
  70. <span>''' + load_lang('skin') + '''</span>
  71. <hr class="main_hr">
  72. <select name="skin">''' + div2 + '''</select>
  73. <hr class="main_hr">
  74. <span>''' + load_lang('language') + '''</span>
  75. <hr class="main_hr">
  76. <select name="lang">''' + div3 + '''</select>
  77. <h2>''' + load_lang('2fa') + '''</h2>
  78. <input type="checkbox" id="twofa_check_input" onclick="do_twofa_check(0);" name="2fa" value="on" ''' + fa_data + '''> ''' + load_lang('on') + '''
  79. <div id="fa_plus_content">
  80. <hr class="main_hr">
  81. <input type="password" name="2fa_pw" placeholder="''' + fa_data_pw + '''">
  82. </div>
  83. <hr class="main_hr">
  84. <button type="submit">''' + load_lang('save') + '''</button>
  85. ''' + http_warning() + '''
  86. <script>do_twofa_check(1);</script>
  87. </form>
  88. ''',
  89. menu = [['user', load_lang('return')]]
  90. ))
  91. else:
  92. if flask.request.method == 'POST':
  93. flask.session['skin'] = flask.request.form.get('skin', '')
  94. flask.session['lang'] = flask.request.form.get('lang', '')
  95. return redirect('/change')
  96. else:
  97. div2 = load_skin(
  98. ('' if not 'skin' in flask.session else flask.session['skin']),
  99. 0,
  100. 1
  101. )
  102. data = [['default']] if not 'lang' in flask.session else [[flask.session['lang']]]
  103. div3 = ''
  104. for lang_data in support_language:
  105. see_data = lang_data if lang_data != 'default' else load_lang('default')
  106. if data and data[0][0] == lang_data:
  107. div3 = '<option value="' + lang_data + '">' + see_data + '</option>' + div3
  108. else:
  109. div3 += '<option value="' + lang_data + '">' + see_data + '</option>'
  110. return easy_minify(flask.render_template(skin_check(),
  111. imp = [load_lang('user_setting'), wiki_set(), wiki_custom(), wiki_css([0, 0])],
  112. data = '''
  113. <form method="post">
  114. <div id="get_user_info"></div>
  115. <script>load_user_info("''' + ip + '''");</script>
  116. <hr class="main_hr">
  117. <h2>''' + load_lang('main') + '''</h2>
  118. <span>''' + load_lang('skin') + '''</span>
  119. <hr class="main_hr">
  120. <select name="skin">''' + div2 + '''</select>
  121. <hr class="main_hr">
  122. <span>''' + load_lang('language') + '''</span>
  123. <hr class="main_hr">
  124. <select name="lang">''' + div3 + '''</select>
  125. <hr class="main_hr">
  126. <button type="submit">''' + load_lang('save') + '''</button>
  127. ''' + http_warning() + '''
  128. <hr class="main_hr">
  129. <span>''' + load_lang('user_head_warning') + '''</span>
  130. </form>
  131. ''',
  132. menu = [['user', load_lang('return')]]
  133. ))