Add an initial "gmg serve" implementation.
The CLI is similar to "paster serve".
This commit is contained in:
parent
f3c1b6ff6d
commit
051c728c6e
@ -59,6 +59,10 @@ SUBCOMMAND_MAP = {
|
||||
'setup': 'mediagoblin.gmg_commands.deletemedia:parser_setup',
|
||||
'func': 'mediagoblin.gmg_commands.deletemedia:deletemedia',
|
||||
'help': 'Delete media entries'},
|
||||
'serve': {
|
||||
'setup': 'mediagoblin.gmg_commands.serve:parser_setup',
|
||||
'func': 'mediagoblin.gmg_commands.serve:serve',
|
||||
'help': 'PasteScript replacement'},
|
||||
# 'theme': {
|
||||
# 'setup': 'mediagoblin.gmg_commands.theme:theme_parser_setup',
|
||||
# 'func': 'mediagoblin.gmg_commands.theme:theme',
|
||||
|
63
mediagoblin/gmg_commands/serve.py
Normal file
63
mediagoblin/gmg_commands/serve.py
Normal file
@ -0,0 +1,63 @@
|
||||
# GNU MediaGoblin -- federated, autonomous media hosting
|
||||
# Copyright (C) 2011, 2012 MediaGoblin contributors. See AUTHORS.
|
||||
#
|
||||
# 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/>.
|
||||
|
||||
from __future__ import print_function
|
||||
|
||||
|
||||
class ServeCommand(object):
|
||||
|
||||
def loadserver(self, server_spec, name, relative_to, **kw):
|
||||
pass
|
||||
|
||||
def loadapp(self, app_spec, name, relative_to, **kw):
|
||||
pass
|
||||
|
||||
def daemonize(self):
|
||||
# TODO: pass to gunicorn if available
|
||||
pass
|
||||
|
||||
def restart_with_reloader(self):
|
||||
pass
|
||||
|
||||
def restart_with_monitor(self, reloader=False):
|
||||
pass
|
||||
|
||||
def run(self):
|
||||
print('Running...')
|
||||
|
||||
|
||||
def parser_setup(subparser):
|
||||
subparser.add_argument('config', metavar='CONFIG_FILE')
|
||||
subparser.add_argument('command',
|
||||
choices=['start', 'stop', 'restart', 'status'],
|
||||
nargs='?', default='start')
|
||||
subparser.add_argument('-n', '--app-name',
|
||||
dest='app_name',
|
||||
metavar='NAME',
|
||||
help="Load the named application (default main)")
|
||||
subparser.add_argument('-s', '--server',
|
||||
dest='server',
|
||||
metavar='SERVER_TYPE',
|
||||
help="Use the named server.")
|
||||
subparser.add_argument('--reload',
|
||||
dest='reload',
|
||||
action='store_true',
|
||||
help="Use auto-restart file monitor")
|
||||
|
||||
|
||||
def serve(args):
|
||||
serve_cmd = ServeCommand() # TODO: pass args to it
|
||||
serve_cmd.run()
|
Loading…
x
Reference in New Issue
Block a user