forked from cybrespace/mastodon
Fix guard clause in WebPushNotificationWorker (#4421)
This commit is contained in:
parent
6e186b9c77
commit
4e2f2fab73
|
@ -7,18 +7,19 @@ class WebPushNotificationWorker
|
||||||
|
|
||||||
def perform(session_activation_id, notification_id)
|
def perform(session_activation_id, notification_id)
|
||||||
session_activation = SessionActivation.find(session_activation_id)
|
session_activation = SessionActivation.find(session_activation_id)
|
||||||
notification = Notification.find(notification_id)
|
notification = Notification.find(notification_id)
|
||||||
|
|
||||||
return if session_activation.nil? || notification.nil?
|
return if session_activation.web_push_subscription.nil? || notification.activity.nil?
|
||||||
|
|
||||||
begin
|
session_activation.web_push_subscription.push(notification)
|
||||||
session_activation.web_push_subscription.push(notification)
|
rescue Webpush::InvalidSubscription, Webpush::ExpiredSubscription
|
||||||
rescue Webpush::InvalidSubscription, Webpush::ExpiredSubscription => e
|
# Subscription expiration is not currently implemented in any browser
|
||||||
# Subscription expiration is not currently implemented in any browser
|
|
||||||
session_activation.web_push_subscription.destroy!
|
|
||||||
session_activation.update!(web_push_subscription: nil)
|
|
||||||
|
|
||||||
raise e
|
session_activation.web_push_subscription.destroy!
|
||||||
end
|
session_activation.update!(web_push_subscription: nil)
|
||||||
|
|
||||||
|
true
|
||||||
|
rescue ActiveRecord::RecordNotFound
|
||||||
|
true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue