Sha256: 02f80ba5cdb6938e50ad75cbc30cec868cead46c35be61be4145a6b68258a043

Contents?: true

Size: 1.67 KB

Versions: 12

Compression:

Stored size: 1.67 KB

Contents

# frozen_string_literal: true

module Rack
  # Middleware that verifies webhooks from SendGrid using the EventWebhook
  # verifier.
  #
  # The middleware takes a public key with which to set up the request
  # validator and any number of paths. When a path matches the incoming request
  # path, the request will be verified using the signature and timestamp of the
  # request.
  #
  # Example:
  #
  # require 'rack'
  # use Rack::SendGridWebhookVerification, ENV['PUBLIC_KEY'], /\/emails/
  #
  # The above appends this middleware to the stack, using a public key saved in
  # the ENV and only against paths that match /\/emails/. If the request
  # validates then it gets passed on to the action as normal. If the request
  # doesn't validate then the middleware responds immediately with a 403 status.
  class SendGridWebhookVerification
    def initialize(app, public_key, *paths)
      @app = app
      @public_key = public_key
      @path_regex = Regexp.union(paths)
    end

    def call(env)
      return @app.call(env) unless env['PATH_INFO'].match(@path_regex)

      request = Rack::Request.new(env)

      event_webhook = SendGrid::EventWebhook.new
      ec_public_key = event_webhook.convert_public_key_to_ecdsa(@public_key)
      verified = event_webhook.verify_signature(
        ec_public_key,
        request.body.read,
        request.env[SendGrid::EventWebhookHeader::SIGNATURE],
        request.env[SendGrid::EventWebhookHeader::TIMESTAMP]
      )

      request.body.rewind

      if verified
        @app.call(env)
      else
        [
          403,
          { 'Content-Type' => 'text/plain' },
          ['SendGrid Request Verification Failed.']
        ]
      end
    end
  end
end

Version data entries

12 entries across 12 versions & 1 rubygems

Version Path
sendgrid-ruby-6.7.0 lib/rack/sendgrid_webhook_verification.rb
sendgrid-ruby-6.6.2 lib/rack/sendgrid_webhook_verification.rb
sendgrid-ruby-6.6.1 lib/rack/sendgrid_webhook_verification.rb
sendgrid-ruby-6.6.0 lib/rack/sendgrid_webhook_verification.rb
sendgrid-ruby-6.5.2 lib/rack/sendgrid_webhook_verification.rb
sendgrid-ruby-6.5.1 lib/rack/sendgrid_webhook_verification.rb
sendgrid-ruby-6.5.0 lib/rack/sendgrid_webhook_verification.rb
sendgrid-ruby-6.4.0 lib/rack/sendgrid_webhook_verification.rb
sendgrid-ruby-6.3.9 lib/rack/sendgrid_webhook_verification.rb
sendgrid-ruby-6.3.8 lib/rack/sendgrid_webhook_verification.rb
sendgrid-ruby-6.3.7 lib/rack/sendgrid_webhook_verification.rb
sendgrid-ruby-6.3.6 lib/rack/sendgrid_webhook_verification.rb