當前位置: 首頁>>代碼示例>>Python>>正文


Python Site.find_for_request方法代碼示例

本文整理匯總了Python中wagtail.core.models.Site.find_for_request方法的典型用法代碼示例。如果您正苦於以下問題:Python Site.find_for_request方法的具體用法?Python Site.find_for_request怎麽用?Python Site.find_for_request使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在wagtail.core.models.Site的用法示例。


在下文中一共展示了Site.find_for_request方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: get

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def get(self, request, *args, **kwargs):
        site = Site.find_for_request(request)
        if not site:
            raise Http404
        if request.resolver_match.url_name == 'entry_page_serve_slug':
            # Splitting the request path and obtaining the path_components
            # this way allows you to place the blog at the level you want on
            # your sitemap.
            # Example:
            # splited_path =  ['es', 'blog', '2016', '06', '23', 'blog-entry']
            # slicing this way you obtain:
            # path_components =  ['es', 'blog', 'blog-entry']
            # with the oldest solution you'll get ['es', 'blog-entry']
            # and a 404 will be raised
            splited_path = strip_prefix_and_ending_slash(request.path).split("/")
            path_components = splited_path[:-4] + splited_path[-1:]
        else:
            path_components = [strip_prefix_and_ending_slash(request.path).split('/')[-1]]
        page, args, kwargs = site.root_page.specific.route(request, path_components)

        for fn in hooks.get_hooks('before_serve_page'):
            result = fn(page, request, args, kwargs)
            if isinstance(result, HttpResponse):
                return result
        return page.serve(request, *args, **kwargs) 
開發者ID:APSL,項目名稱:puput,代碼行數:27,代碼來源:views.py

示例2: test_preview_uses_correct_site

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def test_preview_uses_correct_site(self):
        # create a Site record for the child page
        Site.objects.create(hostname='childpage.example.com', root_page=self.child_page)

        post_data = {
            'title': "I've been edited!",
            'content': "Some content",
            'slug': 'hello-world',
            'action-submit': "Submit",
        }
        preview_url = reverse('wagtailadmin_pages:preview_on_edit',
                              args=(self.child_page.id,))
        response = self.client.post(preview_url, post_data)

        # Check the JSON response
        self.assertEqual(response.status_code, 200)
        self.assertJSONEqual(response.content.decode(), {'is_valid': True})

        response = self.client.get(preview_url)

        # Check that the correct site object has been selected by the site middleware
        self.assertEqual(response.status_code, 200)
        self.assertTemplateUsed(response, 'tests/simple_page.html')
        self.assertEqual(Site.find_for_request(response.context['request']).hostname, 'childpage.example.com') 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:26,代碼來源:test_edit_page.py

示例3: get_base_queryset

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def get_base_queryset(self):
        """
        Returns a queryset containing all pages that can be seen by this user.

        This is used as the base for get_queryset and is also used to find the
        parent pages when using the child_of and descendant_of filters as well.
        """
        # Get live pages that are not in a private section
        queryset = Page.objects.all().public().live()

        # Filter by site
        site = Site.find_for_request(self.request)
        if site:
            queryset = queryset.descendant_of(site.root_page, inclusive=True)
        else:
            # No sites configured
            queryset = queryset.none()

        return queryset 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:21,代碼來源:views.py

示例4: get_base_url

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def get_base_url(request=None):
    base_url = None

    try:
        base_url = getattr(settings, 'WAGTAILAPI_BASE_URL')
    except AttributeError:
        if request:
            site = Site.find_for_request(request)
            if site:
                base_url = site.root_url

    if base_url:
        # We only want the scheme and netloc
        base_url_parsed = urlparse(base_url)

        return base_url_parsed.scheme + '://' + base_url_parsed.netloc 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:18,代碼來源:utils.py

示例5: routablepageurl

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def routablepageurl(context, page, url_name, *args, **kwargs):
    """
    ``routablepageurl`` is similar to ``pageurl``, but works with
    pages using ``RoutablePageMixin``. It behaves like a hybrid between the built-in
    ``reverse``, and ``pageurl`` from Wagtail.

    ``page`` is the RoutablePage that URLs will be generated from.

    ``url_name`` is a URL name defined in ``page.subpage_urls``.

    Positional arguments and keyword arguments should be passed as normal
    positional arguments and keyword arguments.
    """
    request = context['request']
    site = Site.find_for_request(request)
    base_url = page.relative_url(site, request)
    routed_url = page.reverse_subpage(url_name, args=args, kwargs=kwargs)
    if not base_url.endswith('/'):
        base_url += '/'
    return base_url + routed_url 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:22,代碼來源:wagtailroutablepage_tags.py

