edit_upload.py 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. from .tool.func import *
  2. def edit_upload():
  3. with get_db_connect() as conn:
  4. curs = conn.cursor()
  5. if acl_check(conn, '', 'upload') == 1:
  6. return re_error(conn, '/ban')
  7. curs.execute(db_change('select data from other where name = "upload"'))
  8. db_data = curs.fetchall()
  9. file_max = number_check(db_data[0][0]) if db_data and db_data[0][0] != '' else '2'
  10. file_max = int(file_max)
  11. if flask.request.method == 'POST':
  12. if captcha_post(conn, flask.request.form.get('g-recaptcha-response', flask.request.form.get('g-recaptcha', ''))) == 1:
  13. return re_error(conn, '/error/13')
  14. else:
  15. captcha_post(conn, '', 0)
  16. file_data = flask.request.files.getlist("f_data[]")
  17. file_len = len(file_data)
  18. file_size_all = flask.request.content_length
  19. if file_size_all == None:
  20. file_size_all = 0
  21. if (file_max * 1000 * 1000 * file_len) < file_size_all or file_size_all == 0:
  22. return re_error(conn, '/error/17')
  23. if file_len == 1:
  24. file_num = None
  25. else:
  26. if acl_check(conn, '', 'many_upload') == 1:
  27. return re_error(conn, '/ban')
  28. file_num = 1
  29. for data in file_data:
  30. file_name = data.filename if data.filename else ''
  31. if file_name == '':
  32. return re_error(conn, '/error/9')
  33. value_tmp = os.path.splitext(file_name)
  34. value = ''
  35. if len(value_tmp) >= 2:
  36. value = value_tmp[1]
  37. curs.execute(db_change("select html from html_filter where kind = 'extension'"))
  38. extension = [i[0].lower() for i in curs.fetchall()]
  39. if not re.sub(r'^\.', '', value).lower() in extension:
  40. return re_error(conn, '/error/14')
  41. name = ''
  42. if flask.request.form.get('f_name', None):
  43. name = flask.request.form.get('f_name', '') + (' ' + str(file_num) if file_num else '') + value
  44. else:
  45. name = file_name
  46. piece = os.path.splitext(name)
  47. if re.search(r'\.', piece[0]):
  48. return re_error(conn, '/error/22')
  49. e_data = sha224_replace(piece[0]) + piece[1]
  50. curs.execute(db_change("select title from data where title = ?"), ['file:' + name])
  51. if curs.fetchall():
  52. return re_error(conn, '/error/16')
  53. curs.execute(db_change("select html from html_filter where kind = 'file'"))
  54. db_data = curs.fetchall()
  55. for i in db_data:
  56. t_re = re.compile(i[0])
  57. if t_re.search(name):
  58. return redirect(conn, '/filter/file_filter')
  59. data_url_image = load_image_url(conn)
  60. if os.path.exists(os.path.join(data_url_image, e_data)):
  61. return re_error(conn, '/error/16')
  62. else:
  63. data.save(os.path.join(data_url_image, e_data))
  64. ip = ip_check()
  65. g_lice = flask.request.form.get('f_lice', '')
  66. file_size = os.stat(os.path.join(data_url_image, e_data)).st_size
  67. file_size = str(round(file_size / 1000, 1))
  68. curs.execute(db_change("select data from other where name = 'markup'"))
  69. db_data = curs.fetchall()
  70. if db_data and db_data[0][0] == 'namumark':
  71. file_d = '' + \
  72. flask.request.form.get('f_lice_sel', 'direct_input') + '\n' + \
  73. '[[category:' + re.sub(r'\]', '_', flask.request.form.get('f_lice_sel', '')) + ']]\n' + \
  74. (g_lice if g_lice != '' else '') + \
  75. ''
  76. else:
  77. file_d = '' + \
  78. flask.request.form.get('f_lice_sel', 'direct_input') + '\n' + \
  79. (g_lice if g_lice != '' else '') + \
  80. ''
  81. curs.execute(db_change("insert into data (title, data) values (?, ?)"), ['file:' + name, file_d])
  82. render_set(conn,
  83. doc_name = 'file:' + name,
  84. doc_data = file_d,
  85. data_type = 'backlink'
  86. )
  87. history_plus(conn,
  88. 'file:' + name,
  89. file_d,
  90. get_time(),
  91. ip,
  92. '',
  93. '0',
  94. mode = 'upload'
  95. )
  96. if file_num:
  97. file_num += 1
  98. return redirect(conn, '/w/file:' + name)
  99. else:
  100. license_list = '<option value="direct_input">' + get_lang(conn, 'direct_input') + '</option>'
  101. file_name = html.escape(flask.request.args.get('name', ''))
  102. curs.execute(db_change("select html from html_filter where kind = 'image_license'"))
  103. db_data = curs.fetchall()
  104. license_list += ''.join(['<option value="' + i[0] + '">' + i[0] + '</option>' for i in db_data])
  105. curs.execute(db_change("select data from other where name = 'upload_help'"))
  106. db_data = curs.fetchall()
  107. upload_help = ('<hr class="main_hr">' + db_data[0][0]) if db_data and db_data[0][0] != '' else ''
  108. curs.execute(db_change("select data from other where name = 'upload_default'"))
  109. db_data = curs.fetchall()
  110. upload_default = html.escape(db_data[0][0]) if db_data and db_data[0][0] != '' else ''
  111. return easy_minify(conn, flask.render_template(skin_check(conn),
  112. imp = [get_lang(conn, 'upload'), wiki_set(conn), wiki_custom(conn), wiki_css([0, 0])],
  113. data = '''
  114. <a href="/filter/file_filter">(''' + get_lang(conn, 'file_filter_list') + ''')</a> <a href="/filter/extension_filter">(''' + get_lang(conn, 'extension_filter_list') + ''')</a>
  115. ''' + upload_help + '''
  116. <hr class="main_hr">
  117. ''' + get_lang(conn, 'max_file_size') + ''' : ''' + str(file_max) + '''MB
  118. <hr class="main_hr">
  119. <form method="post" enctype="multipart/form-data" accept-charset="utf8">
  120. <input multiple="multiple" type="file" name="f_data[]">
  121. <hr class="main_hr">
  122. <input placeholder="''' + get_lang(conn, 'file_name') + '''" name="f_name" value="''' + file_name + '''">
  123. <hr class="main_hr">
  124. <select name="f_lice_sel">
  125. ''' + license_list + '''
  126. </select>
  127. <hr class="main_hr">
  128. <textarea class="opennamu_textarea_100" placeholder="''' + get_lang(conn, 'other') + '''" name="f_lice">''' + upload_default + '''</textarea>
  129. <hr class="main_hr">
  130. ''' + captcha_get(conn) + '''
  131. <button id="opennamu_save_button" type="submit">''' + get_lang(conn, 'save') + '''</button>
  132. </form>
  133. ''',
  134. menu = [['other', get_lang(conn, 'return')]]
  135. ))