feat: Enable push subscription for mobile devices by default (#4321)
This commit is contained in:
		
				
					committed by
					
						 Eugen Rochko
						Eugen Rochko
					
				
			
			
				
	
			
			
			
						parent
						
							63a2566007
						
					
				
				
					commit
					9075c90c46
				
			| @@ -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) | ||||
|   | ||||
| @@ -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,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]) | ||||
|       push_subscription = Web::PushSubscription.find_by(endpoint: create_payload[:subscription][: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 | ||||
|  | ||||
|     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]) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user