diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2016-12-22 21:34:19 +0100 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2016-12-22 21:34:19 +0100 |
commit | 2d2154ba75279186b064c887452b7d6ee70b8ba2 (patch) | |
tree | e27a84e2245184c899f2b347d63af16210973660 /app/services | |
parent | f91b6fa9e15029f23be7be3b796eca122e5b5588 (diff) |
Add "locked" flag to accounts, prevent blocked users from following, force-unfollow blocked users
Diffstat (limited to 'app/services')
-rw-r--r-- | app/services/block_service.rb | 3 | ||||
-rw-r--r-- | app/services/follow_service.rb | 1 |
2 files changed, 4 insertions, 0 deletions
diff --git a/app/services/block_service.rb b/app/services/block_service.rb index 6a032a5a1..66146a72a 100644 --- a/app/services/block_service.rb +++ b/app/services/block_service.rb @@ -5,7 +5,10 @@ class BlockService < BaseService return if account.id == target_account.id UnfollowService.new.call(account, target_account) if account.following?(target_account) + UnfollowService.new.call(target_account, account) if target_account.following?(account) + account.block!(target_account) + clear_timelines(account, target_account) clear_notifications(account, target_account) end diff --git a/app/services/follow_service.rb b/app/services/follow_service.rb index ed9b62455..02baa6553 100644 --- a/app/services/follow_service.rb +++ b/app/services/follow_service.rb @@ -8,6 +8,7 @@ class FollowService < BaseService target_account = follow_remote_account_service.call(uri) raise ActiveRecord::RecordNotFound if target_account.nil? || target_account.id == source_account.id || target_account.suspended? + raise Mastodon::NotPermitted if target_account.blocking?(source_account) follow = source_account.follow!(target_account) |