2
0

user_setting.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. from .tool.func import *
  2. def user_setting():
  3. with get_db_connect() as conn:
  4. curs = conn.cursor()
  5. support_language = ['default'] + get_init_set_list()['language']['list']
  6. ip = ip_check()
  7. if ip_or_user(ip) == 0:
  8. if flask.request.method == 'POST':
  9. auto_list = [
  10. ['skin', flask.request.form.get('skin', '')],
  11. ['lang', flask.request.form.get('lang', '')],
  12. ['user_title', flask.request.form.get('user_title', '')],
  13. ['sub_user_name' , flask.request.form.get('sub_user_name', '')]
  14. ]
  15. if not auto_list[2][1] in get_user_title_list(conn, ip):
  16. auto_list[2][1] = ''
  17. twofa_on = flask.request.form.get('2fa', '')
  18. if twofa_on != '':
  19. twofa_pw = flask.request.form.get('2fa_pw', '')
  20. if twofa_pw != '':
  21. twofa_pw = pw_encode(conn, twofa_pw)
  22. curs.execute(db_change("select data from user_set where id = ? and name = 'encode'"), [ip])
  23. twofa_encode = curs.fetchall()[0][0]
  24. auto_list += [['2fa', 'on'], ['2fa_pw', twofa_pw], ['2fa_pw_encode', twofa_encode]]
  25. else:
  26. auto_list += [['2fa', 'on']]
  27. else:
  28. auto_list += [['2fa', '']]
  29. for auto_data in auto_list:
  30. curs.execute(db_change('select data from user_set where name = ? and id = ?'), [auto_data[0], ip])
  31. if curs.fetchall():
  32. curs.execute(db_change("update user_set set data = ? where name = ? and id = ?"), [auto_data[1], auto_data[0], ip])
  33. else:
  34. curs.execute(db_change("insert into user_set (name, id, data) values (?, ?, ?)"), [auto_data[0], ip, auto_data[1]])
  35. return redirect(conn, '/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 and data[0][0] != '' else '-'
  40. curs.execute(db_change('select data from user_set where name = "random_key" and id = ?'), [ip])
  41. data = curs.fetchall()
  42. ramdom_key = data[0][0] if data and data[0][0] != '' else '-'
  43. curs.execute(db_change('select data from user_set where name = "skin" and id = ?'), [ip])
  44. data = curs.fetchall()
  45. div2 = load_skin(conn, data[0][0] if data else '', 0, 1)
  46. curs.execute(db_change('select data from user_set where name = "lang" and id = ?'), [ip])
  47. data = curs.fetchall()
  48. data = [['default']] if not data else data
  49. div3 = ''
  50. for lang_data in support_language:
  51. see_data = lang_data if lang_data != 'default' else get_lang(conn, 'default')
  52. if data and data[0][0] == lang_data:
  53. div3 = '<option value="' + lang_data + '">' + see_data + '</option>' + div3
  54. else:
  55. div3 += '<option value="' + lang_data + '">' + see_data + '</option>'
  56. curs.execute(db_change('select data from user_set where name = "user_title" and id = ?'), [ip])
  57. data = curs.fetchall()
  58. data = [['']] if not data else data
  59. user_title_list = get_user_title_list(conn, ip)
  60. div4 = ''
  61. for user_title in user_title_list:
  62. if data and data[0][0] == user_title:
  63. div4 = '<option value="' + user_title + '">' + user_title_list[user_title] + '</option>' + div4
  64. else:
  65. div4 += '<option value="' + user_title + '">' + user_title_list[user_title] + '</option>'
  66. curs.execute(db_change('select data from user_set where name = "2fa" and id = ?'), [ip])
  67. fa_data = curs.fetchall()
  68. fa_data = fa_data[0][0] if fa_data and fa_data[0][0] != '' else ''
  69. fa_data_select = ''
  70. fa_data_sp_list = [[get_lang(conn, 'off'), ''], [get_lang(conn, 'password'), 'on']]
  71. for fa_data_get in fa_data_sp_list:
  72. fa_data_selected = ''
  73. if fa_data == fa_data_get[1]:
  74. fa_data_selected = 'selected'
  75. fa_data_select += '<option ' + fa_data_selected + ' value="' + fa_data_get[1] + '">' + fa_data_get[0] + '</option>'
  76. curs.execute(db_change('select data from user_set where name = "2fa_pw" and id = ?'), [ip])
  77. fa_data_pw = curs.fetchall()
  78. fa_data_pw = get_lang(conn, '2fa_password_change') if fa_data_pw else get_lang(conn, '2fa_password')
  79. curs.execute(db_change('select data from user_set where name = "user_name" and id = ?'), [ip])
  80. db_data = curs.fetchall()
  81. user_name = db_data[0][0] if db_data else ip
  82. curs.execute(db_change('select data from user_set where name = "sub_user_name" and id = ?'), [ip])
  83. db_data = curs.fetchall()
  84. sub_user_name = db_data[0][0] if db_data else ''
  85. return easy_minify(conn, flask.render_template(skin_check(conn),
  86. imp = [get_lang(conn, 'user_setting'), wiki_set(conn), wiki_custom(conn), wiki_css([0, 0])],
  87. data = '''
  88. <form method="post">
  89. <div id="opennamu_get_user_info">''' + html.escape(ip) + '''</div>
  90. <hr class="main_hr">
  91. <a href="/change/pw">(''' + get_lang(conn, 'password_change') + ''')</a>
  92. <hr class="main_hr">
  93. <span>''' + get_lang(conn, 'email') + ''' : ''' + email + '''</span> <a href="/change/email">(''' + get_lang(conn, 'email_change') + ''')</a> <a href="/change/email/delete">(''' + get_lang(conn, 'email_delete') + ''')</a>
  94. <hr class="main_hr">
  95. <span>''' + get_lang(conn, 'password_instead_key') + ''' : ''' + ramdom_key + ''' <a href="/change/key">(''' + get_lang(conn, 'key_change') + ''')</a> <a href="/change/key/delete">(''' + get_lang(conn, 'key_delete') + ''')</a></span>
  96. <h2>''' + get_lang(conn, 'main') + '''</h2>
  97. <a href="/change/head">(''' + get_lang(conn, 'user_head') + ''')</a> <a href="/change/top_menu">(''' + get_lang(conn, 'user_added_menu') + ''')</a>
  98. <hr class="main_hr">
  99. <span>''' + get_lang(conn, 'skin') + '''</span>
  100. <hr class="main_hr">
  101. <select name="skin">''' + div2 + '''</select>
  102. <hr class="main_hr">
  103. <a href="/change/skin_set">(''' + get_lang(conn, 'skin_set') + ''')</a> <a href="/change/skin_set/main">(''' + get_lang(conn, 'main_skin_set') + ''')</a>
  104. <hr class="main_hr">
  105. <span>''' + get_lang(conn, 'language') + '''</span>
  106. <hr class="main_hr">
  107. <select name="lang">''' + div3 + '''</select>
  108. <hr class="main_hr">
  109. <span>''' + get_lang(conn, 'user_title') + '''</span>
  110. <hr class="main_hr">
  111. <select name="user_title">''' + div4 + '''</select>
  112. <h2>''' + get_lang(conn, '2fa') + '''</h2>
  113. <select name="2fa" id="twofa_check_input">''' + fa_data_select + '''</select>
  114. <hr class="main_hr">
  115. <input type="password" name="2fa_pw" placeholder="''' + fa_data_pw + '''">
  116. <h2>''' + get_lang(conn, 'main_user_name') + '''</h2>
  117. <a href="/change/user_name">(''' + get_lang(conn, 'change_user_name') + ''')</a>
  118. <hr class="main_hr">
  119. ''' + get_lang(conn, 'user_name') + ''' : ''' + html.escape(user_name) + '''
  120. <h2>''' + get_lang(conn, 'sub_user_name') + '''</h2>
  121. <input name="sub_user_name" value="''' + html.escape(sub_user_name) + '''" placeholder="''' + get_lang(conn, 'sub_user_name') + '''">
  122. <hr class="main_hr">
  123. <button type="submit">''' + get_lang(conn, 'save') + '''</button>
  124. ''' + http_warning(conn) + '''
  125. </form>
  126. ''',
  127. menu = [['user', get_lang(conn, 'return')]]
  128. ))
  129. else:
  130. if flask.request.method == 'POST':
  131. flask.session['skin'] = flask.request.form.get('skin', '')
  132. flask.session['lang'] = flask.request.form.get('lang', '')
  133. return redirect(conn, '/change')
  134. else:
  135. div2 = load_skin(conn,
  136. ('' if not 'skin' in flask.session else flask.session['skin']),
  137. 0,
  138. 1
  139. )
  140. data = [['default']] if not 'lang' in flask.session else [[flask.session['lang']]]
  141. div3 = ''
  142. for lang_data in support_language:
  143. see_data = lang_data if lang_data != 'default' else get_lang(conn, 'default')
  144. if data and data[0][0] == lang_data:
  145. div3 = '<option value="' + lang_data + '">' + see_data + '</option>' + div3
  146. else:
  147. div3 += '<option value="' + lang_data + '">' + see_data + '</option>'
  148. return easy_minify(conn, flask.render_template(skin_check(conn),
  149. imp = [get_lang(conn, 'user_setting'), wiki_set(conn), wiki_custom(conn), wiki_css([0, 0])],
  150. data = '''
  151. <form method="post">
  152. <div id="opennamu_get_user_info">''' + html.escape(ip) + '''</div>
  153. <hr class="main_hr">
  154. <h2>''' + get_lang(conn, 'main') + '''</h2>
  155. <span>''' + get_lang(conn, 'skin') + '''</span>
  156. <hr class="main_hr">
  157. <select name="skin">''' + div2 + '''</select>
  158. <hr class="main_hr">
  159. <a href="/change/skin_set">(''' + get_lang(conn, 'skin_set') + ''')</a> <a href="/change/skin_set/main">(''' + get_lang(conn, 'main_skin_set') + ''')</a>
  160. <hr class="main_hr">
  161. <span>''' + get_lang(conn, 'language') + '''</span>
  162. <hr class="main_hr">
  163. <select name="lang">''' + div3 + '''</select>
  164. <hr class="main_hr">
  165. <button type="submit">''' + get_lang(conn, 'save') + '''</button>
  166. ''' + http_warning(conn) + '''
  167. <hr class="main_hr">
  168. <span>''' + get_lang(conn, 'user_head_warning') + '''</span>
  169. </form>
  170. ''',
  171. menu = [['user', get_lang(conn, 'return')]]
  172. ))