123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- # frozen_string_literal: true
- class Api::V1::Push::SubscriptionsController < Api::BaseController
- before_action -> { doorkeeper_authorize! :push }
- before_action :require_user!
- before_action :set_push_subscription
- before_action :check_push_subscription, only: [:show, :update]
- def show
- render json: @push_subscription, serializer: REST::WebPushSubscriptionSerializer
- end
- def create
- @push_subscription&.destroy!
- @push_subscription = Web::PushSubscription.create!(
- endpoint: subscription_params[:endpoint],
- key_p256dh: subscription_params[:keys][:p256dh],
- key_auth: subscription_params[:keys][:auth],
- data: data_params,
- user_id: current_user.id,
- access_token_id: doorkeeper_token.id
- )
- render json: @push_subscription, serializer: REST::WebPushSubscriptionSerializer
- end
- def update
- @push_subscription.update!(data: data_params)
- render json: @push_subscription, serializer: REST::WebPushSubscriptionSerializer
- end
- def destroy
- @push_subscription&.destroy!
- render_empty
- end
- private
- def set_push_subscription
- @push_subscription = Web::PushSubscription.find_by(access_token_id: doorkeeper_token.id)
- end
- def check_push_subscription
- not_found if @push_subscription.nil?
- end
- def subscription_params
- params.require(:subscription).permit(:endpoint, keys: [:auth, :p256dh])
- end
- def data_params
- return {} if params[:data].blank?
- params.require(:data).permit(:policy, alerts: Notification::TYPES)
- end
- end
|