Class: MaliPoPay::Webhooks::Verifier
- Inherits:
-
Object
- Object
- MaliPoPay::Webhooks::Verifier
- Defined in:
- lib/malipopay/webhooks/verifier.rb
Constant Summary collapse
- TOLERANCE_IN_SECONDS =
5 minutes
300
Class Method Summary collapse
-
.sign(payload, secret, timestamp: nil) ⇒ String
Generate an HMAC signature for a payload.
Instance Method Summary collapse
-
#construct_event(payload, signature, timestamp: nil) ⇒ Hash
Verify and parse a webhook event.
-
#initialize(secret) ⇒ Verifier
constructor
A new instance of Verifier.
-
#verify(payload, signature, timestamp: nil) ⇒ Boolean
Verify a webhook signature.
Constructor Details
#initialize(secret) ⇒ Verifier
Returns a new instance of Verifier.
11 12 13 |
# File 'lib/malipopay/webhooks/verifier.rb', line 11 def initialize(secret) @secret = secret end |
Class Method Details
.sign(payload, secret, timestamp: nil) ⇒ String
Generate an HMAC signature for a payload
51 52 53 54 |
# File 'lib/malipopay/webhooks/verifier.rb', line 51 def self.sign(payload, secret, timestamp: nil) signed_payload = ? "#{}.#{payload}" : payload OpenSSL::HMAC.hexdigest("SHA256", secret, signed_payload) end |
Instance Method Details
#construct_event(payload, signature, timestamp: nil) ⇒ Hash
Verify and parse a webhook event
38 39 40 41 42 43 44 |
# File 'lib/malipopay/webhooks/verifier.rb', line 38 def construct_event(payload, signature, timestamp: nil) unless verify(payload, signature, timestamp: ) raise MaliPoPay::AuthenticationError.new("Invalid webhook signature") end JSON.parse(payload) end |
#verify(payload, signature, timestamp: nil) ⇒ Boolean
Verify a webhook signature
20 21 22 23 24 25 26 27 28 29 30 |
# File 'lib/malipopay/webhooks/verifier.rb', line 20 def verify(payload, signature, timestamp: nil) return false if signature.nil? || signature.empty? if ts = .to_i return false if (Time.now.to_i - ts).abs > TOLERANCE_IN_SECONDS end expected = self.class.sign(payload, @secret, timestamp: ) secure_compare(expected, signature) end |