Move the general applicaiton setup commands to a utility module
This commit is contained in:
parent
dbb92c6020
commit
8820121ad1
@ -16,7 +16,7 @@
|
|||||||
|
|
||||||
import argparse
|
import argparse
|
||||||
|
|
||||||
from mediagoblin import util
|
from mediagoblin import util as mg_util
|
||||||
|
|
||||||
|
|
||||||
SUBCOMMAND_MAP = {
|
SUBCOMMAND_MAP = {
|
||||||
@ -39,8 +39,8 @@ def main_cli():
|
|||||||
else:
|
else:
|
||||||
subparser = subparsers.add_parser(command_name)
|
subparser = subparsers.add_parser(command_name)
|
||||||
|
|
||||||
setup_func = util.import_component(command_struct['setup'])
|
setup_func = mg_util.import_component(command_struct['setup'])
|
||||||
exec_func = util.import_component(command_struct['func'])
|
exec_func = mg_util.import_component(command_struct['func'])
|
||||||
|
|
||||||
setup_func(subparser)
|
setup_func(subparser)
|
||||||
|
|
||||||
|
@ -16,12 +16,9 @@
|
|||||||
|
|
||||||
|
|
||||||
import code
|
import code
|
||||||
import os
|
|
||||||
|
|
||||||
from paste.deploy.loadwsgi import NicerConfigParser
|
|
||||||
|
|
||||||
from mediagoblin import app
|
|
||||||
from mediagoblin import globals as mgoblin_globals
|
from mediagoblin import globals as mgoblin_globals
|
||||||
|
from mediagoblin.gmg_commands import util as commands_util
|
||||||
|
|
||||||
|
|
||||||
def shell_parser_setup(subparser):
|
def shell_parser_setup(subparser):
|
||||||
@ -45,22 +42,9 @@ Available vars:
|
|||||||
|
|
||||||
def shell(args):
|
def shell(args):
|
||||||
"""
|
"""
|
||||||
|
Setup a shell for the user
|
||||||
"""
|
"""
|
||||||
# Duplicated from from_celery.py, remove when we have the generic util
|
mgoblin_app = commands_util.setup_app(args)
|
||||||
parser = NicerConfigParser(args.conf_file)
|
|
||||||
parser.read(args.conf_file)
|
|
||||||
parser._defaults.setdefault(
|
|
||||||
'here', os.path.dirname(os.path.abspath(args.conf_file)))
|
|
||||||
parser._defaults.setdefault(
|
|
||||||
'__file__', os.path.abspath(args.conf_file))
|
|
||||||
|
|
||||||
mgoblin_section = dict(parser.items(args.app_section))
|
|
||||||
mgoblin_conf = dict(
|
|
||||||
[(section_name, dict(parser.items(section_name)))
|
|
||||||
for section_name in parser.sections()])
|
|
||||||
|
|
||||||
mgoblin_app = app.paste_app_factory(
|
|
||||||
mgoblin_conf, **mgoblin_section)
|
|
||||||
|
|
||||||
code.interact(
|
code.interact(
|
||||||
banner=SHELL_BANNER,
|
banner=SHELL_BANNER,
|
||||||
|
45
mediagoblin/gmg_commands/util.py
Normal file
45
mediagoblin/gmg_commands/util.py
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
# GNU MediaGoblin -- federated, autonomous media hosting
|
||||||
|
# Copyright (C) 2011 Free Software Foundation, Inc
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU Affero General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU Affero General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU Affero General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
|
||||||
|
import os
|
||||||
|
|
||||||
|
from paste.deploy.loadwsgi import NicerConfigParser
|
||||||
|
|
||||||
|
from mediagoblin import app
|
||||||
|
|
||||||
|
|
||||||
|
def setup_app(args):
|
||||||
|
"""
|
||||||
|
Setup the application after reading the mediagoblin config files
|
||||||
|
"""
|
||||||
|
# Duplicated from from_celery.py, remove when we have the generic util
|
||||||
|
parser = NicerConfigParser(args.conf_file)
|
||||||
|
parser.read(args.conf_file)
|
||||||
|
parser._defaults.setdefault(
|
||||||
|
'here', os.path.dirname(os.path.abspath(args.conf_file)))
|
||||||
|
parser._defaults.setdefault(
|
||||||
|
'__file__', os.path.abspath(args.conf_file))
|
||||||
|
|
||||||
|
mgoblin_section = dict(parser.items(args.app_section))
|
||||||
|
mgoblin_conf = dict(
|
||||||
|
[(section_name, dict(parser.items(section_name)))
|
||||||
|
for section_name in parser.sections()])
|
||||||
|
|
||||||
|
mgoblin_app = app.paste_app_factory(
|
||||||
|
mgoblin_conf, **mgoblin_section)
|
||||||
|
|
||||||
|
return mgoblin_app
|
Loading…
x
Reference in New Issue
Block a user