forked from indymedia/epicyon
Missing argument
parent
d4751a47c6
commit
0735ceceb2
18
newswire.py
18
newswire.py
|
@ -19,6 +19,7 @@ from utils import isSuspended
|
||||||
from utils import containsInvalidChars
|
from utils import containsInvalidChars
|
||||||
from blocking import isBlockedDomain
|
from blocking import isBlockedDomain
|
||||||
|
|
||||||
|
|
||||||
def rss2Header(httpPrefix: str,
|
def rss2Header(httpPrefix: str,
|
||||||
nickname: str, domainFull: str,
|
nickname: str, domainFull: str,
|
||||||
title: str, translate: {}) -> str:
|
title: str, translate: {}) -> str:
|
||||||
|
@ -51,7 +52,7 @@ def rss2Footer() -> str:
|
||||||
return rssStr
|
return rssStr
|
||||||
|
|
||||||
|
|
||||||
def xml2StrToDict(xmlStr: str, moderated: bool,
|
def xml2StrToDict(baseDir: str, xmlStr: str, moderated: bool,
|
||||||
maxPostsPerSource: int) -> {}:
|
maxPostsPerSource: int) -> {}:
|
||||||
"""Converts an xml 2.0 string to a dictionary
|
"""Converts an xml 2.0 string to a dictionary
|
||||||
"""
|
"""
|
||||||
|
@ -125,7 +126,7 @@ def xml2StrToDict(xmlStr: str, moderated: bool,
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
||||||
def atomFeedToDict(xmlStr: str, moderated: bool,
|
def atomFeedToDict(baseDir: str, xmlStr: str, moderated: bool,
|
||||||
maxPostsPerSource: int) -> {}:
|
maxPostsPerSource: int) -> {}:
|
||||||
"""Converts an atom feed string to a dictionary
|
"""Converts an atom feed string to a dictionary
|
||||||
"""
|
"""
|
||||||
|
@ -199,18 +200,18 @@ def atomFeedToDict(xmlStr: str, moderated: bool,
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
||||||
def xmlStrToDict(xmlStr: str, moderated: bool,
|
def xmlStrToDict(baseDir: str, xmlStr: str, moderated: bool,
|
||||||
maxPostsPerSource: int) -> {}:
|
maxPostsPerSource: int) -> {}:
|
||||||
"""Converts an xml string to a dictionary
|
"""Converts an xml string to a dictionary
|
||||||
"""
|
"""
|
||||||
if 'rss version="2.0"' in xmlStr:
|
if 'rss version="2.0"' in xmlStr:
|
||||||
return xml2StrToDict(xmlStr, moderated, maxPostsPerSource)
|
return xml2StrToDict(baseDir, xmlStr, moderated, maxPostsPerSource)
|
||||||
elif 'xmlns="http://www.w3.org/2005/Atom"' in xmlStr:
|
elif 'xmlns="http://www.w3.org/2005/Atom"' in xmlStr:
|
||||||
return atomFeedToDict(xmlStr, moderated, maxPostsPerSource)
|
return atomFeedToDict(baseDir, xmlStr, moderated, maxPostsPerSource)
|
||||||
return {}
|
return {}
|
||||||
|
|
||||||
|
|
||||||
def getRSS(session, url: str, moderated: bool,
|
def getRSS(baseDir: str, session, url: str, moderated: bool,
|
||||||
maxPostsPerSource: int,
|
maxPostsPerSource: int,
|
||||||
maxFeedSizeKb: int) -> {}:
|
maxFeedSizeKb: int) -> {}:
|
||||||
"""Returns an RSS url as a dict
|
"""Returns an RSS url as a dict
|
||||||
|
@ -238,7 +239,8 @@ def getRSS(session, url: str, moderated: bool,
|
||||||
if result:
|
if result:
|
||||||
if int(len(result.text) / 1024) < maxFeedSizeKb and \
|
if int(len(result.text) / 1024) < maxFeedSizeKb and \
|
||||||
not containsInvalidChars(result.text):
|
not containsInvalidChars(result.text):
|
||||||
return xmlStrToDict(result.text, moderated, maxPostsPerSource)
|
return xmlStrToDict(baseDir, result.text, moderated,
|
||||||
|
maxPostsPerSource)
|
||||||
else:
|
else:
|
||||||
print('WARN: feed is too large: ' + url)
|
print('WARN: feed is too large: ' + url)
|
||||||
except requests.exceptions.RequestException as e:
|
except requests.exceptions.RequestException as e:
|
||||||
|
@ -449,7 +451,7 @@ def getDictFromNewswire(session, baseDir: str,
|
||||||
moderated = True
|
moderated = True
|
||||||
url = url.replace('*', '').strip()
|
url = url.replace('*', '').strip()
|
||||||
|
|
||||||
itemsList = getRSS(session, url, moderated,
|
itemsList = getRSS(baseDir, session, url, moderated,
|
||||||
maxPostsPerSource, maxFeedSizeKb)
|
maxPostsPerSource, maxFeedSizeKb)
|
||||||
for dateStr, item in itemsList.items():
|
for dateStr, item in itemsList.items():
|
||||||
result[dateStr] = item
|
result[dateStr] = item
|
||||||
|
|
Loading…
Reference in New Issue