mastodon/app
ThibG cd4ec7cd74
Do not serve account actors at all in limited federation mode (#14800)
* Do not serve account actors at all in limited federation mode

When an account is fetched without a signature from an allowed instance,
return an error.

This isn't really an improvement in security, as the only information that was
previously returned was required protocol-level info, and the only personal bit
was the existence of the account. The existence of the account can still be
checked by issuing a webfinger query, as those are accepted without signatures.

However, this change makes it so that unallowed instances won't create account
records on their end when they find a reference to an unknown account.

The previous behavior of rendering a limited list of fields, instead of not
rendering the actor at all, was in order to prevent situations in which two
instances in Authorized Fetch mode or Limited Federation mode would fail to
reach each other because resolving an account would require a signed query…
from an account which can only be fetched with a signed query itself. However,
this should now be fine as fetching accounts is done by signing on behalf of
the special instance actor, which does not require any kind of valid signature
to be fetched.

* Fix tests
2020-09-14 13:04:29 +02:00
..
chewy Change `tootctl search deploy` algorithm (#14300) 2020-07-14 18:10:35 +02:00
controllers Do not serve account actors at all in limited federation mode (#14800) 2020-09-14 13:04:29 +02:00
helpers Bump rubocop from 0.86.0 to 0.88.0 (#14412) 2020-09-01 03:04:00 +02:00
javascript Add border around 🕺 emoji (#14769) 2020-09-10 19:08:03 +02:00
lib Refactor feed manager (#14761) 2020-09-08 03:41:16 +02:00
mailers Add WebAuthn as an alternative 2FA method (#14466) 2020-08-24 16:46:27 +02:00
models Fix reported statuses not being included in warning e-mail (#14778) 2020-09-13 12:52:17 +02:00
policies Change REST API to return empty data for suspended accounts (#14765) 2020-09-11 15:16:29 +02:00
presenters Add user notes on accounts (#14148) 2020-06-30 19:19:50 +02:00
serializers Change REST API to return empty data for suspended accounts (#14765) 2020-09-11 15:16:29 +02:00
services Refactor feed manager (#14761) 2020-09-08 03:41:16 +02:00
validators Improve email address validation (#14565) 2020-08-12 12:40:25 +02:00
views Refactor settings controllers (#14767) 2020-09-11 20:56:35 +02:00
workers Refactor feed manager (#14761) 2020-09-08 03:41:16 +02:00