navigation.py
142 lines
| 5.3 KiB
| text/x-python
|
PythonLexer
r1503 | # -*- coding: utf-8 -*- | |||
# Copyright (C) 2016-2017 RhodeCode GmbH | ||||
# | ||||
# 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/ | ||||
import logging | ||||
import collections | ||||
from pylons import url | ||||
from zope.interface import implementer | ||||
from rhodecode.apps.admin.interfaces import IAdminNavigationRegistry | ||||
from rhodecode.lib.utils import get_registry | ||||
from rhodecode.translation import _ | ||||
log = logging.getLogger(__name__) | ||||
NavListEntry = collections.namedtuple('NavListEntry', ['key', 'name', 'url']) | ||||
class NavEntry(object): | ||||
""" | ||||
Represents an entry in the admin navigation. | ||||
:param key: Unique identifier used to store reference in an OrderedDict. | ||||
:param name: Display name, usually a translation string. | ||||
:param view_name: Name of the view, used generate the URL. | ||||
:param pyramid: Indicator to use pyramid for URL generation. This should | ||||
be removed as soon as we are fully migrated to pyramid. | ||||
""" | ||||
def __init__(self, key, name, view_name, pyramid=False): | ||||
self.key = key | ||||
self.name = name | ||||
self.view_name = view_name | ||||
self.pyramid = pyramid | ||||
def generate_url(self, request): | ||||
if self.pyramid: | ||||
if hasattr(request, 'route_path'): | ||||
return request.route_path(self.view_name) | ||||
else: | ||||
# TODO: johbo: Remove this after migrating to pyramid. | ||||
# We need the pyramid request here to generate URLs to pyramid | ||||
# views from within pylons views. | ||||
from pyramid.threadlocal import get_current_request | ||||
pyramid_request = get_current_request() | ||||
return pyramid_request.route_path(self.view_name) | ||||
else: | ||||
return url(self.view_name) | ||||
def get_localized_name(self, request): | ||||
if hasattr(request, 'translate'): | ||||
return request.translate(self.name) | ||||
else: | ||||
# TODO(marcink): Remove this after migrating to pyramid | ||||
from pyramid.threadlocal import get_current_request | ||||
pyramid_request = get_current_request() | ||||
return pyramid_request.translate(self.name) | ||||
@implementer(IAdminNavigationRegistry) | ||||
class NavigationRegistry(object): | ||||
_base_entries = [ | ||||
NavEntry('global', _('Global'), 'admin_settings_global'), | ||||
NavEntry('vcs', _('VCS'), 'admin_settings_vcs'), | ||||
NavEntry('visual', _('Visual'), 'admin_settings_visual'), | ||||
NavEntry('mapping', _('Remap and Rescan'), 'admin_settings_mapping'), | ||||
NavEntry('issuetracker', _('Issue Tracker'), | ||||
'admin_settings_issuetracker'), | ||||
NavEntry('email', _('Email'), 'admin_settings_email'), | ||||
NavEntry('hooks', _('Hooks'), 'admin_settings_hooks'), | ||||
NavEntry('search', _('Full Text Search'), 'admin_settings_search'), | ||||
NavEntry('integrations', _('Integrations'), | ||||
'global_integrations_home', pyramid=True), | ||||
NavEntry('system', _('System Info'), | ||||
'admin_settings_system', pyramid=True), | ||||
r1885 | NavEntry('process_management', _('Processes'), | |||
'admin_settings_process_management', pyramid=True), | ||||
r1503 | NavEntry('sessions', _('User Sessions'), | |||
'admin_settings_sessions', pyramid=True), | ||||
NavEntry('open_source', _('Open Source Licenses'), | ||||
'admin_settings_open_source', pyramid=True), | ||||
# TODO: marcink: we disable supervisor now until the supervisor stats | ||||
# page is fixed in the nix configuration | ||||
# NavEntry('supervisor', _('Supervisor'), 'admin_settings_supervisor'), | ||||
] | ||||
_labs_entry = NavEntry('labs', _('Labs'), 'admin_settings_labs') | ||||
def __init__(self, labs_active=False): | ||||
self._registered_entries = collections.OrderedDict([ | ||||
(item.key, item) for item in self.__class__._base_entries | ||||
]) | ||||
if labs_active: | ||||
self.add_entry(self._labs_entry) | ||||
def add_entry(self, entry): | ||||
self._registered_entries[entry.key] = entry | ||||
def get_navlist(self, request): | ||||
navlist = [NavListEntry(i.key, i.get_localized_name(request), | ||||
i.generate_url(request)) | ||||
for i in self._registered_entries.values()] | ||||
return navlist | ||||
def navigation_registry(request): | ||||
""" | ||||
Helper that returns the admin navigation registry. | ||||
""" | ||||
pyramid_registry = get_registry(request) | ||||
nav_registry = pyramid_registry.queryUtility(IAdminNavigationRegistry) | ||||
return nav_registry | ||||
def navigation_list(request): | ||||
""" | ||||
Helper that returns the admin navigation as list of NavListEntry objects. | ||||
""" | ||||
return navigation_registry(request).get_navlist(request) | ||||