44 lines
1.7 KiB
Python
44 lines
1.7 KiB
Python
# Copyright (C) 2014-2015 Andrey Antukh <niwi@niwi.be>
|
|
# Copyright (C) 2014-2015 Jesús Espino <jespinog@gmail.com>
|
|
# Copyright (C) 2014-2015 David Barragán <bameda@dbarragan.com>
|
|
# Copyright (C) 2014-2015 Anler Hernández <hello@anler.me>
|
|
# 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/>.
|
|
|
|
import django_sites as sites
|
|
from django.core.urlresolvers import reverse as django_reverse
|
|
|
|
URL_TEMPLATE = "{scheme}://{domain}/{path}"
|
|
|
|
|
|
def build_url(path, scheme="http", domain="localhost"):
|
|
return URL_TEMPLATE.format(scheme=scheme, domain=domain, path=path.lstrip("/"))
|
|
|
|
|
|
def is_absolute_url(path):
|
|
"""Test wether or not `path` is absolute url."""
|
|
return path.startswith("http")
|
|
|
|
|
|
def get_absolute_url(path):
|
|
"""Return a path as an absolute url."""
|
|
if is_absolute_url(path):
|
|
return path
|
|
site = sites.get_current()
|
|
return build_url(path, scheme=site.scheme, domain=site.domain)
|
|
|
|
|
|
def reverse(viewname, *args, **kwargs):
|
|
"""Same behavior as django's reverse but uses django_sites to compute absolute url."""
|
|
return get_absolute_url(django_reverse(viewname, *args, **kwargs))
|