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


Python ImagesByWikiPage.get_images方法代碼示例

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


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

示例1: valid_url

# 需要導入模塊: from r2.models.wiki import ImagesByWikiPage [as 別名]
# 或者: from r2.models.wiki.ImagesByWikiPage import get_images [as 別名]
def valid_url(prop, value, report, generate_https_urls):
    """Validate a URL in the stylesheet.

    The only valid URLs for use in a stylesheet are the custom image format
    (%%example%%) which this function will translate to actual URLs.

    """
    try:
        url = value.getStringValue()
    except IndexError:
        g.log.error("Problem validating [%r]" % value)
        raise

    m = custom_img_urls.match(url)
    if m:
        name = m.group(1)

        # this relies on localcache to not be doing a lot of lookups
        images = ImagesByWikiPage.get_images(c.site, "config/stylesheet")

        if name in images:
            if not generate_https_urls:
                url = images[name]
            else:
                url = g.media_provider.convert_to_https(images[name])
            value._setCssText("url(%s)" % url)
        else:
            # unknown image label -> error
            report.append(ValidationError(msgs["broken_url"] % dict(brokenurl=value.cssText), value))
    else:
        report.append(ValidationError(msgs["custom_images_only"], value))
開發者ID:tolgaek,項目名稱:reddit,代碼行數:33,代碼來源:cssfilter.py

示例2: images

# 需要導入模塊: from r2.models.wiki import ImagesByWikiPage [as 別名]
# 或者: from r2.models.wiki.ImagesByWikiPage import get_images [as 別名]
 def images(self):
     sr_images = ImagesByWikiPage.get_images(c.site, "config/stylesheet")
     images = []
     for name, url in sr_images.iteritems():
         images.append({'name': name,
                        'link': 'url(%%%%%s%%%%)' % name,
                        'url': url})
     return images
開發者ID:Dakta,項目名稱:reddit,代碼行數:10,代碼來源:jsontemplates.py

示例3: valid_url

# 需要導入模塊: from r2.models.wiki import ImagesByWikiPage [as 別名]
# 或者: from r2.models.wiki.ImagesByWikiPage import get_images [as 別名]
def valid_url(prop, value, report, generate_https_urls, enforce_custom_images_only):
    """
    checks url(...) arguments in CSS, ensuring that the contents are
    officially sanctioned.  Sanctioned urls include:
     * anything in /static/
     * image labels %%..%% for images uploaded on /about/stylesheet
     * urls with domains in g.allowed_css_linked_domains
    """
    try:
        url = value.getStringValue()
    except IndexError:
        g.log.error("Problem validating [%r]" % value)
        raise
    # local urls are allowed
    if local_urls.match(url):
        if enforce_custom_images_only:
            report.append(ValidationError(msgs["custom_images_only"], value))
            return

        t_url = None
        while url != t_url:
            t_url, url = url, filters.url_unescape(url)
        # disallow path trickery
        if "../" in url:
            report.append(ValidationError(msgs["broken_url"] % dict(brokenurl=value.cssText), value))
    # custom urls are allowed, but need to be transformed into a real path
    elif custom_img_urls.match(url):
        name = custom_img_urls.match(url).group(1)

        # this relies on localcache to not be doing a lot of lookups
        images = ImagesByWikiPage.get_images(c.site, "config/stylesheet")

        if name in images:
            if not generate_https_urls:
                url = images[name]
            else:
                url = s3_direct_https(images[name])
            value._setCssText("url(%s)" % url)
        else:
            # unknown image label -> error
            report.append(ValidationError(msgs["broken_url"] % dict(brokenurl=value.cssText), value))
    else:
        if enforce_custom_images_only:
            report.append(ValidationError(msgs["custom_images_only"], value))
            return

        try:
            u = urlparse(url)
            valid_scheme = u.scheme and u.scheme in valid_url_schemes
            valid_domain = u.netloc in g.allowed_css_linked_domains
        except ValueError:
            u = False

        # allowed domains are ok
        if not (u and valid_scheme and valid_domain):
            report.append(ValidationError(msgs["broken_url"] % dict(brokenurl=value.cssText), value))
開發者ID:andre-d,項目名稱:reddit,代碼行數:58,代碼來源:cssfilter.py

