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

Automatic retry with exponential backoff #58

Open
wants to merge 8 commits into
base: master
Choose a base branch
from

Conversation

Alan-M-Thomaz
Copy link

Implemented it using the recently added gem Faraday, when it is status 5xx or 200 and any of the results form body is error:Unavaible, it will retry the whole request, with an exponential interval.
passed on simple rspec test with webmock stubs.
I'm not sure if those interval params where good the exponential backoff.

Also updated group notification url to fcm url. #56

ToDo

Implement a Retry faraday middleware that allow editing the body of the request before resend it, so when it is 200 + error:unavaible, we can resend it only for the registration_ids that failed, instead to sending for all.

@Alan-M-Thomaz
Copy link
Author

oh, i just screw the other http errors, i will be fixing it

@kashif
Copy link
Contributor

kashif commented Apr 1, 2019

cool thanks... let me know when you are ready to review

@Alan-M-Thomaz
Copy link
Author

it's fixed, just removed the error raise middleware, it was causing more problems than helping, refactored to use just retryable_statuses.

Copy link
Collaborator

@Roy-Mao Roy-Mao left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

just two minor suggestions..

Think it would be better if we put all the error handling into a different module or class, I will fork the repo and make a PR regarding this issue.

@@ -34,6 +33,7 @@ def initialize(api_key, client_options = {})
def send_notification(registration_ids, options = {})
post_body = build_post_body(registration_ids, options)


Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👇here why not just using execute_notifications(post_body) instead

lib/fcm.rb Outdated
@@ -49,8 +49,8 @@ def create_notification_key(key_name, project_id, registration_ids = [])
'project_id' => project_id
}

for_uri(GROUP_NOTIFICATION_BASE_URI, extra_headers) do |connection|
response = connection.post('/gcm/notification', post_body.to_json)
for_uri(BASE_URI, extra_headers) do |connection|
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Alan-M-Thomaz

since there are four places where we need to call /fcm/notification

  • create_notification_key(post)
  • add_registration_ids(post)
  • remove_registration_ids(post)
  • recover_notification_key(get)

maybe it would be better if we refactor this api call into a separate private method, like what execute_notification method does..

def update_group_messaging_setting(body)
  for_uri(BASE_URI, extra_headers) do |connection|
      response = connection.post('/fcm/notification', body.to_json)
      build_response(response)
  end
end

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

done, except for recover_notification_key, because it's a get request

@dgmstuart
Copy link

Hi - great work on the PR. Is there a plan to get this merged soon? We're using the gem and are trying to work out if we can wait for this PR or if we need to create our own fork. Thanks!

connection = ::Faraday.new(:url => uri) do |faraday|
faraday.request :retry, max: 5, interval: 0.1, interval_randomness: 0.5, backoff_factor: 2,
exceptions: retryable_exceptions, retry_statuses: [200, *(500..599)], methods: [],
retry_if: retry_if_func
faraday.adapter Faraday.default_adapter
faraday.headers["Content-Type"] = "application/json"
faraday.headers["Authorization"] = "key=#{api_key}"
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Before

Authorization: key=AIzaSyZ-1u...0GBYzPu7Udno5aA
After

Authorization: Bearer ya29.ElqKBGN2Ri_Uz...HnS_uNreA

https://firebase.google.com/docs/cloud-messaging/migrate-v1

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants