Class: RubyPushNotifications::GCM::GCMConnection

Inherits:
Object
  • Object
show all
Defined in:
lib/ruby-push-notifications/gcm/gcm_connection.rb

Overview

Encapsulates a connection to the GCM service Responsible for final connection with the service.

Author:

  • Carlos Alonso

Constant Summary collapse

GCM_URL =
'https://android.googleapis.com/gcm/send'
CONTENT_TYPE_HEADER =
'Content-Type'
JSON_CONTENT_TYPE =
'application/json'
AUTHORIZATION_HEADER =
'Authorization'

Class Method Summary collapse

Class Method Details

.post(notification, key, options = {}) ⇒ GCMResponse

Issues a POST request to the GCM send endpoint to submit the given notifications.

Parameters:

  • notification (String)

    . The text to POST

  • key (String)
  • options (Hash) (defaults to: {})

    optional. Options for #post. Currently supports:

    • url [String]: URL of the GCM endpoint. Defaults to the official GCM URL.

    • open_timeout [Integer]: Number of seconds to wait for the connection to open. Defaults to 30.

    • read_timeout [Integer]: Number of seconds to wait for one block to be read. Defaults to 30.

Returns:

  • (GCMResponse)

    . The GCMResponse that encapsulates the received response



35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
# File 'lib/ruby-push-notifications/gcm/gcm_connection.rb', line 35

def self.post(notification, key, options = {})
  headers = {
      CONTENT_TYPE_HEADER => JSON_CONTENT_TYPE,
      AUTHORIZATION_HEADER => "key=#{key}"
  }

  url = URI.parse options.fetch(:url, GCM_URL)
  http = Net::HTTP.new url.host, url.port
  http.use_ssl = url.scheme == 'https'
  http.verify_mode = OpenSSL::SSL::VERIFY_NONE
  http.open_timeout = options.fetch(:open_timeout, 30)
  http.read_timeout = options.fetch(:read_timeout, 30)

  response = http.post url.path, notification, headers

  GCMResponse.new response.code.to_i, response.body
end