Import.py: Sanitize given csv in case --Import isnt given and...

... fixup some variable names, also a `pass` that i forget to delete
beforehand.

Also, as you can see in the title, i added the ability to sanitize a
given csv file in case the user didnt supply the --Import flag. Thus, it
isnt required anymore.
Darksider3 5 years ago
parent aae7504e13
commit b4bb45ef85

@ -1,14 +1,17 @@
#!/usr/bin/env python3 #!/usr/bin/env python3
"""
Import users or sanitize backup files
"""
import configparser import configparser
import csv import csv
import os import os
import lib.UserExceptions import lib.UserExceptions
import lib.uis.config_ui # dont go to default, just following -c flag import lib.uis.config_ui # dont go to default, just following -c flag
import lib.Validator
def import_from_file(file_path: str, db: str, user_ids: tuple = tuple([])) -> bool: def import_from_file(file_path: str, database_file: str, user_ids: tuple = tuple([])) -> bool:
""" Imports Users from a given CSV-file to the system and DB """ Imports Users from a given CSV-file to the system and DB
:param file_path: :param file_path:
@ -23,22 +26,21 @@ def import_from_file(file_path: str, db: str, user_ids: tuple = tuple([])) -> bo
if not os.path.isfile(file_path): if not os.path.isfile(file_path):
print(f"File {file_path} don't exist") print(f"File {file_path} don't exist")
return False return False
if not os.path.isfile(db): if not os.path.isfile(database_file):
print(f"The database file {db} don't exist") print(f"The database file {database_file} don't exist")
return False return False
if user_ids: if user_ids:
pass # empty tuple means everything pass # empty tuple means everything
# noinspection PyBroadException # noinspection PyBroadException
try: try:
with open(file_path, 'r', newline='') as f: with open(file_path, 'r', newline='') as f:
import lib.Validator import lib.sqlitedb
sql = lib.sqlitedb.SQLiteDB(db) import lib.System
err = lib.Validator.checkImportFile(file_path, db) sql = lib.sqlitedb.SQLiteDB(database_file)
err = lib.Validator.checkImportFile(file_path, database_file)
if err is not True: if err is not True:
print(err) print(err)
exit(0) exit(0)
import lib.sqlitedb
import lib.System
sys_ctl = lib.System.System("root") sys_ctl = lib.System.System("root")
reader = csv.DictReader(f) # @TODO csv.Sniffer to compare? When yes, give force-accept option reader = csv.DictReader(f) # @TODO csv.Sniffer to compare? When yes, give force-accept option
for row in reader: for row in reader:
@ -47,8 +49,8 @@ def import_from_file(file_path: str, db: str, user_ids: tuple = tuple([])) -> bo
sys_ctl.setUser(row["username"]) sys_ctl.setUser(row["username"])
sys_ctl.aio_approve(row["pubkey"]) sys_ctl.aio_approve(row["pubkey"])
print(row['username'], "====> Registered.") print(row['username'], "====> Registered.")
except lib.UserExceptions.General as GeneralExcept: except lib.UserExceptions.General as general_except:
print(f"Something didnt work out! {GeneralExcept}") print(f"Something didnt work out! {general_except}")
elif row["status"] == "0": elif row["status"] == "0":
print(row['username'] + " not approved, therefore not registered.") print(row['username'] + " not approved, therefore not registered.")
try: try:
@ -56,11 +58,10 @@ def import_from_file(file_path: str, db: str, user_ids: tuple = tuple([])) -> bo
"INSERT INTO `applications` (username, name, timestamp, email, pubkey, status) " "INSERT INTO `applications` (username, name, timestamp, email, pubkey, status) "
"VALUES (?,?,?,?,?,?)", tuple([row["username"], row["name"], row["timestamp"], "VALUES (?,?,?,?,?,?)", tuple([row["username"], row["name"], row["timestamp"],
row["email"], row["pubkey"], row["status"]])) row["email"], row["pubkey"], row["status"]]))
except OSError as E: except OSError as os_exception:
pass print(f"UUFFF, something went WRONG with the file {file_path}: {os_exception}")
print(f"UUFFF, something went WRONG with the file {file_path}: {E}") except Exception as didnt_catch:
except Exception as didntCatch: print(f"Exception! UNCATCHED! {type(didnt_catch)}: {didnt_catch}")
print(f"Exception! UNCATCHED! {type(didntCatch)}: {didntCatch}")
return True return True
@ -71,17 +72,24 @@ if __name__ == "__main__":
ArgParser.add_argument('-f', '--file', default="stdout", ArgParser.add_argument('-f', '--file', default="stdout",
type=str, help='Import from CSV file', required=True) type=str, help='Import from CSV file', required=True)
ArgParser.add_argument('--Import', default=False, action="store_true", ArgParser.add_argument('--Import', default=False, action="store_true",
help="Import Users.", required=True) help="Import Users. If not set, just sanitize the supplied csv", required=False)
args = ArgParser.parse_args() args = ArgParser.parse_args()
config = configparser.ConfigParser() config = configparser.ConfigParser()
config.read(args.config) config.read(args.config)
if not args.Import:
print("Error, need the import flag")
if not args.file: if not args.file:
print("Error, need the import file") print("Error, need the import file")
if not args.file: if not args.Import:
print("You MUST set a CSV-file with the -f/--file flag that already exist") # we assume that you just want to sanitize the backup
if not os.path.isfile(args.file):
print(f"File {args.file} doesnt exist")
exit(1) exit(1)
sanitized = lib.Validator.checkImportFile(args.file, config['DEFAULT']['applications_db'])
if sanitized is not True:
print(sanitized)
else:
print(f"{args.file} is valid!")
exit(0)
elif args.Import:
import_from_file(args.file, config['DEFAULT']['applications_db']) import_from_file(args.file, config['DEFAULT']['applications_db'])
exit(0) exit(0)
Loading…
Cancel
Save