Use create_post instead of post_json_to_model for retrieved posts

This commit is contained in:
freamon 2024-05-27 22:51:49 +01:00
parent 6df2575238
commit 8da2b68ab1

View file

@ -1682,6 +1682,14 @@ def create_post(activity_log: ActivityPubLog, community: Community, request_json
activity_log.exception_message = domain.name + ' is blocked by admin' activity_log.exception_message = domain.name + ' is blocked by admin'
if post is not None: if post is not None:
if request_json['object']['type'] == 'Video':
post.type = POST_TYPE_VIDEO
post.url = request_json['object']['id']
if 'icon' in request_json['object'] and isinstance(request_json['object']['icon'], list):
icon = File(source_url=request_json['object']['icon'][-1]['url'])
db.session.add(icon)
post.image = icon
if 'language' in request_json['object'] and isinstance(request_json['object']['language'], dict): if 'language' in request_json['object'] and isinstance(request_json['object']['language'], dict):
language = find_language_or_create(request_json['object']['language']['identifier'], language = find_language_or_create(request_json['object']['language']['identifier'],
request_json['object']['language']['name']) request_json['object']['language']['name'])
@ -2364,23 +2372,11 @@ def resolve_remote_post(uri: str, community_id: int, announce_actor=None) -> Uni
db.session.add(activity_log) db.session.add(activity_log)
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:
post = post_json_to_model(activity_log, post_data, user, community) request_json = {
post.ranking = post_ranking(post.score, post.posted_at) 'id': f"https://{uri_domain}/activities/create/gibberish(15)",
community.last_active = utcnow() 'object': post_data
if post.url: }
other_posts = Post.query.filter(Post.id != post.id, Post.url == post.url, post = create_post(activity_log, community, request_json, user)
Post.posted_at > post.posted_at - timedelta(days=3),
Post.posted_at < post.posted_at + timedelta(days=3)).all()
for op in other_posts:
if op.cross_posts is None:
op.cross_posts = [post.id]
else:
op.cross_posts.append(post.id)
if post.cross_posts is None:
post.cross_posts = [op.id]
else:
post.cross_posts.append(op.id)
db.session.commit()
if post: if post:
return post.id return post.id