##// END OF EJS Templates
hovercards: allow hovercards on parsed !PR patterns....
hovercards: allow hovercards on parsed !PR patterns. - in addition expose server info so we can generate fully qualified urls.

File last commit:

r3363:f08e98b1 default
r4046:a792f9c3 default
Show More
routing_links.py
106 lines | 3.9 KiB | text/x-python | PythonLexer
# -*- coding: utf-8 -*-
# Copyright (C) 2010-2019 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/
"""
Single source for redirection links.
Goal of this module is to provide a single source of truth regarding external
links. The data inside this module is used to configure the routing
system of Enterprise and it is used also as a base to check if this data
and our server configuration are in sync.
.. py:data:: link_config
Contains the configuration for external links. Each item is supposed to be
a `dict` like this example::
{"name": "url_name",
"target": "https://rhodecode.com/r1/enterprise/keyword/",
"external_target": "https://example.com/some-page.html",
}
then you can retrieve the url by simply calling the URL function:
`h.route_path('url_name')`
The redirection must be first implemented in our servers before
you can see it working.
"""
# pragma: no cover
from __future__ import unicode_literals
link_config = [
{
"name": "enterprise_docs",
"target": "https://rhodecode.com/r1/enterprise/docs/",
"external_target": "https://docs.rhodecode.com/RhodeCode-Enterprise/",
},
{
"name": "enterprise_log_file_locations",
"target": "https://rhodecode.com/r1/enterprise/docs/admin-system-overview/",
"external_target": "https://docs.rhodecode.com/RhodeCode-Enterprise/admin/system-overview.html#log-files",
},
{
"name": "enterprise_issue_tracker_settings",
"target": "https://rhodecode.com/r1/enterprise/docs/issue-trackers-overview/",
"external_target": "https://docs.rhodecode.com/RhodeCode-Enterprise/issue-trackers/issue-trackers.html",
},
{
"name": "enterprise_svn_setup",
"target": "https://rhodecode.com/r1/enterprise/docs/svn-setup/",
"external_target": "https://docs.rhodecode.com/RhodeCode-Enterprise/admin/svn-http.html",
},
{
"name": "enterprise_license_convert_from_old",
"target": "https://rhodecode.com/r1/enterprise/convert-license/",
"external_target": "https://rhodecode.com/u/license-upgrade",
},
{
"name": "rst_help",
"target": "http://docutils.sourceforge.net/docs/user/rst/quickref.html",
"external_target": "http://docutils.sourceforge.net/docs/user/rst/quickref.html",
},
{
"name": "markdown_help",
"target": "https://daringfireball.net/projects/markdown/syntax",
"external_target": "https://daringfireball.net/projects/markdown/syntax",
},
{
"name": "rhodecode_official",
"target": "https://rhodecode.com",
"external_target": "https://rhodecode.com/",
},
{
"name": "rhodecode_support",
"target": "https://rhodecode.com/help/",
"external_target": "https://rhodecode.com/support",
},
{
"name": "rhodecode_translations",
"target": "https://rhodecode.com/translate/enterprise",
"external_target": "https://www.transifex.com/rhodecode/RhodeCode/",
},
]
def connect_redirection_links(config):
for link in link_config:
config.add_route(link['name'], link['target'], static=True)