Specs for pubsub subscribe service (#2951)
* Add spec for pubsubhubbub/subscribe * Refactor pubsubhubbub/subscribe service
This commit is contained in:
committed by
Eugen Rochko
parent
441d6dc734
commit
682507bc3c
@ -1,14 +1,61 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
class Pubsubhubbub::SubscribeService < BaseService
|
||||
URL_PATTERN = /\A#{URI.regexp(%w(http https))}\z/
|
||||
|
||||
attr_reader :account, :callback, :secret, :lease_seconds
|
||||
|
||||
def call(account, callback, secret, lease_seconds)
|
||||
return ['Invalid topic URL', 422] if account.nil?
|
||||
return ['Invalid callback URL', 422] unless !callback.blank? && callback =~ /\A#{URI.regexp(%w(http https))}\z/
|
||||
return ['Callback URL not allowed', 403] if DomainBlock.blocked?(Addressable::URI.parse(callback).normalize.host)
|
||||
@account = account
|
||||
@callback = callback
|
||||
@secret = secret
|
||||
@lease_seconds = lease_seconds
|
||||
|
||||
subscription = Subscription.where(account: account, callback_url: callback).first_or_create!(account: account, callback_url: callback)
|
||||
process_subscribe
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def process_subscribe
|
||||
case subscribe_status
|
||||
when :invalid_topic
|
||||
['Invalid topic URL', 422]
|
||||
when :invalid_callback
|
||||
['Invalid callback URL', 422]
|
||||
when :callback_not_allowed
|
||||
['Callback URL not allowed', 403]
|
||||
when :valid
|
||||
confirm_subscription
|
||||
['', 202]
|
||||
end
|
||||
end
|
||||
|
||||
def subscribe_status
|
||||
if account.nil?
|
||||
:invalid_topic
|
||||
elsif !valid_callback?
|
||||
:invalid_callback
|
||||
elsif blocked_domain?
|
||||
:callback_not_allowed
|
||||
else
|
||||
:valid
|
||||
end
|
||||
end
|
||||
|
||||
def confirm_subscription
|
||||
subscription = locate_subscription
|
||||
Pubsubhubbub::ConfirmationWorker.perform_async(subscription.id, 'subscribe', secret, lease_seconds)
|
||||
end
|
||||
|
||||
['', 202]
|
||||
def valid_callback?
|
||||
callback.present? && callback =~ URL_PATTERN
|
||||
end
|
||||
|
||||
def blocked_domain?
|
||||
DomainBlock.blocked? Addressable::URI.parse(callback).normalize.host
|
||||
end
|
||||
|
||||
def locate_subscription
|
||||
Subscription.where(account: account, callback_url: callback).first_or_create!(account: account, callback_url: callback)
|
||||
end
|
||||
end
|
||||
|
Reference in New Issue
Block a user