Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use #try when destroying devices #18

Open
wants to merge 3 commits into
base: master
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
112 changes: 61 additions & 51 deletions lib/gcm_on_rails/app/models/gcm/notification.rb
Original file line number Diff line number Diff line change
Expand Up @@ -28,73 +28,83 @@ class << self
# {:message=>"{\"multicast_id\":6085691036338669615,\"success\":1,\"failure\":0,\"canonical_ids\":0,\"results\":[{\"message_id\":\"0:1349723376618187%d702725e98d39af3\"}]}", :code=>200}
#
#
def send_notifications(notifications = Gcm::Notification.all(:conditions => {:sent_at => nil}, :joins => :device, :readonly => false))
def send_notifications(notifications = :none)
notification_ids = if notifications == :none
Gcm::Notification.all(
:conditions => {:sent_at => nil},
:select => :id
).map(&:id)
else
notifications.map(&:id)
end

if configatron.gcm_on_rails.delivery_format and configatron.gcm_on_rails.delivery_format == 'plain_text'
format = "plain_text"
else
format = "json"
end

unless notifications.nil? || notifications.empty?
unless notification_ids.nil? || notification_ids.empty?
api_key = Gcm::Connection.open
if api_key
notifications.each do |notification|
notification_ids.each_slice(1000) do |ids|
notifications = Gcm::Notification.all(:conditions => {:id => ids}, :joins => :device, :readonly => false)
notifications.each do |notification|

logger.info "notification = #{notification.inspect}"
response = Gcm::Connection.send_notification(notification, api_key, format)
logger.info "response = #{response.inspect}"

if response[:code] == 200
if response[:message].nil?
# TODO - Making this assumption might not be right. HTTP status code 200 does not really signify success
# if Gcm servers returned nil for the message
error = "success"
elsif format == "json"
error = ""
message_data = JSON.parse response[:message]
success = message_data['success']
error = message_data['results'][0]['error'] if success == 0
elsif format == "plain_text" #format is plain text
message_data = response[:message]
error = response[:message].split('=')[1]
end
logger.info "notification = #{notification.inspect}"
response = Gcm::Connection.send_notification(notification, api_key, format)
logger.info "response = #{response.inspect}"

if response[:code] == 200
if response[:message].nil?
# TODO - Making this assumption might not be right. HTTP status code 200 does not really signify success
# if Gcm servers returned nil for the message
error = "success"
elsif format == "json"
error = ""
message_data = JSON.parse response[:message]
success = message_data['success']
error = message_data['results'][0]['error'] if success == 0
elsif format == "plain_text" #format is plain text
message_data = response[:message]
error = response[:message].split('=')[1]
end

case error
when "MissingRegistration"
ex = Gcm::Errors::MissingRegistration.new(response[:message])
logger.warn("#{ex.message}, destroying gcm_device with id #{notification.device.id}")
notification.device.destroy
when "InvalidRegistration"
ex = Gcm::Errors::InvalidRegistration.new(response[:message])
logger.warn("#{ex.message}, destroying gcm_device with id #{notification.device.id}")
notification.device.destroy
when "MismatchedSenderId"
ex = Gcm::Errors::MismatchSenderId.new(response[:message])
logger.warn(ex.message)
when "NotRegistered"
ex = Gcm::Errors::NotRegistered.new(response[:message])
logger.warn("#{ex.message}, destroying gcm_device with id #{notification.device.id}")
notification.device.destroy
when "MessageTooBig"
ex = Gcm::Errors::MessageTooBig.new(response[:message])
logger.warn(ex.message)
else
notification.sent_at = Time.now
notification.save!
case error
when "MissingRegistration"
ex = Gcm::Errors::MissingRegistration.new(response[:message])
logger.warn("#{ex.message}, destroying gcm_device with id #{notification.device.id}")
notification.device.try(:destroy)
when "InvalidRegistration"
ex = Gcm::Errors::InvalidRegistration.new(response[:message])
logger.warn("#{ex.message}, destroying gcm_device with id #{notification.device.id}")
notification.device.try(:destroy)
when "MismatchedSenderId"
ex = Gcm::Errors::MismatchSenderId.new(response[:message])
logger.warn(ex.message)
when "NotRegistered"
ex = Gcm::Errors::NotRegistered.new(response[:message])
logger.warn("#{ex.message}, destroying gcm_device with id #{notification.device.id}")
notification.device.try(:destroy)
when "MessageTooBig"
ex = Gcm::Errors::MessageTooBig.new(response[:message])
logger.warn(ex.message)
else
notification.sent_at = Time.now
notification.save!
end
elsif response[:code] == 401
raise Gcm::Errors::InvalidAuthToken.new(message_data)
elsif response[:code] == 503
raise Gcm::Errors::ServiceUnavailable.new(message_data)
elsif response[:code] == 500
raise Gcm::Errors::InternalServerError.new(message_data)
end
elsif response[:code] == 401
raise Gcm::Errors::InvalidAuthToken.new(message_data)
elsif response[:code] == 503
raise Gcm::Errors::ServiceUnavailable.new(message_data)
elsif response[:code] == 500
raise Gcm::Errors::InternalServerError.new(message_data)
end

end
end
end
end
end
end
end
end