Implement proper sorting of RSS feed by publish date
This way new torrents always go at the top of the list Regenerate RSS feed with new rss.py
This commit is contained in:
parent
7e2953d9ef
commit
c0274ecb40
2 changed files with 3104 additions and 3095 deletions
31
rss.py
31
rss.py
|
@ -8,9 +8,14 @@ import datetime
|
||||||
|
|
||||||
import bencodepy
|
import bencodepy
|
||||||
|
|
||||||
|
|
||||||
dir = os.path.join(os.getcwd(), "torrents")
|
dir = os.path.join(os.getcwd(), "torrents")
|
||||||
rss = os.path.join(os.getcwd(), "rss.xml")
|
rss = os.path.join(os.getcwd(), "rss.xml")
|
||||||
|
|
||||||
|
|
||||||
|
items = []
|
||||||
|
|
||||||
|
|
||||||
with open(rss, "w") as xml:
|
with open(rss, "w") as xml:
|
||||||
xml.write("<?xml version=\"1.0\" encoding=\"utf-8\"?>\n")
|
xml.write("<?xml version=\"1.0\" encoding=\"utf-8\"?>\n")
|
||||||
xml.write("<rss version=\"2.0\">\n")
|
xml.write("<rss version=\"2.0\">\n")
|
||||||
|
@ -40,25 +45,29 @@ with open(rss, "w") as xml:
|
||||||
length = tor[b"info"][b"length"]
|
length = tor[b"info"][b"length"]
|
||||||
name = tor[b"info"][b"name"].decode("utf-8")
|
name = tor[b"info"][b"name"].decode("utf-8")
|
||||||
ts = tor[b"creation date"]
|
ts = tor[b"creation date"]
|
||||||
|
items.append({"name": name, "infohash": infohash, "length": length, "ts": ts, "trackers": trackers})
|
||||||
|
|
||||||
pubdate = datetime.datetime.utcfromtimestamp(int(ts))
|
items = sorted(items, key=lambda d: d['ts'], reverse=True)
|
||||||
|
|
||||||
|
for i in items:
|
||||||
|
pubdate = datetime.datetime.utcfromtimestamp(int(i["ts"]))
|
||||||
xml.write("\t\t<item>\n")
|
xml.write("\t\t<item>\n")
|
||||||
xml.write("\t\t\t<title>{0}</title>\n".format(name))
|
xml.write("\t\t\t<title>{0}</title>\n".format(i["name"]))
|
||||||
xml.write("\t\t\t<description>{0}</description>\n".format(name))
|
xml.write("\t\t\t<description>{0}</description>\n".format(i["name"]))
|
||||||
xml.write("\t\t\t<guid>{0}</guid>\n".format(infohash))
|
xml.write("\t\t\t<guid>{0}</guid>\n".format(i["infohash"]))
|
||||||
xml.write("\t\t\t<link>magnet:?xt=urn:btih:{0}</link>\n".format(infohash))
|
xml.write("\t\t\t<link>magnet:?xt=urn:btih:{0}</link>\n".format(i["infohash"]))
|
||||||
xml.write("\t\t\t<pubDate>{0}</pubDate>\n".format(pubdate.strftime("%a, %d %b %Y %X +0000")))
|
xml.write("\t\t\t<pubDate>{0}</pubDate>\n".format(pubdate.strftime("%a, %d %b %Y %X +0000")))
|
||||||
xml.write("\t\t\t<contentLength>{0}</contentLength>\n".format(length))
|
xml.write("\t\t\t<contentLength>{0}</contentLength>\n".format(i["length"]))
|
||||||
xml.write("\t\t\t<infoHash>{0}</infoHash>\n".format(infohash))
|
xml.write("\t\t\t<infoHash>{0}</infoHash>\n".format(i["infohash"]))
|
||||||
xml.write("\t\t\t<magnetURI>magnet:?xt=urn:btih:{0}</magnetURI>\n".format(infohash))
|
xml.write("\t\t\t<magnetURI>magnet:?xt=urn:btih:{0}</magnetURI>\n".format(i["infohash"]))
|
||||||
#xml.write("\t\t\t<fileName>{0}</fileName><fileName>\n".format(name))
|
#xml.write("\t\t\t<fileName>{0}</fileName><fileName>\n".format(name))
|
||||||
xml.write("\t\t\t<enclosure url=\"magnet:?xt=urn:btih:{0}\" type=\"application/x-bittorrent\" />\n".format(infohash))
|
xml.write("\t\t\t<enclosure url=\"magnet:?xt=urn:btih:{0}\" type=\"application/x-bittorrent\" />\n".format(i["infohash"]))
|
||||||
|
|
||||||
if trackers:
|
if i["trackers"]:
|
||||||
xml.write("\t\t\t<trackers>\n")
|
xml.write("\t\t\t<trackers>\n")
|
||||||
xml.write("\t\t\t\t<group order=\"random\">\n")
|
xml.write("\t\t\t\t<group order=\"random\">\n")
|
||||||
|
|
||||||
for tracker in trackers:
|
for tracker in i["trackers"]:
|
||||||
xml.write("\t\t\t\t\t<tracker>\n")
|
xml.write("\t\t\t\t\t<tracker>\n")
|
||||||
xml.write("\t\t\t\t\t\t{0}\n".format(tracker))
|
xml.write("\t\t\t\t\t\t{0}\n".format(tracker))
|
||||||
xml.write("\t\t\t\t\t</tracker>\n")
|
xml.write("\t\t\t\t\t</tracker>\n")
|
||||||
|
|
Loading…
Reference in a new issue