ansible/roles/developer/build/files/rss.py
Ben Cotton 46d4f10433 Fix handling of title-less Planet posts
Some platforms can give us a post without a title. When that happens,
Planet's RSS feed title is "$author" instead of "$author.title", which
causes our split to blow up. Instead, we check to see if there is a ':',
and if so split like normal. If not, explicitly set the title to
"(untitled post)" in order for it to still render.

While I'm at it, update a comment so that it reflects what the code is
actually doing.

Fixes #9251

Signed-off-by: Ben Cotton <bcotton@fedoraproject.org>
2020-08-20 13:24:43 +00:00

122 lines
3.9 KiB
Python

#!/usr/bin/python -tt
# -*- coding: utf-8 -*-
from __future__ import print_function
import codecs
import os
import sys
import feedparser
import re
import sys
feedparser._HTMLSanitizer.unacceptable_elements_with_end_tag.add('<div>')
defenc = "utf-8" if sys.getdefaultencoding() == "ascii" else sys.getdefaultencoding()
FedMag = ['http://fedoraplanet.org/rss20.xml']
if len(sys.argv) > 2:
print ('Alone script or only one argument is allowed.')
sys.exit(1)
HTML = u"""
"""
for feed in map(feedparser.parse, FedMag):
# We will parse last ten items
HTML += u"""
<div class="container" id="blog-headlines">
<div class="container">
<div class="row">
<div class="col-sm-12">
<h2><span>Fedora Planet</span></h2>
</div>
</div>
<div class="row">
"""
cnt = 0
# Getting at least 6 items in case of some python exceptions.
for item in feed["items"][:6]:
if int(cnt) % 2 == 0:
HTML += u"""
<div class="col-sm-6 blog-headlines">
"""
item.title = item.title.replace("&", "&#38;")
# If a blog post doesn't have a title for some reason, it breaks the way
# we try to parse out the author and title. Let's say it's untitled in
# order for it to appear on the page without breaking the script.
if ":" in item.title:
author, title = item.title.split(':', 1)
else:
author, title = item.title, "(untitled post)"
link = item.links[0]['href']
# Remove image tag from beginning
try:
article_desc = '\n'.join(item.description.split('\n')[1:])
# remove html tags from description
article_desc = re.sub('<[^<]+?>', '', article_desc)
article_desc = re.sub('<', '&lt;', article_desc)
article_desc = re.sub('>', '&gt;', article_desc)
if len(article_desc) > 140:
article_desc = ' '.join(article_desc.split()[0:25]) + '...'
if not article_desc.startswith('<p>'):
article_desc = '<p>%s</p>' % article_desc
except AttributeError:
print ('AttributeError. Going to next item')
continue
# we got
# Tue, 20 Oct 2015 03:28:42 +0000
# But we expect
# Tue, 20 Oct 2015
article_date = ' '.join(item.updated.split()[:4])
HTML += u"""
<article>
<h3><a href="{article_url}">{article_title}</a></h3>
{article_desc}
<p><a href="{article_url}">Read more</a></p>
<p class="byline">by <span class="author">{author}</span> <span class="date">{article_date}</span></p>
</article>
""".format(article_url=link,
article_title=title,
article_desc=article_desc,
article_date=article_date,
author=author)
cnt += 1
if int(cnt) % 2 == 0:
HTML += u"""
</div>
"""
# Condition if items were collected properly
if int(cnt) > 3:
break
HTML += u"""
</div>
</div>
</div>
"""
if len(sys.argv) == 1:
INDEX_FILE = os.path.join('.', '_site', 'index.html')
else:
INDEX_FILE = sys.argv[1]
with codecs.open(INDEX_FILE, 'r', 'utf8') as f:
contents = [line for line in f.readlines()]
if contents:
with codecs.open(INDEX_FILE, 'w', 'utf8') as f:
found_start = False
for line in contents:
if not found_start:
f.write(line)
if '<!-- BLOG_HEADLINES_START -->' in line:
f.write(HTML)
found_start = True
continue
if '<!-- BLOG_HEADLINES_END -->' in line:
found_start = False
f.write(line)
continue
#regexp = r'.*(<!-- BLOG_HEADLINES_START -->)(.*)(<!-- BLOG_HEADLINES_END -->).*'
#print (re.search(regexp, contents, re.MULTILINE | re.DOTALL))
#contents = re.sub(regexp, r'\1 MYREPLACE \3', contents, re.DOTALL | re.MULTILINE)