From b4664c8ea912e7b1ae198b1654f29813f922b247 Mon Sep 17 00:00:00 2001 From: rimu <3310831+rimu@users.noreply.github.com> Date: Tue, 14 Jan 2025 13:23:30 +1300 Subject: [PATCH] handle a variety of date formats for end of ban time --- app/activitypub/util.py | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/app/activitypub/util.py b/app/activitypub/util.py index 58fdc59a..fd94c34b 100644 --- a/app/activitypub/util.py +++ b/app/activitypub/util.py @@ -7,6 +7,7 @@ from datetime import timedelta, datetime, timezone from random import randint from typing import Union, Tuple, List +import arrow import httpx import redis from flask import current_app, request, g, url_for, json @@ -1454,10 +1455,22 @@ def ban_user(blocker, blocked, community, core_activity): else: reason = '' new_ban.reason = reason - if 'expires' in core_activity and datetime.fromisoformat(core_activity['expires']) > datetime.now(timezone.utc): - new_ban.ban_until = core_activity['expires'] - elif 'endTime' in core_activity and datetime.fromisoformat(core_activity['endTime']) > datetime.now(timezone.utc): - new_ban.ban_until = core_activity['endTime'] + + ban_until = None + if 'expires' in core_activity: + try: + ban_until = datetime.fromisoformat(core_activity['expires']) + except ValueError as e: + ban_until = arrow.get(core_activity['expires']).datetime + elif 'endTime' in core_activity: + try: + ban_until = datetime.fromisoformat(core_activity['endTime']) + except ValueError as e: + ban_until = arrow.get(core_activity['endTime']).datetime + + if ban_until and ban_until > datetime.now(timezone.utc): + new_ban.ban_until = ban_until + db.session.add(new_ban) community_membership_record = CommunityMember.query.filter_by(community_id=community.id, user_id=blocked.id).first()