summaryrefslogtreecommitdiffstats
path: root/app/services/process_interaction_service.rb
diff options
context:
space:
mode:
authorEugen Rochko <eugen@zeonfederated.com>2017-05-27 00:53:38 +0200
committerGitHub <noreply@github.com>2017-05-27 00:53:38 +0200
commit44cb08297c4fd992f3438b8cac99e1364edd4847 (patch)
tree79b843bccb0c4db0b75dca7b99c97ce64fb3196a /app/services/process_interaction_service.rb
parentbd21afb5edf58a2ce93d0d61ac5ccbada5d857da (diff)
Fix some nil errors (#3338)
* Fix nil input not handled well in AuthorExtractor concern * Fix hard error in ProcessFeedService when replied-to status has been deleted * Fix nil errors in ProcessInteractionService when favourited status cannot be found
Diffstat (limited to 'app/services/process_interaction_service.rb')
-rw-r--r--app/services/process_interaction_service.rb6
1 files changed, 6 insertions, 0 deletions
diff --git a/app/services/process_interaction_service.rb b/app/services/process_interaction_service.rb
index e9c01103d58..bd9afaf2eff 100644
--- a/app/services/process_interaction_service.rb
+++ b/app/services/process_interaction_service.rb
@@ -108,12 +108,18 @@ class ProcessInteractionService < BaseService
def favourite!(xml, from_account)
current_status = status(xml)
+
+ return if current_status.nil?
+
favourite = current_status.favourites.where(account: from_account).first_or_create!(account: from_account)
NotifyService.new.call(current_status.account, favourite)
end
def unfavourite!(xml, from_account)
current_status = status(xml)
+
+ return if current_status.nil?
+
favourite = current_status.favourites.where(account: from_account).first
favourite&.destroy
end