diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2017-03-02 18:50:33 +0100 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2017-03-02 18:50:33 +0100 |
commit | 4c0e9f85c5c9e3be91f9a76139fab3b55abbf363 (patch) | |
tree | 9d60c6b37a6adb60b20a674630587de4e55d8765 /app/services/mute_service.rb | |
parent | 89fc2d7f4810ecdf66b17543f4603c1089a0c3f5 (diff) | |
parent | c64a1c25c4e9a07c694863a38334ed66e368752e (diff) |
Merge branch 'KitRedgrave-add-mute-button'
Diffstat (limited to 'app/services/mute_service.rb')
-rw-r--r-- | app/services/mute_service.rb | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/app/services/mute_service.rb b/app/services/mute_service.rb new file mode 100644 index 000000000..0050cfc8d --- /dev/null +++ b/app/services/mute_service.rb @@ -0,0 +1,23 @@ +# frozen_string_literal: true + +class MuteService < BaseService + def call(account, target_account) + return if account.id == target_account.id + clear_home_timeline(account, target_account) + account.mute!(target_account) + end + + private + + def clear_home_timeline(account, target_account) + home_key = FeedManager.instance.key(:home, account.id) + + target_account.statuses.select('id').find_each do |status| + redis.zrem(home_key, status.id) + end + end + + def redis + Redis.current + end +end |