from .tool.func import * from .api_bbs_w_post import api_bbs_w_post from .edit import edit_editor def bbs_w_edit(bbs_num = '', post_num = '', do_type = ''): with get_db_connect() as conn: curs = conn.cursor() bbs_num_str = str(bbs_num) post_num_str = str(post_num) ip = ip_check() curs.execute(db_change('select set_id from bbs_set where set_id = ? and set_name = "bbs_name"'), [bbs_num_str]) if not curs.fetchall(): return redirect('/bbs/main') if post_num != '': curs.execute(db_change('select set_data from bbs_data where set_name = "user_id" and set_id = ? and set_code = ?'), [bbs_num, post_num]) db_data = curs.fetchall() if not db_data: return redirect('/bbs/main') else: if not db_data[0][0] == ip and admin_check() != 1: return re_error('/ban') if acl_check(bbs_num_str, 'bbs_edit') == 1: return redirect('/bbs/set/' + bbs_num_str) i_list = ['post_view_acl', 'post_comment_acl'] if flask.request.method == 'POST' and do_type != 'preview': 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 post_num == '': curs.execute(db_change('select set_code from bbs_data where set_name = "title" and set_id = ? order by set_code + 0 desc'), [bbs_num_str]) db_data = curs.fetchall() id_data = str(int(db_data[0][0]) + 1) if db_data else '1' else: id_data = post_num_str title = flask.request.form.get('title', 'test') title = 'test' if title == '' else title data = flask.request.form.get('content', '') if data == '': # re_error로 대체 예정 return redirect('/bbs/w/' + bbs_num_str) date = get_time() if post_num == '': curs.execute(db_change("insert into bbs_data (set_name, set_code, set_id, set_data) values ('title', ?, ?, ?)"), [id_data, bbs_num_str, title]) curs.execute(db_change("insert into bbs_data (set_name, set_code, set_id, set_data) values ('data', ?, ?, ?)"), [id_data, bbs_num_str, data]) curs.execute(db_change("insert into bbs_data (set_name, set_code, set_id, set_data) values ('date', ?, ?, ?)"), [id_data, bbs_num_str, date]) curs.execute(db_change("insert into bbs_data (set_name, set_code, set_id, set_data) values ('user_id', ?, ?, ?)"), [id_data, bbs_num_str, ip]) else: curs.execute(db_change("update bbs_data set set_data = ? where set_name = 'title' and set_code = ? and set_id = ?"), [title, post_num, bbs_num_str]) curs.execute(db_change("update bbs_data set set_data = ? where set_name = 'data' and set_code = ? and set_id = ?"), [data, id_data, bbs_num_str]) curs.execute(db_change("update bbs_data set set_data = ? where set_name = 'date' and set_code = ? and set_id = ?"), [date, id_data, bbs_num_str]) return redirect('/bbs/w/' + bbs_num_str + '/' + id_data) else: d_list = ['' for _ in range(0, len(i_list))] if do_type == 'preview': title = flask.request.form.get('title', '') data = flask.request.form.get('content', '') data = data.replace('\r', '') data_preview = render_set( doc_data = data, data_type = 'thread', data_in = 'bbs' ) + '