Sha256: c38c966bdbbad60b38c8693de91499f554986f13791f7cccf7166e38c1ef9790

Contents?: true

Size: 1.32 KB

Versions: 1

Compression:

Stored size: 1.32 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_payload = request.raw_post
      original_payload = JSON.parse(raw_payload)
      event[:github_action] = original_payload["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

1 entries across 1 versions & 1 rubygems

Version Path
hubstats-0.5.10 app/controllers/hubstats/events_controller.rb