diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2017-06-08 15:07:39 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-06-08 15:07:39 +0200 |
commit | b87eb8ea146a54fcfd2533f47622070d0f30a9fa (patch) | |
tree | 40aea8cfa0bd2a61cbf4c1a11884d3c7148e59da /app/services/favourite_service.rb | |
parent | 8902e265b4efea68cafef790ee0e2870f62985cd (diff) |
Fix #3378 - If favourite/reblog already exists, return it instead of failing (#3641)
Diffstat (limited to 'app/services/favourite_service.rb')
-rw-r--r-- | app/services/favourite_service.rb | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/app/services/favourite_service.rb b/app/services/favourite_service.rb index f27145c96..90267af33 100644 --- a/app/services/favourite_service.rb +++ b/app/services/favourite_service.rb @@ -10,6 +10,10 @@ class FavouriteService < BaseService def call(account, status) authorize_with account, status, :show? + favourite = Favourite.find_by(account: account, status: status) + + return favourite unless favourite.nil? + favourite = Favourite.create!(account: account, status: status) if status.local? |