Sha256: 7a9dca2692ad7e056cc8a32b85281150c7538b2d07d78576336f39928bee808b

Contents?: true

Size: 1.28 KB

Versions: 3

Compression:

Stored size: 1.28 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

      raw_parameters = request.request_parameters
      event[:github_action] = raw_parameters["action"]

      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

3 entries across 3 versions & 1 rubygems

Version Path
hubstats-0.6.0 app/controllers/hubstats/events_controller.rb
hubstats-0.5.12 app/controllers/hubstats/events_controller.rb
hubstats-0.5.11 app/controllers/hubstats/events_controller.rb