import html from .front import frontlist from datetime import datetime from files.helpers.get import * from yattag import Doc from files.helpers.wrappers import * from files.helpers.jinja2 import * from files.__main__ import app # @app.get('/rss') # @app.get('/feed') # @app.get('/rss//') # def feeds_user(sort='hot', t='all'): # try: page = max(int(request.values.get("page", 1)), 1) # except: page = 1 # ids, next_exists = frontlist( # sort=sort, # page=page, # t=t, # v=None, # ) # posts = get_posts(ids) # domain = environ.get("DOMAIN").strip() # doc, tag, text = Doc().tagtext() # with tag("feed", ("xmlns:media","http://search.yahoo.com/mrss/"), xmlns="http://www.w3.org/2005/Atom",): # with tag("title", type="text"): # text(f"{sort} posts from {domain}") # with tag("id"): # text(SITE_FULL + request.full_path) # with tag("updated"): # text(datetime.now().isoformat()+"Z") # doc.stag("link", rel="self", type="application/atom+xml", href=SITE_FULL + request.full_path) # doc.stag("link", rel="alternate", type="text/html", href=SITE_FULL) # for post in posts: # with tag("entry", ("xml:base", SITE_FULL + request.full_path)): # with tag("title", type="html"): # text(post.realtitle(None)) # with tag("id"): # text(post.permalink) # with tag("updated"): # if (post.edited_utc): # text(datetime.utcfromtimestamp(post.edited_utc).isoformat()+"Z") # else: # text(datetime.utcfromtimestamp(post.created_utc).isoformat()+"Z") # with tag("published"): # text(datetime.utcfromtimestamp(post.created_utc).isoformat()+"Z") # with tag("author"): # with tag("name"): # text(post.author_name) # with tag("uri"): # text(f'/@{post.author_name}') # doc.stag("link", href=post.permalink) # image_url = post.thumb_url or post.embed_url or post.url # doc.stag("media:thumbnail", url=image_url) # if len(post.body_html): # with tag("content", type="html"): # doc.cdata(f'''{post.realtitle(None)}
{post.realbody(None)}''') # return Response( ""+ doc.getvalue(), mimetype="application/xml")