Improve spec coverage for api/web/push_subscriptions
controller (#27858)
Co-authored-by: Claire <claire.github-309c@sitedethib.com>
This commit is contained in:
parent
d67bd44ca1
commit
fe58ac8d9f
2 changed files with 86 additions and 52 deletions
|
@ -3,37 +3,13 @@
|
|||
class Api::Web::PushSubscriptionsController < Api::Web::BaseController
|
||||
before_action :require_user!
|
||||
before_action :set_push_subscription, only: :update
|
||||
before_action :destroy_previous_subscriptions, only: :create, if: :prior_subscriptions?
|
||||
after_action :update_session_with_subscription, only: :create
|
||||
|
||||
def create
|
||||
active_session = current_session
|
||||
@push_subscription = ::Web::PushSubscription.create!(web_push_subscription_params)
|
||||
|
||||
unless active_session.web_push_subscription.nil?
|
||||
active_session.web_push_subscription.destroy!
|
||||
active_session.update!(web_push_subscription: nil)
|
||||
end
|
||||
|
||||
# Mobile devices do not support regular notifications, so we enable push notifications by default
|
||||
alerts_enabled = active_session.detection.device.mobile? || active_session.detection.device.tablet?
|
||||
|
||||
data = {
|
||||
policy: 'all',
|
||||
alerts: Notification::TYPES.index_with { alerts_enabled },
|
||||
}
|
||||
|
||||
data.deep_merge!(data_params) if params[:data]
|
||||
|
||||
push_subscription = ::Web::PushSubscription.create!(
|
||||
endpoint: subscription_params[:endpoint],
|
||||
key_p256dh: subscription_params[:keys][:p256dh],
|
||||
key_auth: subscription_params[:keys][:auth],
|
||||
data: data,
|
||||
user_id: active_session.user_id,
|
||||
access_token_id: active_session.access_token_id
|
||||
)
|
||||
|
||||
active_session.update!(web_push_subscription: push_subscription)
|
||||
|
||||
render json: push_subscription, serializer: REST::WebPushSubscriptionSerializer
|
||||
render json: @push_subscription, serializer: REST::WebPushSubscriptionSerializer
|
||||
end
|
||||
|
||||
def update
|
||||
|
@ -43,6 +19,41 @@ class Api::Web::PushSubscriptionsController < Api::Web::BaseController
|
|||
|
||||
private
|
||||
|
||||
def active_session
|
||||
@active_session ||= current_session
|
||||
end
|
||||
|
||||
def destroy_previous_subscriptions
|
||||
active_session.web_push_subscription.destroy!
|
||||
active_session.update!(web_push_subscription: nil)
|
||||
end
|
||||
|
||||
def prior_subscriptions?
|
||||
active_session.web_push_subscription.present?
|
||||
end
|
||||
|
||||
def subscription_data
|
||||
default_subscription_data.tap do |data|
|
||||
data.deep_merge!(data_params) if params[:data]
|
||||
end
|
||||
end
|
||||
|
||||
def default_subscription_data
|
||||
{
|
||||
policy: 'all',
|
||||
alerts: Notification::TYPES.index_with { alerts_enabled },
|
||||
}
|
||||
end
|
||||
|
||||
def alerts_enabled
|
||||
# Mobile devices do not support regular notifications, so we enable push notifications by default
|
||||
active_session.detection.device.mobile? || active_session.detection.device.tablet?
|
||||
end
|
||||
|
||||
def update_session_with_subscription
|
||||
active_session.update!(web_push_subscription: @push_subscription)
|
||||
end
|
||||
|
||||
def set_push_subscription
|
||||
@push_subscription = ::Web::PushSubscription.find(params[:id])
|
||||
end
|
||||
|
@ -51,6 +62,17 @@ class Api::Web::PushSubscriptionsController < Api::Web::BaseController
|
|||
@subscription_params ||= params.require(:subscription).permit(:endpoint, keys: [:auth, :p256dh])
|
||||
end
|
||||
|
||||
def web_push_subscription_params
|
||||
{
|
||||
access_token_id: active_session.access_token_id,
|
||||
data: subscription_data,
|
||||
endpoint: subscription_params[:endpoint],
|
||||
key_auth: subscription_params[:keys][:auth],
|
||||
key_p256dh: subscription_params[:keys][:p256dh],
|
||||
user_id: active_session.user_id,
|
||||
}
|
||||
end
|
||||
|
||||
def data_params
|
||||
@data_params ||= params.require(:data).permit(:policy, alerts: Notification::TYPES)
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue