Exemple #1
0
def archive(request, year=None, month=None):
    """
    Display post archive.
    :param year: the year to filter by or `None`
    :param month: the month to filter by (requires `year` set) or `None`
    """
    posts = Page.filter(isblog=True)

    if year is None:
        years = {}
        for post in posts:
            _year = years.setdefault(post.creation_time.year,
                                     Year(post.creation_time.year))
            _year.add_month(post.creation_time.month)
        return render(settings.TEMPLATE_OVERVIEW_ARCHIVE, 'archive', {
            'years' : sorted(years.values(), reverse=True),
        })
    else:
        year = int(year)
    if month is not None:
        month = int(month)

    years = set([p.creation_time.year for p in posts])
    posts = posts.filter(creation_time__year=year)
    months = None
    if month:
        months = set([p.creation_time.month for p in posts])
        posts = posts.filter(creation_time__month=month)
    return render(settings.TEMPLATE_ARCHIVE, 'archive', {
        'items' : posts,
        'year' : year,
        'years' : years,
        'month' : month or '',
        'months' : months,
    })
Exemple #2
0
def single_page(request, single):
    """ Display single page having slug `single` or raise 404 """
    page = get_object_or_404(Page.filter(url=single, isblog=False))
    return render(settings.TEMPLATE_PAGE, single, {
        'items' : (page,)
        #'comment_url' : urlreverse('comment', kwargs = {'single' : single}),
    })
Exemple #3
0
def search(request, keywords=None, sep=' '):
    """ Search for `keywords` in `Page` titles and `contents` """
    if keywords is None:
        keywords = request.GET.get('keywords')
        # prefer GET to POST
        if keywords is None:
            keywords = request.POST.get('keywords')
            if not keywords:
                # no (NOT EVEN A LITTLE BIT!!!!!!!1111!!1) input
                return HttpResponseRedirect(urlreverse(home))
    assert(isinstance(keywords, basestring))
    if not re.match('[a-zA-Z]', keywords):
        return HttpResponseRedirect(urlreverse(home))
    keywords = kewwords.strip().strip(',')
    if not keywords:
        return HttpResponseRedirect(urlreverse(home))

    results = SortedDefaultDict(int)
    keywords = keywords.split(sep)

    for keyword in keywords:
        for obj in Page.filter(title__contains=keyword):
            results[obj] += 5
        for obj in Page.filter(text__contains=keyword):
            results[obj] += obj.text.lower().count(keyword.lower())
    results.sort_by_values(reverse=True)

    return render(settings.TEMPLATE_SEARCH, 'search', parameters={
        'keywords': keywords, 'results': results
    })
Exemple #4
0
def single_post(request, single):
    """ Display single blog entry having slug `single` or raise 404 """
    post = get_object_or_404(Page, url=single, isblog=True)
    return render(settings.TEMPLATE_BLOG, single, {
        'items' : (post,),
        'comment_url' : urlreverse('comment', kwargs = {'single' : single}),
        'comments' : post.comment_set.all().filter(public=True),
    })
Exemple #5
0
def popular_pages(request, isblog=False):
    """
    Display popular pages.
    :param isblog: `True` if only blog entries should be displayed
    """
    template = isblog and settings.TEMPLATE_BLOG or settings.TEMPLATE_PAGE
    return render(template, None, {
        'items' : Page.filter(isblog=isblog, popular=True),
        'isblog': isblog,
    })
Exemple #6
0
def blog_pages(request, page=1, home=False):
    """
        Display blog entries using pagination.
        @param page: the current page's index
        @param home: (template-specific) `True` if using this for
                     displaying the "home" site.
    """
    posts = Page.filter(isblog=True).order_by('-creation_time')
    return render(settings.TEMPLATE_BLOG, ('pages', 'home')[home], {
        'items' : posts,
        'home' : home,
    }, True, int(page))
Exemple #7
0
def _feed(request, posts, n=20, show_summary=False, show_content=True):
    """ Display news feed, chosen by `type` """
    posts = posts.order_by('-edit_time')
    if posts:
        pubdate = posts.latest(field_name='creation_time').creation_time
    else:
        pubdate = None
    return render(settings.TEMPLATE_FEED, None, {
        'items' : posts[:n],
        'pubdate' : pubdate,
        'show_summary' : show_summary,
        'show_content' : show_content,
        'REQUEST_PATH' : request.path.lstrip('/')
    }, mimetype='application/xml')
Exemple #8
0
def comment(request, single):
    """
    Add a comment to a Post having slug `single` (raises 404 of Post
    does not exist).
    """
    is_spam = False
    # blacklist checks:
    if request.META['REMOTE_ADDR'] in IP_BLACKLIST:
        return responses.HttpNotAcceptable("""
            Deine IP-Adresse ist auf einer Blacklist, weil von dieser
            in Vergangenheit massiv gespammt wurde. Bitte kontaktiere
            mich, falls du dich zu Unrecht blockiert fühlst.
        """)
    elif request.method == 'POST':
        name = request.POST['name']
        text = request.POST['text']

        lower_text = text.lower()
        lower_name = name.lower()

        for word in WORD_BLACKLIST:
            if word in lower_name or word in lower_text:
                return responses.HttpNotAcceptable(_("The the word '%s' is "
                    "blacklisted. Please avoid it in your comments.") % word)
        public = True

        if not name or not text:
            return render(settings.TEMPLATE_BLOG, single, {
                'items' : [get_object_or_404(Page, url=single)],
                'error' : _('Please fill out all fields!'),
            })
        comment = Comment()
        comment.page = get_object_or_404(Page, url=single)
        comment.name = name
        comment.text = text
        comment.save()
        return responses.SuccessfullyCommentedResponse(comment.page.url)
    else:
        return HttpResponseRedirect(urlreverse('single_post',
            kwargs={'single': single}))
Exemple #9
0
def all_pages(request):
    """ Display *all* pages """
    return render(settings.TEMPLATE_PAGE, None, {
        'items' : Page.filter(isblog=False).oder_by('-creation_time')
    })
Exemple #10
0
def by_tags(request, tags=None, tag=None):
    tags = split_tags(tags or tag)
    return render(settings.TEMPLATE_SEARCH, 'by_tags', parameters={
        'keywords': tags, 'results': posts_by_tags(tags)
    })