main_upload.py 6.7 KB

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