oh boy, this sucks #194

This commit is contained in:
rimu 2024-06-05 13:21:41 +12:00
parent c902f28137
commit 3203ac5506
14 changed files with 155 additions and 152 deletions

View file

@ -255,7 +255,7 @@ def user_profile(actor):
server = current_app.config['SERVER_NAME'] server = current_app.config['SERVER_NAME']
actor_data = { "@context": default_context(), actor_data = { "@context": default_context(),
"type": "Person" if not user.bot else "Service", "type": "Person" if not user.bot else "Service",
"id": user.profile_id(), "id": user.public_url(),
"preferredUsername": actor.lower(), "preferredUsername": actor.lower(),
"name": user.title if user.title else user.user_name, "name": user.title if user.title else user.user_name,
"inbox": f"https://{server}/u/{actor.lower()}/inbox", "inbox": f"https://{server}/u/{actor.lower()}/inbox",
@ -264,8 +264,8 @@ def user_profile(actor):
"indexable": user.indexable, "indexable": user.indexable,
"manuallyApprovesFollowers": False if not user.ap_manually_approves_followers else user.ap_manually_approves_followers, "manuallyApprovesFollowers": False if not user.ap_manually_approves_followers else user.ap_manually_approves_followers,
"publicKey": { "publicKey": {
"id": f"https://{server}/u/{actor.lower()}#main-key", "id": f"{user.public_url()}#main-key",
"owner": f"https://{server}/u/{actor.lower()}", "owner": user.public_url(),
"publicKeyPem": user.public_key # .replace("\n", "\\n") #LOOKSWRONG "publicKeyPem": user.public_key # .replace("\n", "\\n") #LOOKSWRONG
}, },
"endpoints": { "endpoints": {
@ -1187,13 +1187,13 @@ def announce_activity_to_followers(community, creator, activity):
announce_activity = { announce_activity = {
'@context': default_context(), '@context': default_context(),
"actor": community.profile_id(), "actor": community.public_url(),
"to": [ "to": [
"https://www.w3.org/ns/activitystreams#Public" "https://www.w3.org/ns/activitystreams#Public"
], ],
"object": activity, "object": activity,
"cc": [ "cc": [
f"{community.profile_id()}/followers" f"{community.public_url()}/followers"
], ],
"type": "Announce", "type": "Announce",
"id": f"https://{current_app.config['SERVER_NAME']}/activities/announce/{gibberish(15)}" "id": f"https://{current_app.config['SERVER_NAME']}/activities/announce/{gibberish(15)}"
@ -1390,7 +1390,7 @@ def process_user_follow_request(request_json, activitypublog_id, remote_user_id)
"type": "Accept", "type": "Accept",
"id": f"https://{current_app.config['SERVER_NAME']}/activities/accept/" + gibberish(32) "id": f"https://{current_app.config['SERVER_NAME']}/activities/accept/" + gibberish(32)
} }
if post_request(remote_user.ap_inbox_url, accept, local_user.private_key, f"{local_user.profile_id()}#main-key"): if post_request(remote_user.ap_inbox_url, accept, local_user.private_key, f"{local_user.public_url()}#main-key"):
activity_log.result = 'success' activity_log.result = 'success'
else: else:
activity_log.exception_message = 'Error sending Accept' activity_log.exception_message = 'Error sending Accept'
@ -1461,21 +1461,21 @@ def comment_ap(comment_id):
"@context": default_context(), "@context": default_context(),
"type": "Note", "type": "Note",
"id": reply.ap_id, "id": reply.ap_id,
"attributedTo": reply.author.profile_id(), "attributedTo": reply.author.public_url(),
"inReplyTo": reply.in_reply_to(), "inReplyTo": reply.in_reply_to(),
"to": [ "to": [
"https://www.w3.org/ns/activitystreams#Public", "https://www.w3.org/ns/activitystreams#Public",
reply.to() reply.to()
], ],
"cc": [ "cc": [
reply.community.profile_id(), reply.community.public_url(),
reply.author.followers_url() reply.author.followers_url()
], ],
'content': reply.body_html, 'content': reply.body_html,
'mediaType': 'text/html', 'mediaType': 'text/html',
'published': ap_datetime(reply.created_at), 'published': ap_datetime(reply.created_at),
'distinguished': False, 'distinguished': False,
'audience': reply.community.profile_id(), 'audience': reply.community.public_url(),
'language': { 'language': {
'identifier': reply.language_code(), 'identifier': reply.language_code(),
'name': reply.language_name() 'name': reply.language_name()

View file

@ -133,14 +133,14 @@ def post_to_activity(post: Post, community: Community):
], ],
"object": { "object": {
"id": create_id, "id": create_id,
"actor": post.author.profile_id() if post.author.is_local() else post.author.ap_public_url, "actor": post.author.public_url(),
"to": [ "to": [
"https://www.w3.org/ns/activitystreams#Public" "https://www.w3.org/ns/activitystreams#Public"
], ],
"object": { "object": {
"type": "Page", "type": "Page",
"id": post.ap_id, "id": post.ap_id,
"attributedTo": post.author.profile_id() if post.author.is_local() else post.author.ap_public_url, "attributedTo": post.author.public_url(),
"to": [ "to": [
f"https://{current_app.config['SERVER_NAME']}/c/{community.name}", f"https://{current_app.config['SERVER_NAME']}/c/{community.name}",
"https://www.w3.org/ns/activitystreams#Public" "https://www.w3.org/ns/activitystreams#Public"
@ -2283,7 +2283,7 @@ def lemmy_site_data():
"banned": admin.banned, "banned": admin.banned,
"published": admin.created.isoformat() + 'Z', "published": admin.created.isoformat() + 'Z',
"updated": admin.created.isoformat() + 'Z', "updated": admin.created.isoformat() + 'Z',
"actor_id": admin.profile_id(), "actor_id": admin.public_url(),
"local": True, "local": True,
"deleted": admin.deleted, "deleted": admin.deleted,
"matrix_user_id": admin.matrix_user_id, "matrix_user_id": admin.matrix_user_id,
@ -2571,8 +2571,8 @@ def inform_followers_of_post_update_task(post_id: int, sending_instance_id: int)
update_json = { update_json = {
'id': f"https://{current_app.config['SERVER_NAME']}/activities/update/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/update/{gibberish(15)}",
'type': 'Update', 'type': 'Update',
'actor': post.author.profile_id(), 'actor': post.author.public_url(),
'audience': post.community.profile_id(), 'audience': post.community.public_url(),
'to': ['https://www.w3.org/ns/activitystreams#Public'], 'to': ['https://www.w3.org/ns/activitystreams#Public'],
'published': ap_datetime(utcnow()), 'published': ap_datetime(utcnow()),
'cc': [ 'cc': [
@ -2589,7 +2589,7 @@ def inform_followers_of_post_update_task(post_id: int, sending_instance_id: int)
for i in instances: for i in instances:
if sending_instance_id != i.id: if sending_instance_id != i.id:
try: try:
post_request(i.inbox, update_json, post.author.private_key, post.author.profile_id() + '#main-key') post_request(i.inbox, update_json, post.author.private_key, post.author.public_url() + '#main-key')
except Exception: except Exception:
pass pass
@ -2600,6 +2600,6 @@ def inform_followers_of_post_update_task(post_id: int, sending_instance_id: int)
for i in instances: for i in instances:
if sending_instance_id != i.id: if sending_instance_id != i.id:
try: try:
post_request(i.inbox, update_json, post.author.private_key, post.author.profile_id() + '#main-key') post_request(i.inbox, update_json, post.author.private_key, post.author.public_url() + '#main-key')
except Exception: except Exception:
pass pass

View file

@ -34,9 +34,9 @@ def unsubscribe_from_everything_then_delete_task(user_id):
instances = Instance.query.filter(Instance.dormant == False).all() instances = Instance.query.filter(Instance.dormant == False).all()
payload = { payload = {
"@context": default_context(), "@context": default_context(),
"actor": user.profile_id(), "actor": user.public_url(),
"id": f"{user.profile_id()}#delete", "id": f"{user.public_url()}#delete",
"object": user.profile_id(), "object": user.public_url(),
"to": [ "to": [
"https://www.w3.org/ns/activitystreams#Public" "https://www.w3.org/ns/activitystreams#Public"
], ],
@ -44,7 +44,7 @@ def unsubscribe_from_everything_then_delete_task(user_id):
} }
for instance in instances: for instance in instances:
if instance.inbox and instance.online() and instance.id != 1: # instance id 1 is always the current instance if instance.inbox and instance.online() and instance.id != 1: # instance id 1 is always the current instance
post_request(instance.inbox, payload, user.private_key, f"{user.profile_id()}#main-key") post_request(instance.inbox, payload, user.private_key, f"{user.public_url()}#main-key")
sleep(5) sleep(5)
@ -57,15 +57,15 @@ def unsubscribe_from_everything_then_delete_task(user_id):
def unsubscribe_from_community(community, user): def unsubscribe_from_community(community, user):
undo_id = f"https://{current_app.config['SERVER_NAME']}/activities/undo/" + gibberish(15) undo_id = f"https://{current_app.config['SERVER_NAME']}/activities/undo/" + gibberish(15)
follow = { follow = {
"actor": f"https://{current_app.config['SERVER_NAME']}/u/{user.user_name}", "actor": user.public_url(),
"to": [community.ap_profile_id], "to": [community.public_url()],
"object": community.ap_profile_id, "object": community.public_url(),
"type": "Follow", "type": "Follow",
"id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{gibberish(15)}" "id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{gibberish(15)}"
} }
undo = { undo = {
'actor': user.profile_id(), 'actor': user.public_url(),
'to': [community.ap_profile_id], 'to': [community.public_url()],
'type': 'Undo', 'type': 'Undo',
'id': undo_id, 'id': undo_id,
'object': follow 'object': follow
@ -74,7 +74,7 @@ def unsubscribe_from_community(community, user):
activity_json=json.dumps(undo), result='processing') activity_json=json.dumps(undo), result='processing')
db.session.add(activity) db.session.add(activity)
db.session.commit() db.session.commit()
post_request(community.ap_inbox_url, undo, user.private_key, user.profile_id() + '#main-key') post_request(community.ap_inbox_url, undo, user.private_key, user.public_url() + '#main-key')
activity.result = 'success' activity.result = 'success'
db.session.commit() db.session.commit()

View file

@ -30,26 +30,26 @@ def send_message(message: str, conversation_id: int) -> ChatMessage:
else: else:
# Federate reply # Federate reply
reply_json = { reply_json = {
"actor": current_user.profile_id(), "actor": current_user.public_url(),
"id": f"https://{current_app.config['SERVER_NAME']}/activities/create/{gibberish(15)}", "id": f"https://{current_app.config['SERVER_NAME']}/activities/create/{gibberish(15)}",
"object": { "object": {
"attributedTo": current_user.profile_id(), "attributedTo": current_user.public_url(),
"content": reply.body_html, "content": reply.body_html,
"id": f"https://{current_app.config['SERVER_NAME']}/private_message/{reply.id}", "id": f"https://{current_app.config['SERVER_NAME']}/private_message/{reply.id}",
"mediaType": "text/html", "mediaType": "text/html",
"published": utcnow().isoformat() + 'Z', # Lemmy is inconsistent with the date format they use "published": utcnow().isoformat() + 'Z', # Lemmy is inconsistent with the date format they use
"to": [ "to": [
recipient.profile_id() recipient.public_url()
], ],
"type": "ChatMessage" "type": "ChatMessage"
}, },
"to": [ "to": [
recipient.profile_id() recipient.public_url()
], ],
"type": "Create" "type": "Create"
} }
success = post_request(recipient.ap_inbox_url, reply_json, current_user.private_key, success = post_request(recipient.ap_inbox_url, reply_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash(_('Message failed to send to %(name)s.', name=recipient.link()), 'error') flash(_('Message failed to send to %(name)s.', name=recipient.link()), 'error')

View file

@ -386,14 +386,14 @@ def subscribe(actor):
db.session.add(join_request) db.session.add(join_request)
db.session.commit() db.session.commit()
follow = { follow = {
"actor": current_user.profile_id(), "actor": current_user.public_url(),
"to": [community.ap_profile_id], "to": [community.public_url()],
"object": community.ap_profile_id, "object": community.public_url(),
"type": "Follow", "type": "Follow",
"id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{join_request.id}" "id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{join_request.id}"
} }
success = post_request(community.ap_inbox_url, follow, current_user.private_key, success = post_request(community.ap_inbox_url, follow, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash(_("There was a problem while trying to communicate with remote server. If other people have already joined this community it won't matter."), 'error') flash(_("There was a problem while trying to communicate with remote server. If other people have already joined this community it won't matter."), 'error')
# for local communities, joining is instant # for local communities, joining is instant
@ -426,21 +426,21 @@ def unsubscribe(actor):
if '@' in actor: # this is a remote community, so activitypub is needed if '@' in actor: # this is a remote community, so activitypub is needed
undo_id = f"https://{current_app.config['SERVER_NAME']}/activities/undo/" + gibberish(15) undo_id = f"https://{current_app.config['SERVER_NAME']}/activities/undo/" + gibberish(15)
follow = { follow = {
"actor": current_user.profile_id(), "actor": current_user.public_url(),
"to": [community.ap_profile_id], "to": [community.public_url()],
"object": community.ap_profile_id, "object": community.public_url(),
"type": "Follow", "type": "Follow",
"id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{gibberish(15)}" "id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{gibberish(15)}"
} }
undo = { undo = {
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'to': [community.ap_profile_id], 'to': [community.public_url()],
'type': 'Undo', 'type': 'Undo',
'id': undo_id, 'id': undo_id,
'object': follow 'object': follow
} }
success = post_request(community.ap_inbox_url, undo, current_user.private_key, success = post_request(community.ap_inbox_url, undo, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash('There was a problem while trying to unsubscribe', 'error') flash('There was a problem while trying to unsubscribe', 'error')
@ -478,14 +478,14 @@ def join_then_add(actor):
db.session.add(join_request) db.session.add(join_request)
db.session.commit() db.session.commit()
follow = { follow = {
"actor": current_user.profile_id(), "actor": current_user.public_url(),
"to": [community.ap_profile_id], "to": [community.public_url()],
"object": community.ap_profile_id, "object": community.public_url(),
"type": "Follow", "type": "Follow",
"id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{join_request.id}" "id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{join_request.id}"
} }
success = post_request(community.ap_inbox_url, follow, current_user.private_key, success = post_request(community.ap_inbox_url, follow, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
member = CommunityMember(user_id=current_user.id, community_id=community.id) member = CommunityMember(user_id=current_user.id, community_id=community.id)
db.session.add(member) db.session.add(member)
db.session.commit() db.session.commit()
@ -952,7 +952,7 @@ def federate_post(community, post):
page['oneOf' if poll.mode == 'single' else 'anyOf'] = choices page['oneOf' if poll.mode == 'single' else 'anyOf'] = choices
if not community.is_local(): # this is a remote community - send the post to the instance that hosts it if not community.is_local(): # this is a remote community - send the post to the instance that hosts it
success = post_request(community.ap_inbox_url, create, current_user.private_key, success = post_request(community.ap_inbox_url, create, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if success: if success:
flash(_('Your post to %(name)s has been made.', name=community.title)) flash(_('Your post to %(name)s has been made.', name=community.title))
else: else:
@ -1067,7 +1067,7 @@ def federate_post_to_user_followers(post):
instances = Instance.query.join(User, User.instance_id == Instance.id).join(UserFollower, UserFollower.remote_user_id == User.id) instances = Instance.query.join(User, User.instance_id == Instance.id).join(UserFollower, UserFollower.remote_user_id == User.id)
instances = instances.filter(UserFollower.local_user_id == post.user_id).filter(Instance.gone_forever == False) instances = instances.filter(UserFollower.local_user_id == post.user_id).filter(Instance.gone_forever == False)
for i in instances: for i in instances:
post_request(i.inbox, create, current_user.private_key, current_user.profile_id() + '#main-key') post_request(i.inbox, create, current_user.private_key, current_user.public_url() + '#main-key')
@bp.route('/community/<int:community_id>/report', methods=['GET', 'POST']) @bp.route('/community/<int:community_id>/report', methods=['GET', 'POST'])

View file

@ -548,9 +548,9 @@ def delete_post_from_community_task(post_id):
delete_json = { delete_json = {
'id': f"https://{current_app.config['SERVER_NAME']}/activities/delete/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/delete/{gibberish(15)}",
'type': 'Delete', 'type': 'Delete',
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'audience': post.community.profile_id(), 'audience': post.community.public_url(),
'to': [post.community.profile_id(), 'https://www.w3.org/ns/activitystreams#Public'], 'to': [post.community.public_url(), 'https://www.w3.org/ns/activitystreams#Public'],
'published': ap_datetime(utcnow()), 'published': ap_datetime(utcnow()),
'cc': [ 'cc': [
current_user.followers_url() current_user.followers_url()
@ -560,7 +560,7 @@ def delete_post_from_community_task(post_id):
if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it
success = post_request(post.community.ap_inbox_url, delete_json, current_user.private_key, success = post_request(post.community.ap_inbox_url, delete_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
else: # local community - send it to followers on remote instances else: # local community - send it to followers on remote instances
announce = { announce = {
"id": f"https://{current_app.config['SERVER_NAME']}/activities/announce/{gibberish(15)}", "id": f"https://{current_app.config['SERVER_NAME']}/activities/announce/{gibberish(15)}",
@ -608,9 +608,9 @@ def delete_post_reply_from_community_task(post_reply_id):
delete_json = { delete_json = {
'id': f"https://{current_app.config['SERVER_NAME']}/activities/delete/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/delete/{gibberish(15)}",
'type': 'Delete', 'type': 'Delete',
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'audience': post.community.profile_id(), 'audience': post.community.public_url(),
'to': [post.community.profile_id(), 'https://www.w3.org/ns/activitystreams#Public'], 'to': [post.community.public_url(), 'https://www.w3.org/ns/activitystreams#Public'],
'published': ap_datetime(utcnow()), 'published': ap_datetime(utcnow()),
'cc': [ 'cc': [
current_user.followers_url() current_user.followers_url()
@ -620,7 +620,7 @@ def delete_post_reply_from_community_task(post_reply_id):
if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it
success = post_request(post.community.ap_inbox_url, delete_json, current_user.private_key, success = post_request(post.community.ap_inbox_url, delete_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
else: # local community - send it to followers on remote instances else: # local community - send it to followers on remote instances
announce = { announce = {

View file

@ -756,7 +756,7 @@ class User(UserMixin, db.Model):
if self.ap_followers_url: if self.ap_followers_url:
return self.ap_followers_url return self.ap_followers_url
else: else:
return self.profile_id() + '/followers' return self.public_url() + '/followers'
def get_reset_password_token(self, expires_in=600): def get_reset_password_token(self, expires_in=600):
return jwt.encode( return jwt.encode(
@ -1118,6 +1118,9 @@ class PostReply(db.Model):
else: else:
return f"https://{current_app.config['SERVER_NAME']}/comment/{self.id}" return f"https://{current_app.config['SERVER_NAME']}/comment/{self.id}"
def public_url(self):
return self.profile_id()
# the ap_id of the parent object, whether it's another PostReply or a Post # the ap_id of the parent object, whether it's another PostReply or a Post
def in_reply_to(self): def in_reply_to(self):
if self.parent_id is None: if self.parent_id is None:
@ -1129,10 +1132,10 @@ class PostReply(db.Model):
# the AP profile of the person who wrote the parent object, which could be another PostReply or a Post # the AP profile of the person who wrote the parent object, which could be another PostReply or a Post
def to(self): def to(self):
if self.parent_id is None: if self.parent_id is None:
return self.post.author.profile_id() return self.post.author.public_url()
else: else:
parent = PostReply.query.get(self.parent_id) parent = PostReply.query.get(self.parent_id)
return parent.author.profile_id() return parent.author.public_url()
def delete_dependencies(self): def delete_dependencies(self):
for child_reply in self.child_replies(): for child_reply in self.child_replies():

View file

@ -145,7 +145,7 @@ def show_post(post_id: int):
# federation # federation
reply_json = { reply_json = {
'type': 'Note', 'type': 'Note',
'id': reply.profile_id(), 'id': reply.public_url(),
'attributedTo': current_user.public_url(), 'attributedTo': current_user.public_url(),
'to': [ 'to': [
'https://www.w3.org/ns/activitystreams#Public' 'https://www.w3.org/ns/activitystreams#Public'
@ -154,7 +154,7 @@ def show_post(post_id: int):
community.public_url(), post.author.public_url() community.public_url(), post.author.public_url()
], ],
'content': reply.body_html, 'content': reply.body_html,
'inReplyTo': post.profile_id(), 'inReplyTo': post.public_url(),
'mediaType': 'text/html', 'mediaType': 'text/html',
'published': ap_datetime(utcnow()), 'published': ap_datetime(utcnow()),
'distinguished': False, 'distinguished': False,
@ -189,7 +189,7 @@ def show_post(post_id: int):
} }
if not community.is_local(): # this is a remote community, send it to the instance that hosts it if not community.is_local(): # this is a remote community, send it to the instance that hosts it
success = post_request(community.ap_inbox_url, create_json, current_user.private_key, success = post_request(community.ap_inbox_url, create_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash('Failed to send to remote instance', 'error') flash('Failed to send to remote instance', 'error')
else: # local community - send it to followers on remote instances else: # local community - send it to followers on remote instances
@ -215,12 +215,12 @@ def show_post(post_id: int):
if not post.author.is_local() and post.author.ap_domain != community.ap_domain: if not post.author.is_local() and post.author.ap_domain != community.ap_domain:
if not community.is_local() or (community.is_local and not community.has_followers_from_domain(post.author.ap_domain)): if not community.is_local() or (community.is_local and not community.has_followers_from_domain(post.author.ap_domain)):
success = post_request(post.author.ap_inbox_url, create_json, current_user.private_key, success = post_request(post.author.ap_inbox_url, create_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
# sending to shared inbox is good enough for Mastodon, but Lemmy will reject it the local community has no followers # sending to shared inbox is good enough for Mastodon, but Lemmy will reject it the local community has no followers
personal_inbox = post.author.public_url() + '/inbox' personal_inbox = post.author.public_url() + '/inbox'
post_request(personal_inbox, create_json, current_user.private_key, post_request(personal_inbox, create_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
return redirect(url_for('activitypub.post_ap', post_id=post_id)) # redirect to current page to avoid refresh resubmitting the form return redirect(url_for('activitypub.post_ap', post_id=post_id)) # redirect to current page to avoid refresh resubmitting the form
else: else:
@ -387,26 +387,26 @@ def post_vote(post_id: int, vote_direction):
if not post.community.local_only: if not post.community.local_only:
if undo: if undo:
action_json = { action_json = {
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'type': 'Undo', 'type': 'Undo',
'id': f"https://{current_app.config['SERVER_NAME']}/activities/undo/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/undo/{gibberish(15)}",
'audience': post.community.profile_id(), 'audience': post.community.public_url(),
'object': { 'object': {
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'object': post.profile_id(), 'object': post.public_url(),
'type': undo, 'type': undo,
'id': f"https://{current_app.config['SERVER_NAME']}/activities/{undo.lower()}/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/{undo.lower()}/{gibberish(15)}",
'audience': post.community.profile_id() 'audience': post.community.public_url()
} }
} }
else: else:
action_type = 'Like' if vote_direction == 'upvote' else 'Dislike' action_type = 'Like' if vote_direction == 'upvote' else 'Dislike'
action_json = { action_json = {
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'object': post.profile_id(), 'object': post.public_url(),
'type': action_type, 'type': action_type,
'id': f"https://{current_app.config['SERVER_NAME']}/activities/{action_type.lower()}/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/{action_type.lower()}/{gibberish(15)}",
'audience': post.community.profile_id() 'audience': post.community.public_url()
} }
if post.community.is_local(): if post.community.is_local():
announce = { announce = {
@ -415,7 +415,7 @@ def post_vote(post_id: int, vote_direction):
"to": [ "to": [
"https://www.w3.org/ns/activitystreams#Public" "https://www.w3.org/ns/activitystreams#Public"
], ],
"actor": post.community.ap_profile_id, "actor": post.community.public_url(),
"cc": [ "cc": [
post.community.ap_followers_url post.community.ap_followers_url
], ],
@ -427,7 +427,7 @@ def post_vote(post_id: int, vote_direction):
send_to_remote_instance(instance.id, post.community.id, announce) send_to_remote_instance(instance.id, post.community.id, announce)
else: else:
success = post_request_in_background(post.community.ap_inbox_url, action_json, current_user.private_key, success = post_request_in_background(post.community.ap_inbox_url, action_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash('Failed to send vote', 'warning') flash('Failed to send vote', 'warning')
@ -499,26 +499,26 @@ def comment_vote(comment_id, vote_direction):
if not comment.community.local_only: if not comment.community.local_only:
if undo: if undo:
action_json = { action_json = {
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'type': 'Undo', 'type': 'Undo',
'id': f"https://{current_app.config['SERVER_NAME']}/activities/undo/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/undo/{gibberish(15)}",
'audience': comment.community.profile_id(), 'audience': comment.community.public_url(),
'object': { 'object': {
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'object': comment.profile_id(), 'object': comment.public_url(),
'type': undo, 'type': undo,
'id': f"https://{current_app.config['SERVER_NAME']}/activities/{undo.lower()}/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/{undo.lower()}/{gibberish(15)}",
'audience': comment.community.profile_id() 'audience': comment.community.public_url()
} }
} }
else: else:
action_type = 'Like' if vote_direction == 'upvote' else 'Dislike' action_type = 'Like' if vote_direction == 'upvote' else 'Dislike'
action_json = { action_json = {
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'object': comment.profile_id(), 'object': comment.public_url(),
'type': action_type, 'type': action_type,
'id': f"https://{current_app.config['SERVER_NAME']}/activities/{action_type.lower()}/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/{action_type.lower()}/{gibberish(15)}",
'audience': comment.community.profile_id() 'audience': comment.community.public_url()
} }
if comment.community.is_local(): if comment.community.is_local():
announce = { announce = {
@ -539,7 +539,7 @@ def comment_vote(comment_id, vote_direction):
send_to_remote_instance(instance.id, comment.community.id, announce) send_to_remote_instance(instance.id, comment.community.id, announce)
else: else:
success = post_request_in_background(comment.community.ap_inbox_url, action_json, current_user.private_key, success = post_request_in_background(comment.community.ap_inbox_url, action_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash('Failed to send vote', 'warning') flash('Failed to send vote', 'warning')
@ -592,7 +592,7 @@ def poll_vote(post_id):
'object': { 'object': {
'attributedTo': current_user.public_url(), 'attributedTo': current_user.public_url(),
'id': f"https://{current_app.config['SERVER_NAME']}/activities/vote/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/vote/{gibberish(15)}",
'inReplyTo': post.profile_id(), 'inReplyTo': post.public_url(),
'name': pv.choice_text, 'name': pv.choice_text,
'to': post.author.public_url(), 'to': post.author.public_url(),
'type': 'Note' 'type': 'Note'
@ -602,7 +602,7 @@ def poll_vote(post_id):
} }
try: try:
post_request(post.author.ap_inbox_url, pollvote_json, current_user.private_key, post_request(post.author.ap_inbox_url, pollvote_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
except Exception: except Exception:
pass pass
@ -741,7 +741,7 @@ def add_reply(post_id: int, comment_id: int):
if not post.community.local_only: if not post.community.local_only:
reply_json = { reply_json = {
'type': 'Note', 'type': 'Note',
'id': reply.profile_id(), 'id': reply.public_url(),
'attributedTo': current_user.public_url(), 'attributedTo': current_user.public_url(),
'to': [ 'to': [
'https://www.w3.org/ns/activitystreams#Public' 'https://www.w3.org/ns/activitystreams#Public'
@ -751,8 +751,8 @@ def add_reply(post_id: int, comment_id: int):
in_reply_to.author.public_url() in_reply_to.author.public_url()
], ],
'content': reply.body_html, 'content': reply.body_html,
'inReplyTo': in_reply_to.profile_id(), 'inReplyTo': in_reply_to.public_url(),
'url': reply.profile_id(), 'url': reply.public_url(),
'mediaType': 'text/html', 'mediaType': 'text/html',
'published': ap_datetime(utcnow()), 'published': ap_datetime(utcnow()),
'distinguished': False, 'distinguished': False,
@ -793,7 +793,7 @@ def add_reply(post_id: int, comment_id: int):
] ]
if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it
success = post_request(post.community.ap_inbox_url, create_json, current_user.private_key, success = post_request(post.community.ap_inbox_url, create_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash('Failed to send reply', 'error') flash('Failed to send reply', 'error')
else: # local community - send it to followers on remote instances else: # local community - send it to followers on remote instances
@ -819,12 +819,12 @@ def add_reply(post_id: int, comment_id: int):
if not in_reply_to.author.is_local() and in_reply_to.author.ap_domain != reply.community.ap_domain: if not in_reply_to.author.is_local() and in_reply_to.author.ap_domain != reply.community.ap_domain:
if not post.community.is_local() or (post.community.is_local and not post.community.has_followers_from_domain(in_reply_to.author.ap_domain)): if not post.community.is_local() or (post.community.is_local and not post.community.has_followers_from_domain(in_reply_to.author.ap_domain)):
success = post_request(in_reply_to.author.ap_inbox_url, create_json, current_user.private_key, success = post_request(in_reply_to.author.ap_inbox_url, create_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
# sending to shared inbox is good enough for Mastodon, but Lemmy will reject it the local community has no followers # sending to shared inbox is good enough for Mastodon, but Lemmy will reject it the local community has no followers
personal_inbox = in_reply_to.author.public_url() + '/inbox' personal_inbox = in_reply_to.author.public_url() + '/inbox'
post_request(personal_inbox, create_json, current_user.private_key, post_request(personal_inbox, create_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if reply.depth <= constants.THREAD_CUTOFF_DEPTH: if reply.depth <= constants.THREAD_CUTOFF_DEPTH:
return redirect(url_for('activitypub.post_ap', post_id=post_id, _anchor=f'comment_{reply.id}')) return redirect(url_for('activitypub.post_ap', post_id=post_id, _anchor=f'comment_{reply.id}'))
@ -1312,9 +1312,9 @@ def federate_post_update(post):
update_json = { update_json = {
'id': f"https://{current_app.config['SERVER_NAME']}/activities/update/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/update/{gibberish(15)}",
'type': 'Update', 'type': 'Update',
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'audience': post.community.profile_id(), 'audience': post.community.public_url(),
'to': [post.community.profile_id(), 'https://www.w3.org/ns/activitystreams#Public'], 'to': [post.community.public_url(), 'https://www.w3.org/ns/activitystreams#Public'],
'published': ap_datetime(utcnow()), 'published': ap_datetime(utcnow()),
'cc': [ 'cc': [
current_user.followers_url() current_user.followers_url()
@ -1356,7 +1356,7 @@ def federate_post_update(post):
if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it
success = post_request(post.community.ap_inbox_url, update_json, current_user.private_key, success = post_request(post.community.ap_inbox_url, update_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash('Failed to send edit to remote server', 'error') flash('Failed to send edit to remote server', 'error')
else: # local community - send it to followers on remote instances else: # local community - send it to followers on remote instances
@ -1458,7 +1458,7 @@ def federate_post_edit_to_user_followers(post):
instances = Instance.query.join(User, User.instance_id == Instance.id).join(UserFollower, UserFollower.remote_user_id == User.id) instances = Instance.query.join(User, User.instance_id == Instance.id).join(UserFollower, UserFollower.remote_user_id == User.id)
instances = instances.filter(UserFollower.local_user_id == post.user_id) instances = instances.filter(UserFollower.local_user_id == post.user_id)
for i in instances: for i in instances:
post_request(i.inbox, update, current_user.private_key, current_user.profile_id() + '#main-key') post_request(i.inbox, update, current_user.private_key, current_user.public_url() + '#main-key')
@bp.route('/post/<int:post_id>/delete', methods=['GET', 'POST']) @bp.route('/post/<int:post_id>/delete', methods=['GET', 'POST'])
@ -1483,9 +1483,9 @@ def post_delete(post_id: int):
delete_json = { delete_json = {
'id': f"https://{current_app.config['SERVER_NAME']}/activities/delete/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/delete/{gibberish(15)}",
'type': 'Delete', 'type': 'Delete',
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'audience': post.community.profile_id(), 'audience': post.community.public_url(),
'to': [post.community.profile_id(), 'https://www.w3.org/ns/activitystreams#Public'], 'to': [post.community.public_url(), 'https://www.w3.org/ns/activitystreams#Public'],
'published': ap_datetime(utcnow()), 'published': ap_datetime(utcnow()),
'cc': [ 'cc': [
current_user.followers_url() current_user.followers_url()
@ -1499,7 +1499,7 @@ def post_delete(post_id: int):
if not community.local_only: if not community.local_only:
if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it
success = post_request(post.community.ap_inbox_url, delete_json, current_user.private_key, success = post_request(post.community.ap_inbox_url, delete_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash('Failed to send delete to remote server', 'error') flash('Failed to send delete to remote server', 'error')
else: # local community - send it to followers on remote instances else: # local community - send it to followers on remote instances
@ -1527,7 +1527,7 @@ def post_delete(post_id: int):
instances = Instance.query.join(User, User.instance_id == Instance.id).join(UserFollower, UserFollower.remote_user_id == User.id) instances = Instance.query.join(User, User.instance_id == Instance.id).join(UserFollower, UserFollower.remote_user_id == User.id)
instances = instances.filter(UserFollower.local_user_id == post.user_id) instances = instances.filter(UserFollower.local_user_id == post.user_id)
for i in instances: for i in instances:
post_request(i.inbox, delete_json, current_user.private_key, current_user.profile_id() + '#main-key') post_request(i.inbox, delete_json, current_user.private_key, current_user.public_url() + '#main-key')
return redirect(url_for('activitypub.community_profile', actor=community.ap_id if community.ap_id is not None else community.name)) return redirect(url_for('activitypub.community_profile', actor=community.ap_id if community.ap_id is not None else community.name))
@ -1543,14 +1543,14 @@ def post_restore(post_id: int):
# Federate un-delete # Federate un-delete
if post.is_local(): if post.is_local():
delete_json = { delete_json = {
"actor": current_user.profile_id(), "actor": current_user.public_url(),
"to": ["https://www.w3.org/ns/activitystreams#Public"], "to": ["https://www.w3.org/ns/activitystreams#Public"],
"object": { "object": {
'id': f"https://{current_app.config['SERVER_NAME']}/activities/delete/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/delete/{gibberish(15)}",
'type': 'Delete', 'type': 'Delete',
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'audience': post.community.profile_id(), 'audience': post.community.public_url(),
'to': [post.community.profile_id(), 'https://www.w3.org/ns/activitystreams#Public'], 'to': [post.community.public_url(), 'https://www.w3.org/ns/activitystreams#Public'],
'published': ap_datetime(utcnow()), 'published': ap_datetime(utcnow()),
'cc': [ 'cc': [
current_user.followers_url() current_user.followers_url()
@ -1559,8 +1559,8 @@ def post_restore(post_id: int):
'uri': post.ap_id, 'uri': post.ap_id,
"summary": "bad post", "summary": "bad post",
}, },
"cc": [post.community.profile_id()], "cc": [post.community.public_url()],
"audience": post.author.profile_id(), "audience": post.author.public_url(),
"type": "Undo", "type": "Undo",
"id": f"https://{current_app.config['SERVER_NAME']}/activities/undo/{gibberish(15)}" "id": f"https://{current_app.config['SERVER_NAME']}/activities/undo/{gibberish(15)}"
} }
@ -1571,7 +1571,7 @@ def post_restore(post_id: int):
"to": [ "to": [
"https://www.w3.org/ns/activitystreams#Public" "https://www.w3.org/ns/activitystreams#Public"
], ],
"actor": post.community.ap_profile_id, "actor": post.community.public_url(),
"cc": [ "cc": [
post.community.ap_followers_url post.community.ap_followers_url
], ],
@ -1626,21 +1626,21 @@ def post_report(post_id: int):
if form.description.data: if form.description.data:
summary += ' - ' + form.description.data summary += ' - ' + form.description.data
report_json = { report_json = {
"actor": current_user.profile_id(), "actor": current_user.public_url(),
"audience": post.community.profile_id(), "audience": post.community.public_url(),
"content": None, "content": None,
"id": f"https://{current_app.config['SERVER_NAME']}/activities/flag/{gibberish(15)}", "id": f"https://{current_app.config['SERVER_NAME']}/activities/flag/{gibberish(15)}",
"object": post.ap_id, "object": post.ap_id,
"summary": summary, "summary": summary,
"to": [ "to": [
post.community.profile_id() post.community.public_url()
], ],
"type": "Flag" "type": "Flag"
} }
instance = Instance.query.get(post.community.instance_id) instance = Instance.query.get(post.community.instance_id)
if post.community.ap_inbox_url and not current_user.has_blocked_instance(instance.id) and not instance_banned(instance.domain): if post.community.ap_inbox_url and not current_user.has_blocked_instance(instance.id) and not instance_banned(instance.domain):
success = post_request(post.community.ap_inbox_url, report_json, current_user.private_key, success = post_request(post.community.ap_inbox_url, report_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash('Failed to send report to remote server', 'error') flash('Failed to send report to remote server', 'error')
@ -1762,14 +1762,14 @@ def post_reply_report(post_id: int, comment_id: int):
if form.description.data: if form.description.data:
summary += ' - ' + form.description.data summary += ' - ' + form.description.data
report_json = { report_json = {
"actor": current_user.profile_id(), "actor": current_user.public_url(),
"audience": post.community.profile_id(), "audience": post.community.public_url(),
"content": None, "content": None,
"id": f"https://{current_app.config['SERVER_NAME']}/activities/flag/{gibberish(15)}", "id": f"https://{current_app.config['SERVER_NAME']}/activities/flag/{gibberish(15)}",
"object": post_reply.ap_id, "object": post_reply.ap_id,
"summary": summary, "summary": summary,
"to": [ "to": [
post.community.profile_id() post.community.public_url()
], ],
"type": "Flag" "type": "Flag"
} }
@ -1777,7 +1777,7 @@ def post_reply_report(post_id: int, comment_id: int):
if post.community.ap_inbox_url and not current_user.has_blocked_instance( if post.community.ap_inbox_url and not current_user.has_blocked_instance(
instance.id) and not instance_banned(instance.domain): instance.id) and not instance_banned(instance.domain):
success = post_request(post.community.ap_inbox_url, report_json, current_user.private_key, success = post_request(post.community.ap_inbox_url, report_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash('Failed to send report to remote server', 'error') flash('Failed to send report to remote server', 'error')
@ -1852,7 +1852,7 @@ def post_reply_edit(post_id: int, comment_id: int):
if not post.community.local_only: if not post.community.local_only:
reply_json = { reply_json = {
'type': 'Note', 'type': 'Note',
'id': post_reply.profile_id(), 'id': post_reply.public_url(),
'attributedTo': current_user.public_url(), 'attributedTo': current_user.public_url(),
'to': [ 'to': [
'https://www.w3.org/ns/activitystreams#Public' 'https://www.w3.org/ns/activitystreams#Public'
@ -1862,8 +1862,8 @@ def post_reply_edit(post_id: int, comment_id: int):
in_reply_to.author.public_url() in_reply_to.author.public_url()
], ],
'content': post_reply.body_html, 'content': post_reply.body_html,
'inReplyTo': in_reply_to.profile_id(), 'inReplyTo': in_reply_to.public_url(),
'url': post_reply.profile_id(), 'url': post_reply.public_url(),
'mediaType': 'text/html', 'mediaType': 'text/html',
'published': ap_datetime(post_reply.posted_at), 'published': ap_datetime(post_reply.posted_at),
'updated': ap_datetime(post_reply.edited_at), 'updated': ap_datetime(post_reply.edited_at),
@ -1909,7 +1909,7 @@ def post_reply_edit(post_id: int, comment_id: int):
] ]
if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it
success = post_request(post.community.ap_inbox_url, update_json, current_user.private_key, success = post_request(post.community.ap_inbox_url, update_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash('Failed to send send edit to remote server', 'error') flash('Failed to send send edit to remote server', 'error')
else: # local community - send it to followers on remote instances else: # local community - send it to followers on remote instances
@ -1935,12 +1935,12 @@ def post_reply_edit(post_id: int, comment_id: int):
if not in_reply_to.author.is_local() and in_reply_to.author.ap_domain != post_reply.community.ap_domain: if not in_reply_to.author.is_local() and in_reply_to.author.ap_domain != post_reply.community.ap_domain:
if not post.community.is_local() or (post.community.is_local and not post.community.has_followers_from_domain(in_reply_to.author.ap_domain)): if not post.community.is_local() or (post.community.is_local and not post.community.has_followers_from_domain(in_reply_to.author.ap_domain)):
success = post_request(in_reply_to.author.ap_inbox_url, update_json, current_user.private_key, success = post_request(in_reply_to.author.ap_inbox_url, update_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
# sending to shared inbox is good enough for Mastodon, but Lemmy will reject it the local community has no followers # sending to shared inbox is good enough for Mastodon, but Lemmy will reject it the local community has no followers
personal_inbox = in_reply_to.author.public_url() + '/inbox' personal_inbox = in_reply_to.author.public_url() + '/inbox'
post_request(personal_inbox, update_json, current_user.private_key, post_request(personal_inbox, update_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
return redirect(url_for('activitypub.post_ap', post_id=post.id)) return redirect(url_for('activitypub.post_ap', post_id=post.id))
else: else:
@ -1978,9 +1978,9 @@ def post_reply_delete(post_id: int, comment_id: int):
delete_json = { delete_json = {
'id': f"https://{current_app.config['SERVER_NAME']}/activities/delete/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/delete/{gibberish(15)}",
'type': 'Delete', 'type': 'Delete',
'actor': current_user.profile_id(), 'actor': current_user.public_url(),
'audience': post.community.profile_id(), 'audience': post.community.public_url(),
'to': [post.community.profile_id(), 'https://www.w3.org/ns/activitystreams#Public'], 'to': [post.community.public_url(), 'https://www.w3.org/ns/activitystreams#Public'],
'published': ap_datetime(utcnow()), 'published': ap_datetime(utcnow()),
'cc': [ 'cc': [
current_user.followers_url() current_user.followers_url()
@ -1992,7 +1992,7 @@ def post_reply_delete(post_id: int, comment_id: int):
if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it
success = post_request(post.community.ap_inbox_url, delete_json, current_user.private_key, success = post_request(post.community.ap_inbox_url, delete_json, current_user.private_key,
current_user.profile_id() + '#main-key') current_user.public_url() + '#main-key')
if not success: if not success:
flash('Failed to send delete to remote server', 'error') flash('Failed to send delete to remote server', 'error')
else: # local community - send it to followers on remote instances else: # local community - send it to followers on remote instances

View file

@ -38,7 +38,7 @@
</form> </form>
<p class="mt-4"> <p class="mt-4">
{% if not user.is_local() %} {% if not user.is_local() %}
<a href="{{ user.profile_id() }}" class="btn btn-primary">View original profile</a> <a href="{{ user.public_url() }}" class="btn btn-primary">View original profile</a>
{% endif %} {% endif %}
</p> </p>
</div> </div>

View file

@ -149,7 +149,7 @@
{% endif -%} {% endif -%}
{% if not community.is_local() -%} {% if not community.is_local() -%}
<ul> <ul>
<li><p><a href="{{ community.profile_id() }}">{{ _('View community on original server') }}</a></p></li> <li><p><a href="{{ community.public_url() }}">{{ _('View community on original server') }}</a></p></li>
<li><p><a href="{{ url_for('community.retrieve_remote_post', community_id=community.id) }}">{{ _('Retrieve a post from the original server') }}</a></p></li> <li><p><a href="{{ url_for('community.retrieve_remote_post', community_id=community.id) }}">{{ _('Retrieve a post from the original server') }}</a></p></li>
</ul> </ul>
{% endif -%} {% endif -%}

View file

@ -11,7 +11,7 @@
<div class="col-12 col-md-8 position-relative add_reply main_pane"> <div class="col-12 col-md-8 position-relative add_reply main_pane">
<fieldset class="coolfieldset mt-4"><legend class="w-auto">Original post</legend> <fieldset class="coolfieldset mt-4"><legend class="w-auto">Original post</legend>
<h3>{{ post.title }}</h3> <h3>{{ post.title }}</h3>
{{ post.body_html | safe }} {{ post.body_html|safe if post.body_html }}
</fieldset> </fieldset>
{% if comment %} {% if comment %}
<fieldset class="coolfieldset mt-4"><legend class="w-auto">Comment you are replying to</legend> <fieldset class="coolfieldset mt-4"><legend class="w-auto">Comment you are replying to</legend>

View file

@ -273,11 +273,11 @@ def send_community_follow(community_id, join_request_id, user_id):
user = User.query.get(user_id) user = User.query.get(user_id)
community = Community.query.get(community_id) community = Community.query.get(community_id)
follow = { follow = {
"actor": current_user.profile_id(), "actor": current_user.public_url(),
"to": [community.ap_profile_id], "to": [community.public_url()],
"object": community.ap_profile_id, "object": community.public_url(),
"type": "Follow", "type": "Follow",
"id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{join_request_id}" "id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{join_request_id}"
} }
success = post_request(community.ap_inbox_url, follow, user.private_key, success = post_request(community.ap_inbox_url, follow, user.private_key,
user.profile_id() + '#main-key') user.public_url() + '#main-key')

View file

@ -560,9 +560,9 @@ def send_deletion_requests(user_id):
instances = Instance.query.filter(Instance.dormant == False).all() instances = Instance.query.filter(Instance.dormant == False).all()
payload = { payload = {
"@context": default_context(), "@context": default_context(),
"actor": user.profile_id(), "actor": user.public_url(),
"id": f"{user.profile_id()}#delete", "id": f"{user.public_url()}#delete",
"object": user.profile_id(), "object": user.public_url(),
"to": [ "to": [
"https://www.w3.org/ns/activitystreams#Public" "https://www.w3.org/ns/activitystreams#Public"
], ],
@ -570,7 +570,7 @@ def send_deletion_requests(user_id):
} }
for instance in instances: for instance in instances:
if instance.inbox and instance.online() and instance.id != 1: # instance id 1 is always the current instance if instance.inbox and instance.online() and instance.id != 1: # instance id 1 is always the current instance
post_request(instance.inbox, payload, user.private_key, f"{user.profile_id()}#main-key") post_request(instance.inbox, payload, user.private_key, f"{user.public_url()}#main-key")
sleep(5) sleep(5)
@ -704,14 +704,14 @@ def import_settings_task(user_id, filename):
db.session.add(join_request) db.session.add(join_request)
db.session.commit() db.session.commit()
follow = { follow = {
"actor": current_user.profile_id(), "actor": current_user.public_url(),
"to": [community.ap_profile_id], "to": [community.public_url()],
"object": community.ap_profile_id, "object": community.public_url(),
"type": "Follow", "type": "Follow",
"id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{join_request.id}" "id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{join_request.id}"
} }
success = post_request(community.ap_inbox_url, follow, user.private_key, success = post_request(community.ap_inbox_url, follow, user.private_key,
user.profile_id() + '#main-key') user.public_url() + '#main-key')
if not success: if not success:
sleep(5) # give them a rest sleep(5) # give them a rest
else: # for local communities, joining is instant else: # for local communities, joining is instant

View file

@ -27,9 +27,9 @@ def purge_user_then_delete_task(user_id):
delete_json = { delete_json = {
'id': f"https://{current_app.config['SERVER_NAME']}/activities/delete/{gibberish(15)}", 'id': f"https://{current_app.config['SERVER_NAME']}/activities/delete/{gibberish(15)}",
'type': 'Delete', 'type': 'Delete',
'actor': user.profile_id(), 'actor': user.public_url(),
'audience': post.community.profile_id(), 'audience': post.community.public_url(),
'to': [post.community.profile_id(), 'https://www.w3.org/ns/activitystreams#Public'], 'to': [post.community.public_url(), 'https://www.w3.org/ns/activitystreams#Public'],
'published': ap_datetime(utcnow()), 'published': ap_datetime(utcnow()),
'cc': [ 'cc': [
user.followers_url() user.followers_url()
@ -39,7 +39,7 @@ def purge_user_then_delete_task(user_id):
if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it if not post.community.is_local(): # this is a remote community, send it to the instance that hosts it
success = post_request(post.community.ap_inbox_url, delete_json, user.private_key, success = post_request(post.community.ap_inbox_url, delete_json, user.private_key,
user.profile_id() + '#main-key') user.public_url() + '#main-key')
else: # local community - send it to followers on remote instances, using Announce else: # local community - send it to followers on remote instances, using Announce
announce = { announce = {
@ -81,7 +81,7 @@ def purge_user_then_delete_task(user_id):
} }
for instance in instances: for instance in instances:
if instance.inbox and instance.id != 1: if instance.inbox and instance.id != 1:
post_request(instance.inbox, payload, user.private_key, user.profile_id() + '#main-key') post_request(instance.inbox, payload, user.private_key, user.public_url() + '#main-key')
sleep(100) # wait a while for any related activitypub traffic to die down. sleep(100) # wait a while for any related activitypub traffic to die down.
user.deleted = True user.deleted = True
@ -93,15 +93,15 @@ def purge_user_then_delete_task(user_id):
def unsubscribe_from_community(community, user): def unsubscribe_from_community(community, user):
undo_id = f"https://{current_app.config['SERVER_NAME']}/activities/undo/" + gibberish(15) undo_id = f"https://{current_app.config['SERVER_NAME']}/activities/undo/" + gibberish(15)
follow = { follow = {
"actor": user.profile_id(), "actor": user.public_url(),
"to": [community.ap_profile_id], "to": [community.public_url()],
"object": community.ap_profile_id, "object": community.public_url(),
"type": "Follow", "type": "Follow",
"id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{gibberish(15)}" "id": f"https://{current_app.config['SERVER_NAME']}/activities/follow/{gibberish(15)}"
} }
undo = { undo = {
'actor': user.profile_id(), 'actor': user.public_url(),
'to': [community.ap_profile_id], 'to': [community.public_url()],
'type': 'Undo', 'type': 'Undo',
'id': undo_id, 'id': undo_id,
'object': follow 'object': follow
@ -110,7 +110,7 @@ def unsubscribe_from_community(community, user):
activity_json=json.dumps(undo), result='processing') activity_json=json.dumps(undo), result='processing')
db.session.add(activity) db.session.add(activity)
db.session.commit() db.session.commit()
post_request(community.ap_inbox_url, undo, user.private_key, user.profile_id() + '#main-key') post_request(community.ap_inbox_url, undo, user.private_key, user.public_url() + '#main-key')
activity.result = 'success' activity.result = 'success'
db.session.commit() db.session.commit()