From 9062f49992f222b318e5c68a5b47e25f9e697219 Mon Sep 17 00:00:00 2001 From: rubenwardy Date: Tue, 2 Jul 2024 20:55:01 +0100 Subject: [PATCH] Fix authors in JSONFeed Unfortunately, the only working validator I found can only validate live URLs --- app/blueprints/feeds/__init__.py | 12 ++++++++++-- app/models/packages.py | 10 +++++----- app/models/users.py | 13 ++++++++++--- app/templates/feeds/json_to_atom.xml | 3 ++- 4 files changed, 27 insertions(+), 11 deletions(-) diff --git a/app/blueprints/feeds/__init__.py b/app/blueprints/feeds/__init__.py index 69f2f2db..c97d579a 100644 --- a/app/blueprints/feeds/__init__.py +++ b/app/blueprints/feeds/__init__.py @@ -50,7 +50,11 @@ def _get_new_packages_feed(feed_url: str) -> dict: "language": "en", "title": f"New: {package.title}", "content_html": render_markdown(package.desc) if package.desc else None, - "author": package.author.display_name, + "author": { + "name": package.author.display_name, + "avatar": package.author.get_profile_pic_url(absolute=True), + "url": abs_url_for("users.profile", username=package.author.username), + }, "url": package.get_url("packages.view", absolute=True), "summary": package.short_desc, "date_published": package.approved_at.isoformat(timespec="seconds") + "Z", @@ -72,7 +76,11 @@ def _get_releases_feed(query, feed_url: str): "language": "en", "title": f"{release.title} - {release.package.title}", "content_html": render_markdown(release.release_notes) if release.release_notes else None, - "author": release.package.author.display_name, + "author": { + "name": release.package.author.display_name, + "avatar": release.package.author.get_profile_pic_url(absolute=True), + "url": abs_url_for("users.profile", username=release.package.author.username), + }, "url": release.package.get_url("packages.view_release", id=release.id, absolute=True), "summary": release.summary, "date_published": release.created_at.isoformat(timespec="seconds") + "Z", diff --git a/app/models/packages.py b/app/models/packages.py index 748b1246..14373488 100644 --- a/app/models/packages.py +++ b/app/models/packages.py @@ -1099,11 +1099,11 @@ class PackageRelease(db.Model): release_notes = db.Column(db.UnicodeText, nullable=True, default=None) @property - def summary(self) -> typing.Optional[str]: - if self.release_notes is None: - return None - if self.release_notes.startswith("-") or self.release_notes.startswith("*"): - return None + def summary(self) -> str: + if self.release_notes is None or \ + self.release_notes.startswith("-") or \ + self.release_notes.startswith("*"): + return self.title return self.release_notes.split("\n")[0] diff --git a/app/models/users.py b/app/models/users.py index 516e868b..b7909fba 100644 --- a/app/models/users.py +++ b/app/models/users.py @@ -17,6 +17,7 @@ import datetime import enum +from flask import current_app from flask_babel import lazy_gettext from flask_login import UserMixin from sqlalchemy import desc, text @@ -246,11 +247,17 @@ def __init__(self, username=None, active=False, email=None, password=None): def can_access_todo_list(self): return Permission.APPROVE_NEW.check(self) or Permission.APPROVE_RELEASE.check(self) - def get_profile_pic_url(self): + def get_profile_pic_url(self, absolute: bool = False): if self.profile_pic: - return self.profile_pic + if absolute: + return current_app.config["BASE_URL"] + self.profile_pic + else: + return self.profile_pic elif self.rank == UserRank.BOT: - return "/static/bot_avatar.png" + if absolute: + return current_app.config["BASE_URL"] + "/static/bot_avatar.png" + else: + return "/static/bot_avatar.png" else: from app.utils.gravatar import get_gravatar return get_gravatar(self.email or f"{self.username}@content.minetest.net") diff --git a/app/templates/feeds/json_to_atom.xml b/app/templates/feeds/json_to_atom.xml index 252c980d..e23a6144 100644 --- a/app/templates/feeds/json_to_atom.xml +++ b/app/templates/feeds/json_to_atom.xml @@ -25,7 +25,8 @@ {{ post["content_html"] | escape }} - {{ post["author"] }} + {{ post["author"]["name"] }} + {{ post["author"]["url"] }} {% for tag in post["tags"] %}