##// END OF EJS Templates
settings: re-use attached request global config for performance...
settings: re-use attached request global config for performance - since we *always* generate a global config and register it into request make use of it, and not rely on the get_all_settings heavy logic that makes it slow to fetch because of cache checks. Within single request we're fine to re-use it when ever request attribute is available

File last commit:

r3363:f08e98b1 default
r4200:007322e6 stable
Show More
ishell.py
80 lines | 2.3 KiB | text/x-python | PythonLexer
project: added all source files and assets
r1 # -*- coding: utf-8 -*-
docs: updated copyrights to 2019
r3363 # Copyright (C) 2013-2019 RhodeCode GmbH
project: added all source files and assets
r1 #
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License, version 3
# (only), as published by the Free Software Foundation.
#
# 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 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/>.
#
# This program is dual-licensed. If you wish to learn more about the
# RhodeCode Enterprise Edition, including its added features, Support services,
# and proprietary license terms, please see https://rhodecode.com/licenses/
"""
interactive shell paster command for RhodeCode
"""
import os
import sys
import logging
pylons: deprecate certain pylons paster command
r2356 from rhodecode.lib.paster_commands import BasePasterCommand
project: added all source files and assets
r1
# fix rhodecode import
from os.path import dirname as dn
rc_path = dn(dn(dn(os.path.realpath(__file__))))
sys.path.append(rc_path)
log = logging.getLogger(__name__)
ishell: updated code with latest ishell changes.
r1241 welcome_banner = """Welcome to RhodeCode iShell.
Type `exit` to exit the shell.
iShell is interactive shell to interact directly with the
internal RhodeCode APIs. You can rescue your lost password,
or reset some user/system settings.
"""
project: added all source files and assets
r1
class Command(BasePasterCommand):
max_args = 1
min_args = 1
usage = "CONFIG_FILE"
group_name = "RhodeCode"
takes_config_file = -1
parser = BasePasterCommand.standard_parser(verbose=True)
summary = "Interactive shell"
def command(self):
#get SqlAlchemy session
self._init_session()
# imports, used in ipython shell
import os
import sys
import time
import shutil
import datetime
from rhodecode.model.db import *
try:
from IPython import embed
ishell: updated code with latest ishell changes.
r1241 from traitlets.config import Config
project: added all source files and assets
r1 cfg = Config()
cfg.InteractiveShellEmbed.confirm_exit = False
ishell: updated code with latest ishell changes.
r1241 embed(config=cfg, banner1=welcome_banner)
project: added all source files and assets
r1 except ImportError:
ishell: updated code with latest ishell changes.
r1241 print('ipython installation required for ishell')
project: added all source files and assets
r1 sys.exit(-1)
def update_parser(self):
pass