mirror of
https://github.com/pgadmin-org/pgadmin4.git
synced 2025-02-25 18:55:31 -06:00
Fixed an issue when dumping servers from a desktop pgAdmin app by providing an option '--sqlite-path'. Fixes #5521
This commit is contained in:
committed by
Akshay Joshi
parent
b21b03495d
commit
1050c9857a
@@ -182,6 +182,11 @@ def create_app(app_name=None):
|
||||
if not app_name:
|
||||
app_name = config.APP_NAME
|
||||
|
||||
# Check if app is created for CLI operations or Web
|
||||
cli_mode = False
|
||||
if app_name.endswith('-cli'):
|
||||
cli_mode = True
|
||||
|
||||
# Only enable password related functionality in server mode.
|
||||
if config.SERVER_MODE is True:
|
||||
# Some times we need to access these config params where application
|
||||
@@ -236,16 +241,17 @@ def create_app(app_name=None):
|
||||
config.MASTER_PASSWORD_REQUIRED = False
|
||||
config.UPGRADE_CHECK_ENABLED = False
|
||||
|
||||
# Ensure the various working directories exist
|
||||
from pgadmin.setup import create_app_data_directory, db_upgrade
|
||||
create_app_data_directory(config)
|
||||
if not cli_mode:
|
||||
# Ensure the various working directories exist
|
||||
from pgadmin.setup import create_app_data_directory
|
||||
create_app_data_directory(config)
|
||||
|
||||
# File logging
|
||||
fh = logging.FileHandler(config.LOG_FILE, encoding='utf-8')
|
||||
fh.setLevel(config.FILE_LOG_LEVEL)
|
||||
fh.setFormatter(logging.Formatter(config.FILE_LOG_FORMAT))
|
||||
app.logger.addHandler(fh)
|
||||
logger.addHandler(fh)
|
||||
# File logging
|
||||
fh = logging.FileHandler(config.LOG_FILE, encoding='utf-8')
|
||||
fh.setLevel(config.FILE_LOG_LEVEL)
|
||||
fh.setFormatter(logging.Formatter(config.FILE_LOG_FORMAT))
|
||||
app.logger.addHandler(fh)
|
||||
logger.addHandler(fh)
|
||||
|
||||
# Console logging
|
||||
ch = logging.StreamHandler()
|
||||
@@ -320,11 +326,21 @@ def create_app(app_name=None):
|
||||
with app.app_context():
|
||||
# Run migration for the first time i.e. create database
|
||||
from config import SQLITE_PATH
|
||||
from pgadmin.setup import db_upgrade
|
||||
|
||||
# If version not available, user must have aborted. Tables are not
|
||||
# created and so its an empty db
|
||||
if not os.path.exists(SQLITE_PATH) or get_version() == -1:
|
||||
db_upgrade(app)
|
||||
# If running in cli mode then don't try to upgrade, just raise
|
||||
# the exception
|
||||
if not cli_mode:
|
||||
db_upgrade(app)
|
||||
else:
|
||||
if not os.path.exists(SQLITE_PATH):
|
||||
raise FileNotFoundError(
|
||||
'SQLite database file "' + SQLITE_PATH +
|
||||
'" does not exists.')
|
||||
raise Exception('Specified SQLite database file is not valid.')
|
||||
else:
|
||||
schema_version = get_version()
|
||||
|
||||
@@ -343,8 +359,10 @@ def create_app(app_name=None):
|
||||
|
||||
Mail(app)
|
||||
|
||||
import pgadmin.utils.paths as paths
|
||||
paths.init_app(app)
|
||||
# Don't bother paths when running in cli mode
|
||||
if not cli_mode:
|
||||
import pgadmin.utils.paths as paths
|
||||
paths.init_app(app)
|
||||
|
||||
# Setup Flask-Security
|
||||
user_datastore = SQLAlchemyUserDatastore(db, User, Role)
|
||||
@@ -382,9 +400,10 @@ def create_app(app_name=None):
|
||||
app.permanent_session_lifetime = timedelta(
|
||||
days=config.SESSION_EXPIRATION_TIME)
|
||||
|
||||
app.session_interface = create_session_interface(
|
||||
app, config.SESSION_SKIP_PATHS
|
||||
)
|
||||
if not cli_mode:
|
||||
app.session_interface = create_session_interface(
|
||||
app, config.SESSION_SKIP_PATHS
|
||||
)
|
||||
|
||||
# Make the Session more secure against XSS & CSRF when running in web mode
|
||||
if config.SERVER_MODE and config.ENHANCED_COOKIE_PROTECTION:
|
||||
|
||||
85
web/setup.py
85
web/setup.py
@@ -56,15 +56,25 @@ def dump_servers(args):
|
||||
Args:
|
||||
args (ArgParser): The parsed command line options
|
||||
"""
|
||||
app = create_app()
|
||||
|
||||
# What user?
|
||||
if args.user is not None:
|
||||
dump_user = args.user
|
||||
else:
|
||||
dump_user = config.DESKTOP_USER
|
||||
|
||||
# And the sqlite path
|
||||
if args.sqlite_path is not None:
|
||||
config.SQLITE_PATH = args.sqlite_path
|
||||
|
||||
print('----------')
|
||||
print('Dumping servers with:')
|
||||
print('User:', dump_user)
|
||||
print('SQLite pgAdmin config:', config.SQLITE_PATH)
|
||||
print('----------')
|
||||
|
||||
app = create_app(config.APP_NAME + '-cli')
|
||||
with app.app_context():
|
||||
|
||||
# What user?
|
||||
if args.user is not None:
|
||||
dump_user = args.user
|
||||
else:
|
||||
dump_user = config.DESKTOP_USER
|
||||
|
||||
user = User.query.filter_by(email=dump_user).first()
|
||||
|
||||
if user is None:
|
||||
@@ -150,6 +160,23 @@ def load_servers(args):
|
||||
Args:
|
||||
args (ArgParser): The parsed command line options
|
||||
"""
|
||||
|
||||
# What user?
|
||||
if args.user is not None:
|
||||
load_user = args.user
|
||||
else:
|
||||
load_user = config.DESKTOP_USER
|
||||
|
||||
# And the sqlite path
|
||||
if args.sqlite_path is not None:
|
||||
config.SQLITE_PATH = args.sqlite_path
|
||||
|
||||
print('----------')
|
||||
print('Loading servers with:')
|
||||
print('User:', load_user)
|
||||
print('SQLite pgAdmin config:', config.SQLITE_PATH)
|
||||
print('----------')
|
||||
|
||||
try:
|
||||
with open(args.load_servers) as f:
|
||||
data = json.load(f)
|
||||
@@ -164,20 +191,13 @@ def load_servers(args):
|
||||
|
||||
f.close()
|
||||
|
||||
app = create_app()
|
||||
app = create_app(config.APP_NAME + '-cli')
|
||||
with app.app_context():
|
||||
|
||||
# What user?
|
||||
if args.user is not None:
|
||||
dump_user = args.user
|
||||
else:
|
||||
dump_user = config.DESKTOP_USER
|
||||
|
||||
user = User.query.filter_by(email=dump_user).first()
|
||||
user = User.query.filter_by(email=load_user).first()
|
||||
|
||||
if user is None:
|
||||
print("The specified user ID (%s) could not be found." %
|
||||
dump_user)
|
||||
load_user)
|
||||
sys.exit(1)
|
||||
|
||||
user_id = user.id
|
||||
@@ -377,21 +397,26 @@ if __name__ == '__main__':
|
||||
|
||||
parser = argparse.ArgumentParser(description='Setup the pgAdmin config DB')
|
||||
|
||||
imp_exp_group = parser.add_mutually_exclusive_group(required=False)
|
||||
|
||||
exp_group = imp_exp_group.add_argument_group('Dump server config')
|
||||
exp_group = parser.add_argument_group('Dump server config')
|
||||
exp_group.add_argument('--dump-servers', metavar="OUTPUT_FILE",
|
||||
help='Dump the servers in the DB', required=False)
|
||||
exp_group.add_argument('--servers', metavar="SERVERS", nargs='*',
|
||||
help='One or more servers to dump', required=False)
|
||||
|
||||
imp_group = imp_exp_group.add_argument_group('Load server config')
|
||||
imp_group = parser.add_argument_group('Load server config')
|
||||
imp_group.add_argument('--load-servers', metavar="INPUT_FILE",
|
||||
help='Load servers into the DB', required=False)
|
||||
|
||||
imp_exp_group.add_argument('--user', metavar="USER_NAME",
|
||||
help='Dump/load servers for the specified '
|
||||
'username', required=False)
|
||||
# Common args
|
||||
parser.add_argument('--sqlite-path', metavar="PATH",
|
||||
help='Dump/load with the specified pgAdmin config DB'
|
||||
' file. This is particularly helpful when there'
|
||||
' are multiple pgAdmin configurations. It is also'
|
||||
' recommended to use this option when running'
|
||||
' pgAdmin in desktop mode.', required=False)
|
||||
parser.add_argument('--user', metavar="USER_NAME",
|
||||
help='Dump/load servers for the specified username',
|
||||
required=False)
|
||||
|
||||
args, extra = parser.parse_known_args()
|
||||
|
||||
@@ -402,8 +427,14 @@ if __name__ == '__main__':
|
||||
|
||||
# What to do?
|
||||
if args.dump_servers is not None:
|
||||
dump_servers(args)
|
||||
try:
|
||||
dump_servers(args)
|
||||
except Exception as e:
|
||||
print(str(e))
|
||||
elif args.load_servers is not None:
|
||||
load_servers(args)
|
||||
try:
|
||||
load_servers(args)
|
||||
except Exception as e:
|
||||
print(str(e))
|
||||
else:
|
||||
setup_db()
|
||||
|
||||
Reference in New Issue
Block a user