before_action :require_user!
def create
- params.require(:data).require(:endpoint)
- params.require(:data).require(:keys).require([:auth, :p256dh])
+ params.require(:subscription).require(:endpoint)
+ params.require(:subscription).require(:keys).require([:auth, :p256dh])
active_session = current_session
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 = {
+ alerts: {
+ follow: alerts_enabled,
+ favourite: alerts_enabled,
+ reblog: alerts_enabled,
+ mention: alerts_enabled,
+ },
+ }
+
web_subscription = ::Web::PushSubscription.create!(
- endpoint: params[:data][:endpoint],
- key_p256dh: params[:data][:keys][:p256dh],
- key_auth: params[:data][:keys][:auth]
+ endpoint: params[:subscription][:endpoint],
+ key_p256dh: params[:subscription][:keys][:p256dh],
+ key_auth: params[:subscription][:keys][:auth],
+ data: data
)
active_session.update!(web_push_subscription: web_subscription)
let(:create_payload) do
{
- data: {
+ subscription: {
endpoint: 'https://fcm.googleapis.com/fcm/send/fiuH06a27qE:APA91bHnSiGcLwdaxdyqVXNDR9w1NlztsHb6lyt5WDKOC_Z_Q8BlFxQoR8tWFSXUIDdkyw0EdvxTu63iqamSaqVSevW5LfoFwojws8XYDXv_NRRLH6vo2CdgiN4jgHv5VLt2A8ah6lUX',
keys: {
p256dh: 'BEm_a0bdPDhf0SOsrnB2-ategf1hHoCnpXgQsFj5JCkcoMrMt2WHoPfEYOYPzOIs9mZE8ZUaD7VA5vouy0kEkr8=',
it 'saves push subscriptions' do
sign_in(user)
- stub_request(:post, create_payload[:data][:endpoint]).to_return(status: 200)
+ stub_request(:post, create_payload[:subscription][:endpoint]).to_return(status: 200)
post :create, format: :json, params: create_payload
user.reload
- push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:data][:endpoint])
-
- expect(push_subscription['endpoint']).to eq(create_payload[:data][:endpoint])
- expect(push_subscription['key_p256dh']).to eq(create_payload[:data][:keys][:p256dh])
- expect(push_subscription['key_auth']).to eq(create_payload[:data][:keys][:auth])
- end
+ push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:subscription][:endpoint])
- it 'sends welcome notification' do
- sign_in(user)
-
- stub_request(:post, create_payload[:data][:endpoint]).to_return(status: 200)
-
- post :create, format: :json, params: create_payload
+ expect(push_subscription['endpoint']).to eq(create_payload[:subscription][:endpoint])
+ expect(push_subscription['key_p256dh']).to eq(create_payload[:subscription][:keys][:p256dh])
+ expect(push_subscription['key_auth']).to eq(create_payload[:subscription][:keys][:auth])
end
end
it 'changes alert settings' do
sign_in(user)
- stub_request(:post, create_payload[:data][:endpoint]).to_return(status: 200)
+ stub_request(:post, create_payload[:subscription][:endpoint]).to_return(status: 200)
post :create, format: :json, params: create_payload
- alerts_payload[:id] = Web::PushSubscription.find_by(endpoint: create_payload[:data][:endpoint]).id
+ alerts_payload[:id] = Web::PushSubscription.find_by(endpoint: create_payload[:subscription][:endpoint]).id
put :update, format: :json, params: alerts_payload
- push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:data][:endpoint])
+ push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:subscription][:endpoint])
expect(push_subscription.data['follow']).to eq(alerts_payload[:data][:follow])
expect(push_subscription.data['favourite']).to eq(alerts_payload[:data][:favourite])