Browse Source

feat: Enable push subscription for mobile devices by default (#4321)

master
Sorin Davidoi 6 years ago
committed by Eugen Rochko
parent
commit
9075c90c46
3 changed files with 28 additions and 23 deletions
  1. +18
    -5
      app/controllers/api/web/push_subscriptions_controller.rb
  2. +1
    -1
      app/javascript/mastodon/web_push_subscription.js
  3. +9
    -17
      spec/controllers/api/web/push_subscriptions_controller_spec.rb

+ 18
- 5
app/controllers/api/web/push_subscriptions_controller.rb View File

@@ -6,8 +6,8 @@ class Api::Web::PushSubscriptionsController < Api::BaseController
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

@@ -16,10 +16,23 @@ class Api::Web::PushSubscriptionsController < Api::BaseController
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)


+ 1
- 1
app/javascript/mastodon/web_push_subscription.js View File

@@ -37,7 +37,7 @@ const unsubscribe = ({ registration, subscription }) =>

const sendSubscriptionToBackend = (subscription) =>
axios.post('/api/web/push_subscriptions', {
data: subscription,
subscription,
}).then(response => response.data);

// Last one checks for payload support: https://web-push-book.gauntface.com/chapter-06/01-non-standards-browsers/#no-payload


+ 9
- 17
spec/controllers/api/web/push_subscriptions_controller_spec.rb View File

@@ -9,7 +9,7 @@ describe Api::Web::PushSubscriptionsController do

let(:create_payload) do
{
data: {
subscription: {
endpoint: 'https://fcm.googleapis.com/fcm/send/fiuH06a27qE:APA91bHnSiGcLwdaxdyqVXNDR9w1NlztsHb6lyt5WDKOC_Z_Q8BlFxQoR8tWFSXUIDdkyw0EdvxTu63iqamSaqVSevW5LfoFwojws8XYDXv_NRRLH6vo2CdgiN4jgHv5VLt2A8ah6lUX',
keys: {
p256dh: 'BEm_a0bdPDhf0SOsrnB2-ategf1hHoCnpXgQsFj5JCkcoMrMt2WHoPfEYOYPzOIs9mZE8ZUaD7VA5vouy0kEkr8=',
@@ -36,25 +36,17 @@ describe Api::Web::PushSubscriptionsController do
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

@@ -62,15 +54,15 @@ describe Api::Web::PushSubscriptionsController do
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])


Loading…
Cancel
Save