from .tool.func import * def edit(name = 'Test', name_load = 0, section = 0): with get_db_connect() as conn: curs = conn.cursor() ip = ip_check() if acl_check(name) == 1: return re_error('/ban') curs.execute(db_change("select id from history where title = ? order by id + 0 desc"), [name]) doc_ver = curs.fetchall() doc_ver = doc_ver[0][0] if doc_ver else '0' section = '' if section == 0 else section post_ver = flask.request.form.get('ver', '') if flask.request.method == 'POST': edit_repeat = 'error' if post_ver != doc_ver else 'post' else: edit_repeat = 'get' if edit_repeat == 'post': if captcha_post(flask.request.form.get('g-recaptcha-response', flask.request.form.get('g-recaptcha', ''))) == 1: return re_error('/error/13') else: captcha_post('', 0) if slow_edit_check() == 1: return re_error('/error/24') today = get_time() content = flask.request.form.get('content', '').replace('\r\n', '\n') if edit_filter_do(content) == 1: return re_error('/error/21') curs.execute(db_change('select data from other where name = "copyright_checkbox_text"')) copyright_checkbox_text_d = curs.fetchall() if copyright_checkbox_text_d and copyright_checkbox_text_d[0][0] != '' and flask.request.form.get('copyright_agreement', '') != 'yes': return re_error('/error/29') curs.execute(db_change("select data from data where title = ?"), [name]) old = curs.fetchall() if old: o_data = old[0][0].replace('\r\n', '\n') leng = leng_check(len(o_data), len(content)) curs.execute(db_change("update data set data = ? where title = ?"), [content, name]) else: leng = '+' + str(len(content)) curs.execute(db_change("insert into data (title, data) values (?, ?)"), [name, content]) curs.execute(db_change('select data from other where name = "count_all_title"')) curs.execute(db_change("update other set data = ? where name = 'count_all_title'"), [str(int(curs.fetchall()[0][0]) + 1)]) curs.execute(db_change("select user from scan where title = ? and type = ''"), [name]) for scan_user in curs.fetchall(): add_alarm(scan_user[0], ip + ' | ' + name + ' | Edit') history_plus( name, content, today, ip, flask.request.form.get('send', ''), leng ) curs.execute(db_change("delete from back where link = ?"), [name]) curs.execute(db_change("delete from back where title = ? and type = 'no'"), [name]) render_set( doc_name = name, doc_data = content, data_type = 'backlink' ) conn.commit() section = (('#edit_load_' + str(section)) if section != '' else '') return redirect('/w/' + url_pas(name) + section) else: editor_top_text = '' if edit_repeat == 'get': load_title = name_load if load_title == 0 and section == '': load_title = name editor_top_text += '(' + load_lang('load') + ') ' elif section != '': load_title = name curs.execute(db_change("select data from data where title = ?"), [load_title]) sql_d = curs.fetchall() data = sql_d[0][0] if sql_d else '' data = data.replace('\r\n', '\n') else: data = flask.request.form.get('content', '') warning_edit = load_lang('exp_edit_conflict') + ' ' if flask.request.form.get('ver', '0') == '0': warning_edit += '(r' + doc_ver + ')' else: warning_edit += '' + \ '' + \ '(r' + doc_ver + ')' + \ '' + \ '' warning_edit += '