2022-02-14 00:43:48 -06:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
##########################################################################
|
|
|
|
#
|
|
|
|
# pgAdmin 4 - PostgreSQL Tools
|
|
|
|
#
|
2024-12-31 23:56:42 -06:00
|
|
|
# Copyright (C) 2013 - 2025, The pgAdmin Development Team
|
2022-02-14 00:43:48 -06:00
|
|
|
# This software is released under the PostgreSQL Licence
|
|
|
|
#
|
|
|
|
##########################################################################
|
|
|
|
|
|
|
|
import argparse
|
|
|
|
import os
|
2022-06-22 09:17:48 -05:00
|
|
|
import sys
|
2022-02-14 00:43:48 -06:00
|
|
|
|
2022-06-22 10:28:57 -05:00
|
|
|
|
2022-02-14 00:43:48 -06:00
|
|
|
def load_providers():
|
|
|
|
""" Loads all the providers """
|
|
|
|
providers = {}
|
|
|
|
|
|
|
|
path = os.path.dirname(os.path.realpath(__file__))
|
|
|
|
modules = os.listdir(path + '/providers')
|
2022-06-22 09:17:48 -05:00
|
|
|
sys.path.append(path)
|
2022-02-14 00:43:48 -06:00
|
|
|
for filename in modules:
|
|
|
|
filename = path + '/providers/' + filename
|
|
|
|
|
|
|
|
if os.path.isfile(filename):
|
|
|
|
basename = os.path.basename(filename)
|
2024-01-24 07:03:43 -06:00
|
|
|
_, extension = os.path.splitext(basename)
|
2022-02-14 00:43:48 -06:00
|
|
|
|
|
|
|
if extension == ".py" and not basename.startswith("_"):
|
|
|
|
module = __import__("providers." + basename[:-3],
|
|
|
|
fromlist=["providers"])
|
|
|
|
provider = module.load()
|
|
|
|
providers[basename[:-3]] = provider
|
|
|
|
|
|
|
|
return providers
|
|
|
|
|
|
|
|
|
|
|
|
def get_args(providers):
|
|
|
|
""" Creates the parsers and returns the args """
|
|
|
|
# Create the top-level parser
|
|
|
|
parser = argparse.ArgumentParser(prog='pgacloud.py')
|
|
|
|
|
|
|
|
# Create the provider sub-parser
|
|
|
|
parsers = parser.add_subparsers(help='provider help', dest='provider')
|
|
|
|
|
|
|
|
# Load the provider parsers
|
|
|
|
for provider in providers:
|
|
|
|
providers[provider].init_args(parsers)
|
|
|
|
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
return parser, args
|
|
|
|
|
|
|
|
|
|
|
|
def execute_command(providers, parser, args):
|
|
|
|
""" Executes the command in the provider """
|
|
|
|
|
|
|
|
# Switch - for _ in command names. We use - in the CLI syntax for ease of
|
|
|
|
# use, but we need an _ in Python function names
|
|
|
|
if 'command' in args and args.command is not None:
|
|
|
|
args.command = args.command.replace('-', '_')
|
|
|
|
|
|
|
|
# Figure out what provider the command was for (if any) and call the
|
|
|
|
# relevant function. If we don't get a match, print the help
|
|
|
|
if args.provider in providers and \
|
|
|
|
'command' in args and \
|
|
|
|
args.command is not None:
|
|
|
|
command = providers[args.provider].commands()[args.command]
|
|
|
|
command(args)
|
|
|
|
else:
|
|
|
|
# If no provider has been given, display the top level help,
|
|
|
|
# otherwise, call the help() method in the provider
|
|
|
|
if args.provider is None:
|
|
|
|
parser.print_help()
|
|
|
|
else:
|
|
|
|
command = providers[args.provider].commands()['help']
|
|
|
|
command()
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
""" Entry point """
|
|
|
|
# Load the providers
|
|
|
|
providers = load_providers()
|
|
|
|
|
|
|
|
# Get the args
|
|
|
|
parser, args = get_args(providers)
|
|
|
|
|
|
|
|
# Execute the command
|
|
|
|
execute_command(providers, parser, args)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|