aboutsummaryrefslogtreecommitdiffstats
path: root/mediagoblin/gmg_commands/shell.py
diff options
context:
space:
mode:
Diffstat (limited to 'mediagoblin/gmg_commands/shell.py')
-rw-r--r--mediagoblin/gmg_commands/shell.py58
1 files changed, 39 insertions, 19 deletions
diff --git a/mediagoblin/gmg_commands/shell.py b/mediagoblin/gmg_commands/shell.py
index 4998acd7..4d3ec241 100644
--- a/mediagoblin/gmg_commands/shell.py
+++ b/mediagoblin/gmg_commands/shell.py
@@ -20,6 +20,8 @@ import code
from mediagoblin import mg_globals
from mediagoblin.gmg_commands import util as commands_util
+from mediagoblin.tools.transition import DISABLE_GLOBALS
+
def shell_parser_setup(subparser):
subparser.add_argument(
@@ -27,14 +29,23 @@ def shell_parser_setup(subparser):
action="store_true")
-SHELL_BANNER = """\
-GNU MediaGoblin shell!
-----------------------
-Available vars:
- - mgoblin_app: instantiated mediagoblin application
- - mg_globals: mediagoblin.globals
- - db: database instance
-"""
+if DISABLE_GLOBALS:
+ SHELL_BANNER = (
+ "GNU MediaGoblin shell!\n"
+ "----------------------\n"
+ "Available vars:\n"
+ " - app: instantiated mediagoblin application\n"
+ " - db: database session\n"
+ " - ctx: context object\n")
+else:
+ SHELL_BANNER = (
+ "GNU MediaGoblin shell!\n"
+ "----------------------\n"
+ "Available vars:\n"
+ " - app: instantiated mediagoblin application\n"
+ " - mg_globals: mediagoblin.globals\n"
+ " - db: database instance\n"
+ " - ctx: context object\n")
def py_shell(**user_namespace):
"""
@@ -59,18 +70,27 @@ def ipython_shell(**user_namespace):
user_ns=user_namespace)
return True
+
def shell(args):
"""
Setup a shell for the user either a normal Python shell or an IPython one
"""
- user_namespace = {
- 'mg_globals': mg_globals,
- 'mgoblin_app': commands_util.setup_app(args),
- 'db': mg_globals.database}
-
- if args.ipython:
- ipython_shell(**user_namespace)
- else:
- # Try ipython_shell first and fall back if not available
- if not ipython_shell(**user_namespace):
- py_shell(**user_namespace)
+ app = commands_util.setup_app(args)
+
+ def run_shell(db, ctx):
+ user_namespace = {
+ 'mg_globals': mg_globals,
+ 'app': app,
+ 'db': db,
+ "ctx": ctx}
+
+ if args.ipython:
+ ipython_shell(**user_namespace)
+ else:
+ # Try ipython_shell first and fall back if not available
+ if not ipython_shell(**user_namespace):
+ py_shell(**user_namespace)
+
+ with app.gen_context() as ctx:
+ db = ctx.db
+ run_shell(db, ctx)