示例4: wikimarkdown

# 需要導入模塊: from r2.models.wiki import ImagesByWikiPage [as 別名]
# 或者: from r2.models.wiki.ImagesByWikiPage import get_images [as 別名]
def wikimarkdown(text, include_toc=True, target=None):
    from r2.lib.template_helpers import make_url_protocol_relative

    # this hard codes the stylesheet page for now, but should be parameterized
    # in the future to allow per-page images.
    from r2.models.wiki import ImagesByWikiPage
    from r2.lib.utils import UrlParser
    from r2.lib.template_helpers import add_sr
    page_images = ImagesByWikiPage.get_images(c.site, "config/stylesheet")
    
    def img_swap(tag):
        name = tag.get('src')
        name = custom_img_url.search(name)
        name = name and name.group(1)
        if name and name in page_images:
            url = page_images[name]
            url = make_url_protocol_relative(url)
            tag['src'] = url
        else:
            tag.extract()
    
    nofollow = True
    
    text = snudown.markdown(_force_utf8(text), nofollow, target,
                            renderer=snudown.RENDERER_WIKI)
    
    # TODO: We should test how much of a load this adds to the app
    soup = BeautifulSoup(text.decode('utf-8'))
    images = soup.findAll('img')
    
    if images:
        [img_swap(image) for image in images]

    def add_ext_to_link(link):
        url = UrlParser(link.get('href'))
        if url.is_reddit_url():
            link['href'] = add_sr(link.get('href'), sr_path=False)

    if c.render_style == 'compact':
        links = soup.findAll('a')
        [add_ext_to_link(a) for a in links]

    if include_toc:
        tocdiv = generate_table_of_contents(soup, prefix="wiki")
        if tocdiv:
            soup.insert(0, tocdiv)
    
    text = str(soup)
    
    return SC_OFF + WIKI_MD_START + text + WIKI_MD_END + SC_ON
開發者ID:pra85,項目名稱:reddit,代碼行數:52,代碼來源:filters.py

示例5: wikimarkdown

# 需要導入模塊: from r2.models.wiki import ImagesByWikiPage [as 別名]
# 或者: from r2.models.wiki.ImagesByWikiPage import get_images [as 別名]
def wikimarkdown(text, include_toc=True, target=None):
    from r2.lib.template_helpers import media_https_if_secure

    # this hard codes the stylesheet page for now, but should be parameterized
    # in the future to allow per-page images.
    from r2.models.wiki import ImagesByWikiPage
    page_images = ImagesByWikiPage.get_images(c.site, "config/stylesheet")
    
    def img_swap(tag):
        name = tag.get('src')
        name = custom_img_url.search(name)
        name = name and name.group(1)
        if name and name in page_images:
            url = page_images[name]
            url = media_https_if_secure(url)
            tag['src'] = url
        else:
            tag.extract()
    
    nofollow = True
    
    text = snudown.markdown(_force_utf8(text), nofollow, target,
                            renderer=snudown.RENDERER_WIKI)
    
    # TODO: We should test how much of a load this adds to the app
    soup = BeautifulSoup(text.decode('utf-8'))
    images = soup.findAll('img')
    
    if images:
        [img_swap(image) for image in images]
    
    if include_toc:
        tocdiv = generate_table_of_contents(soup, prefix="wiki")
        if tocdiv:
            soup.insert(0, tocdiv)
    
    text = str(soup)
    
    return SC_OFF + WIKI_MD_START + text + WIKI_MD_END + SC_ON
開發者ID:Acceto,項目名稱:reddit,代碼行數:41,代碼來源:filters.py

示例6: images

# 需要導入模塊: from r2.models.wiki import ImagesByWikiPage [as 別名]
# 或者: from r2.models.wiki.ImagesByWikiPage import get_images [as 別名]
 def images(self):
     sr_images = ImagesByWikiPage.get_images(c.site, "config/stylesheet")
     images = []
     for name, url in sr_images.iteritems():
         images.append({"name": name, "link": "url(%%%%%s%%%%)" % name, "url": url})
     return images
開發者ID:JingyanZ,項目名稱:reddit,代碼行數:8,代碼來源:jsontemplates.py


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