import mariadb as mdb import json import sys import os from httputils import parse_query, escape_sql_string def readfile(path): if os.path.exists(path): return open(path).read() args = {"host": "127.0.0.1", "port": 3306, "user": "root", "password": "", "database": "test_holder"} settings = json.loads(readfile("cgi/db-settings.json")) args.update(settings) db_connection = mdb.connect(**args) args = parse_query(os.environ['QUERY_STRING']) if not 'question_id' in args: print("Content-Type: text/plain; charset=UTF-8\r\n\r\nВи не зазначили ідентифікатор запитання, якого стосується цей варіант відповіді\r\n") sys.exit(0) if not 'label' in args: print("Content-Type: text/plain; charset=UTF-8\r\n\r\nВи не зазначили текст варіанту відповіді\r\n") sys.exit(0) if not 'mtime' in args: args['mtime'] = 0 cur = db_connection.cursor() try: cur.execute(f"INSERT INTO response_option ( label, qstID, corct ) VALUES ( '{escape_sql_string(args['label'])}', {args['question_id']}, 0 );") db_connection.commit() #cur.execute(f"SELECT id FROM response ORDER BY id DESC;") #new_id = iter(cur).__next__()[0] print(f"Location: /index.py?mode=view-question&id={args['question_id']}\r\n\r\n") except Exception as e: print(f"Content-Type: text/plain; charset=UTF-8\r\n\r\nНе вдалося створити новий варіант відповіді ({e})\r\n")