login_change_password.py 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. from .tool.func import *
  2. def login_change_password_2(conn, server_init):
  3. curs = conn.cursor()
  4. support_language = server_init.server_set_var['language']['list']
  5. if ban_check() == 1:
  6. return re_error('/ban')
  7. if custom()[2] == 0:
  8. return redirect('/login')
  9. ip = ip_check()
  10. user_state = flask.request.args.get('user', 'ip')
  11. if user_state == 'ip':
  12. if flask.request.method == 'POST':
  13. if flask.request.form.get('pw4', None) and flask.request.form.get('pw2', None):
  14. if flask.request.form.get('pw2', None) != flask.request.form.get('pw3', None):
  15. return re_error('/error/20')
  16. curs.execute("select pw, encode from user where id = ?", [flask.session['id']])
  17. user = curs.fetchall()
  18. if not user:
  19. return re_error('/error/2')
  20. pw_check_d = pw_check(
  21. flask.request.form.get('pw4', ''),
  22. user[0][0],
  23. user[0][1],
  24. flask.request.form.get('id', None)
  25. )
  26. if pw_check_d != 1:
  27. return re_error('/error/10')
  28. hashed = pw_encode(flask.request.form.get('pw2', None))
  29. curs.execute("update user set pw = ? where id = ?", [hashed, flask.session['id']])
  30. auto_list = ['email', 'skin', 'lang']
  31. for auto_data in auto_list:
  32. curs.execute('select data from user_set where name = ? and id = ?', [auto_data, ip])
  33. if curs.fetchall():
  34. curs.execute("update user_set set data = ? where name = ? and id = ?", [flask.request.form.get(auto_data, ''), auto_data, ip])
  35. else:
  36. curs.execute("insert into user_set (name, id, data) values (?, ?, ?)", [auto_data, ip, flask.request.form.get(auto_data, '')])
  37. conn.commit()
  38. return redirect('/change')
  39. else:
  40. curs.execute('select data from user_set where name = "email" and id = ?', [ip])
  41. data = curs.fetchall()
  42. if data:
  43. email = data[0][0]
  44. else:
  45. email = ''
  46. div2 = load_skin()
  47. div3 = ''
  48. curs.execute('select data from user_set where name = "lang" and id = ?', [flask.session['id']])
  49. data = curs.fetchall()
  50. if not data:
  51. curs.execute('select data from other where name = "language"')
  52. data = curs.fetchall()
  53. if not data:
  54. data = [['en-US']]
  55. for lang_data in support_language:
  56. if data and data[0][0] == lang_data:
  57. div3 = '<option value="' + lang_data + '">' + lang_data + '</option>' + div3
  58. else:
  59. div3 += '<option value="' + lang_data + '">' + lang_data + '</option>'
  60. oauth_provider = load_oauth('_README')['support']
  61. oauth_content = '<ul>'
  62. for i in range(len(oauth_provider)):
  63. curs.execute('select name, picture from oauth_conn where wiki_id = ? and provider = ?', [flask.session['id'], oauth_provider[i]])
  64. oauth_data = curs.fetchall()
  65. if len(oauth_data) == 1:
  66. oauth_content += '<li>{} - {}</li>'.format(oauth_provider[i].capitalize(), load_lang('connection') + ' : <img src="{}" width="17px" height="17px">{}'.format(oauth_data[0][1], oauth_data[0][0]))
  67. else:
  68. oauth_content += '<li>{} - {}</li>'.format(oauth_provider[i].capitalize(), load_lang('connection') + ' : <a href="/oauth/{}/init">{}</a>'.format(oauth_provider[i], load_lang('connect')))
  69. oauth_content += '</ul>'
  70. http_warring = '<hr class=\"main_hr\"><span>' + load_lang('http_warring') + '</span>'
  71. return easy_minify(flask.render_template(skin_check(),
  72. imp = [load_lang('user_setting'), wiki_set(), custom(), other2([0, 0])],
  73. data = '''
  74. <form method="post">
  75. <span>''' + load_lang('id') + ''' : ''' + ip + '''</span>
  76. <hr class=\"main_hr\">
  77. <input placeholder="''' + load_lang('now_password') + '''" name="pw4" type="password">
  78. <hr class=\"main_hr\">
  79. <input placeholder="''' + load_lang('new_password') + '''" name="pw2" type="password">
  80. <hr class=\"main_hr\">
  81. <input placeholder="''' + load_lang('password_confirm') + '''" name="pw3" type="password">
  82. <hr class=\"main_hr\">
  83. <span>''' + load_lang('skin') + '''</span>
  84. <hr class=\"main_hr\">
  85. <select name="skin">''' + div2 + '''</select>
  86. <hr class=\"main_hr\">
  87. <span>''' + load_lang('language') + '''</span>
  88. <hr class=\"main_hr\">
  89. <select name="lang">''' + div3 + '''</select>
  90. <hr class=\"main_hr\">
  91. <span>''' + load_lang('oauth_connection') + '''</span>
  92. ''' + oauth_content + '''
  93. <hr class=\"main_hr\">
  94. <button type="submit">''' + load_lang('save') + '''</button>
  95. ''' + http_warring + '''
  96. </form>
  97. ''',
  98. menu = [['user', load_lang('return')]]
  99. ))
  100. else:
  101. pass