带有Rails&的Heroku上的EventMachine EM-C2DM宝石

时间:2012-06-07 01:29:06

标签: ruby-on-rails-3.1 heroku eventmachine thin reactor

尝试在Rails中使用GroupMe gem EM-C2DM,https://github.com/groupme/em-c2dm,一个使用Event Machine的Google C2DM Ruby库。我知道它应该适用于Heroku,因为有一个特定于Heroku的配置,但我似乎无法让它运行。

我正在通过Resque Worker执行,工作人员正常工作并排队并调用。但是,它无法通过身份验证,也从未报告推送通知的响应。它似乎永远不会完成。

  module PushAndroid

  require "eventmachine"
  require "em-c2dm"

  @queue = :android_push

  def self.perform(opts)
    puts "entering android push"
    EM.next_tick do
      EM::C2DM.authenticate(ENV["C2DM_EMAIL"], ENV["C2DM_PASSWORD"])
      @push = Push.find(opts['push_id'])
      message = "Message #{@push.title}"
      push_id = "#{@push.id}"
      opts['tokens'].each{ |token|
        EM::C2DM.push(token, :message => message, :push_id => push_id) do |response|
            if response.success?
                puts "success! id=#{response.id}" # ID of sent message
            else
                puts "response:"
                puts response.inspect
                #case response.error
                #when "InvalidToken"
                    # reauthenticate
                #when "InvalidRegistration"
                    # clear our registration id
                #when "RetryAfter"
                    # pause sending for response.retry_after seconds
                #end        
            end
        end
      }
    end
  end
end

我也尝试过它而不使用EM :: next_tick或EM.next_tick并且它通过身份验证,但是从不推送任何东西,永远不会返回响应或任何东西。它实际上从未进入EM :: next_tick。

有关如何使其发挥作用的任何想法?这是在Heroku上,使用Rails 3.1.1 with Thin

来自我的Gemfile.lock:

   thin (1.3.1)
      daemons (>= 1.0.9)
      eventmachine (>= 0.12.6)
      rack (>= 1.0.0)

eventmachine (1.0.0.beta.4)

    em-apn (0.0.3)
      eventmachine (>= 1.0.0.beta.3)
      yajl-ruby (>= 0.8.2)
    em-http-request (1.0.2)
      addressable (>= 2.2.3)
      cookiejar
      em-socksify
      eventmachine (>= 1.0.0.beta.4)
      http_parser.rb (>= 0.5.3)
    em-socksify (0.2.0)
      eventmachine (>= 1.0.0.beta.4)

  remote: git://github.com/groupme/em-c2dm.git
  revision: 2d853ff771908785f23b8c64fa5d5508b4eba40a
  specs:
    em-c2dm (0.0.1)
      em-http-request (>= 1.0.0.beta.4)
      eventmachine (>= 1.0.0.beta.3)
      uuid

1 个答案:

答案 0 :(得分:0)

将它放入EM.run已修复此问题。我猜工人没有连接到Thin,因此需要运行自己的Reactor