Sha256: 36704bdb5f46f6e633a7b969e06ca7935a64661326a429a8d7382fe462cde98b

Contents?: true

Size: 1.17 KB

Versions: 10

Compression:

Stored size: 1.17 KB

Contents

require_dependency "hubstats/application_controller"

module Hubstats
  class EventsController < ApplicationController

    # Public - Verifies that the request we're receiving is a new event, and then will handle it and route
    # it to the correct place.
    #
    # request - the request of the new event
    #
    # Returns - nothing, but makes a new event
    def handler
      verify_signature(request)

      kind = request.headers['X-Github-Event']
      event = params.with_indifferent_access
      eventsHandler = Hubstats::EventsHandler.new()
      eventsHandler.route(event,kind)

      render :nothing => true
    end

    # Public - Will check that the request passed is a valid signature.
    # 
    # request - the signature to be checked
    #
    # Returns - an error if the signatures don't match
    private
    def verify_signature(request)
      request.body.rewind
      payload_body = request.body.read
      signature = 'sha1=' + OpenSSL::HMAC.hexdigest(OpenSSL::Digest.new('sha1'), Hubstats.config.webhook_endpoint, payload_body)
      return 500, "Signatures didn't match!" unless Rack::Utils.secure_compare(signature, request.env['HTTP_X_HUB_SIGNATURE'])
    end
  end
end

Version data entries

10 entries across 10 versions & 1 rubygems

Version Path
hubstats-0.5.9 app/controllers/hubstats/events_controller.rb
hubstats-0.5.7 app/controllers/hubstats/events_controller.rb
hubstats-0.5.6 app/controllers/hubstats/events_controller.rb
hubstats-0.5.5 app/controllers/hubstats/events_controller.rb
hubstats-0.5.4 app/controllers/hubstats/events_controller.rb
hubstats-0.5.3 app/controllers/hubstats/events_controller.rb
hubstats-0.5.2 app/controllers/hubstats/events_controller.rb
hubstats-0.5.1 app/controllers/hubstats/events_controller.rb
hubstats-0.5.0 app/controllers/hubstats/events_controller.rb
hubstats-0.4.4 app/controllers/hubstats/events_controller.rb