forked from mirrors/bookwyrm
Verify that the remote user is who they say they
This commit is contained in:
parent
1b48ca2f85
commit
373a378452
2 changed files with 4 additions and 0 deletions
|
@ -90,6 +90,7 @@ def shared_inbox(request):
|
|||
|
||||
|
||||
def get_public_key(key_actor):
|
||||
''' try a stored key or load it from remote '''
|
||||
try:
|
||||
user = models.User.objects.get(remote_id=key_actor)
|
||||
public_key = user.public_key
|
||||
|
|
|
@ -26,6 +26,9 @@ def get_or_create_remote_user(actor):
|
|||
response.raise_for_status()
|
||||
data = response.json()
|
||||
|
||||
# make sure our actor is who they say they are
|
||||
assert actor == data['id']
|
||||
|
||||
actor_parts = urlparse(actor)
|
||||
with transaction.atomic():
|
||||
user = create_remote_user(data)
|
||||
|
|
Loading…
Reference in a new issue