示例6: get_setting

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def get_setting(context, model_string, use_default_site=False):
    if use_default_site:
        site = Site.objects.get(is_default_site=True)
    elif 'request' in context:
        site = Site.find_for_request(context['request'])
    else:
        raise RuntimeError('No request found in context, and use_default_site '
                           'flag not set')

    # Sadly, WeakKeyDictionary can not implement __missing__, so we have to do
    # this one manually
    try:
        context_cache = settings_cache[context]
    except KeyError:
        context_cache = settings_cache[context] = ContextCache()
    # These ones all implement __missing__ in a useful way though
    return context_cache[site][model_string] 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:19,代碼來源:jinja2tags.py

示例7: test_models_cached

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def test_models_cached(self):
        """ Accessing a setting should only hit the DB once per request instance,
        even if using that request to rendering multiple times"""
        request = self.get_request()
        get_title = '{{ settings.tests.testsetting.title }}'

        # force site query beforehand
        Site.find_for_request(request)

        with self.assertNumQueries(1):
            for i in range(1, 4):
                with self.subTest(attempt=i):
                    self.assertEqual(
                        self.render(request, get_title * i),
                        self.default_site_settings.title * i
                    ) 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:18,代碼來源:test_templates.py

示例8: meta_tags

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def meta_tags(request, model):
    if not request:
        raise TemplateSyntaxError(
            "'meta_tags' missing request from context")
    if not model:
        raise TemplateSyntaxError(
            "'meta_tags' tag is missing a model or object")
    context = {
        'site_name': Site.find_for_request(request).site_name,
        'object': model,
    }

    meta_image = model.get_meta_image()
    if meta_image:
        meta_image = get_meta_image_url(request, meta_image)
    context['meta_image'] = meta_image

    return render_to_string('wagtailmetadata/parts/tags.html',
                            context, request=request) 
開發者ID:neon-jungle,項目名稱:wagtail-metadata,代碼行數:21,代碼來源:tags.py

示例9: item_link

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def item_link(self, item):
        from .urls import get_entry_url
        entry_url = get_entry_url(item, self.blog_page.page_ptr, Site.find_for_request(self.request).root_page)
        return self.request.build_absolute_uri(entry_url) 
開發者ID:APSL,項目名稱:puput,代碼行數:6,代碼來源:feeds.py

示例10: item_enclosure_url

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def item_enclosure_url(self, item):
        if item.header_image:
            site = Site.find_for_request(self.request)
            return urljoin(site.root_url, item.header_image.file.url)
        return None 
開發者ID:APSL,項目名稱:puput,代碼行數:7,代碼來源:feeds.py

示例11: _channel_image_link

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def _channel_image_link(self):
        if self.blog_page.header_image:
            site = Site.find_for_request(self.request)
            return urljoin(site.root_url, self.blog_page.header_image.file.url) 
開發者ID:APSL,項目名稱:puput,代碼行數:6,代碼來源:feeds.py

示例12: entry_url

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def entry_url(context, entry, blog_page):
    return get_entry_url(entry, blog_page.page_ptr, Site.find_for_request(context['request']).root_page) 
開發者ID:APSL,項目名稱:puput,代碼行數:4,代碼來源:puput_tags.py

示例13: setUp

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def setUp(self):
        self.shipping_address = AddressFactory()
        self.billing_address = AddressFactory()
        self.email = "test@test.com"
        self.request = RequestFactory().get('/')
        self.request.session = {}
        self.request.site = Site.find_for_request(self.request)
        self.basket_id = basket_id(self.request)
        BasketItemFactory(basket_id=self.basket_id) 
開發者ID:JamesRamm,項目名稱:longclaw,代碼行數:11,代碼來源:tests.py

示例14: dispatch

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def dispatch(self, request, *args, **kwargs):
        site = Site.find_for_request(request)
        return redirect(
            self.model_admin.url_helper.get_action_url('edit', site.pk)) 
開發者ID:rkhleics,項目名稱:wagtailmenus,代碼行數:6,代碼來源:views.py

示例15: get_site_from_request

# 需要導入模塊: from wagtail.core.models import Site [as 別名]
# 或者: from wagtail.core.models.Site import find_for_request [as 別名]
def get_site_from_request(request, fallback_to_default=True):
    site = getattr(request, 'site', None)
    if isinstance(site, Site):
        return request.site
    site = Site.find_for_request(request)
    if site:
        return site
    if fallback_to_default:
        return Site.objects.filter(is_default_site=True).first()
    return None 
開發者ID:rkhleics,項目名稱:wagtailmenus,代碼行數:12,代碼來源:misc.py


注:本文中的wagtail.core.models.Site.find_for_request方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。