mirror of
https://codeberg.org/rimu/pyfedi
synced 2025-01-23 19:36:56 -08:00
get 10 replies in background to manually retrieved nodebb topics
This commit is contained in:
parent
d3fc652f1f
commit
4eb9259b0e
1 changed files with 28 additions and 4 deletions
|
@ -2222,13 +2222,13 @@ def remote_object_to_json(uri):
|
||||||
|
|
||||||
# called from incoming activitypub, when the object in an Announce is just a URL
|
# called from incoming activitypub, when the object in an Announce is just a URL
|
||||||
# despite the name, it works for both posts and replies
|
# despite the name, it works for both posts and replies
|
||||||
def resolve_remote_post(uri: str, community, announce_id, store_ap_json) -> Union[Post, PostReply, None]:
|
def resolve_remote_post(uri: str, community, announce_id, store_ap_json, nodebb=False) -> Union[Post, PostReply, None]:
|
||||||
parsed_url = urlparse(uri)
|
parsed_url = urlparse(uri)
|
||||||
uri_domain = parsed_url.netloc
|
uri_domain = parsed_url.netloc
|
||||||
announce_actor = community.ap_profile_id
|
announce_actor = community.ap_profile_id
|
||||||
parsed_url = urlparse(announce_actor)
|
parsed_url = urlparse(announce_actor)
|
||||||
announce_actor_domain = parsed_url.netloc
|
announce_actor_domain = parsed_url.netloc
|
||||||
if announce_actor_domain != 'a.gup.pe' and announce_actor_domain != uri_domain:
|
if announce_actor_domain != 'a.gup.pe' and not nodebb and announce_actor_domain != uri_domain:
|
||||||
return None
|
return None
|
||||||
actor_domain = None
|
actor_domain = None
|
||||||
actor = None
|
actor = None
|
||||||
|
@ -2332,6 +2332,20 @@ def resolve_remote_post(uri: str, community, announce_id, store_ap_json) -> Unio
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
|
@celery.task
|
||||||
|
def get_nodebb_replies_in_background(replies_uri_list, community_id):
|
||||||
|
max = 10 if not current_app.debug else 2 # magic number alert
|
||||||
|
community = Community.query.get(community_id)
|
||||||
|
if not community:
|
||||||
|
return
|
||||||
|
reply_count = 0
|
||||||
|
for uri in replies_uri_list:
|
||||||
|
reply_count += 1
|
||||||
|
post_reply = resolve_remote_post(uri, community, None, False, nodebb=True)
|
||||||
|
if reply_count >= max:
|
||||||
|
break
|
||||||
|
|
||||||
|
|
||||||
# called from UI, via 'search' option in navbar, or 'Retrieve a post from the original server' in community sidebar
|
# called from UI, via 'search' option in navbar, or 'Retrieve a post from the original server' in community sidebar
|
||||||
def resolve_remote_post_from_search(uri: str) -> Union[Post, None]:
|
def resolve_remote_post_from_search(uri: str) -> Union[Post, None]:
|
||||||
post = Post.get_by_ap_id(uri)
|
post = Post.get_by_ap_id(uri)
|
||||||
|
@ -2345,11 +2359,14 @@ def resolve_remote_post_from_search(uri: str) -> Union[Post, None]:
|
||||||
|
|
||||||
post_data = remote_object_to_json(uri)
|
post_data = remote_object_to_json(uri)
|
||||||
|
|
||||||
# nodebb. the post is the first entry in orderedItems, and the replies are the remaining entries
|
# nodebb. the post is the first entry in orderedItems of a topic, and the replies are the remaining entries
|
||||||
# just gets orderedItems[0] the retrieve the post
|
# just gets orderedItems[0] to retrieve the post, and then replies are retrieved in the background
|
||||||
|
topic_post_data = post_data
|
||||||
|
nodebb = False
|
||||||
if ('type' in post_data and post_data['type'] == 'OrderedCollection' and
|
if ('type' in post_data and post_data['type'] == 'OrderedCollection' and
|
||||||
'totalItems' in post_data and post_data['totalItems'] > 0 and
|
'totalItems' in post_data and post_data['totalItems'] > 0 and
|
||||||
'orderedItems' in post_data and isinstance(post_data['orderedItems'], list)):
|
'orderedItems' in post_data and isinstance(post_data['orderedItems'], list)):
|
||||||
|
nodebb = True
|
||||||
uri = post_data['orderedItems'][0]
|
uri = post_data['orderedItems'][0]
|
||||||
parsed_url = urlparse(uri)
|
parsed_url = urlparse(uri)
|
||||||
uri_domain = parsed_url.netloc
|
uri_domain = parsed_url.netloc
|
||||||
|
@ -2385,6 +2402,8 @@ def resolve_remote_post_from_search(uri: str) -> Union[Post, None]:
|
||||||
|
|
||||||
# find the community the post was submitted to
|
# find the community the post was submitted to
|
||||||
community = find_community(post_data)
|
community = find_community(post_data)
|
||||||
|
if not community and nodebb:
|
||||||
|
community = find_community(topic_post_data) # use 'audience' from topic if post has no info for how it got there
|
||||||
# find the post's author
|
# find the post's author
|
||||||
user = find_actor_or_create(actor)
|
user = find_actor_or_create(actor)
|
||||||
if user and community and post_data:
|
if user and community and post_data:
|
||||||
|
@ -2395,6 +2414,11 @@ def resolve_remote_post_from_search(uri: str) -> Union[Post, None]:
|
||||||
post.posted_at=post_data['published']
|
post.posted_at=post_data['published']
|
||||||
post.last_active=post_data['published']
|
post.last_active=post_data['published']
|
||||||
db.session.commit()
|
db.session.commit()
|
||||||
|
if nodebb and topic_post_data['totalItems'] > 1:
|
||||||
|
if current_app.debug:
|
||||||
|
get_nodebb_replies_in_background(topic_post_data['orderedItems'][1:], community.id)
|
||||||
|
else:
|
||||||
|
get_nodebb_replies_in_background.delay(topic_post_data['orderedItems'][1:], community.id)
|
||||||
return post
|
return post
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
Loading…
Reference in a new issue