Class: Mammoth::WebhookSink

Inherits:
Object
  • Object
show all
Defined in:
lib/mammoth/webhook_sink.rb

Overview

Delivers normalized Mammoth events to a webhook endpoint.

Constant Summary collapse

SUCCESS_RANGE =
200..299

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(name:, url:, timeout_seconds: 5) ⇒ WebhookSink

Returns a new instance of WebhookSink.

Parameters:

  • name (String)

    destination name

  • url (String)

    webhook endpoint URL

  • timeout_seconds (Integer) (defaults to: 5)

    HTTP open/read timeout in seconds



17
18
19
20
21
# File 'lib/mammoth/webhook_sink.rb', line 17

def initialize(name:, url:, timeout_seconds: 5)
  @name = name
  @url = URI(url)
  @timeout_seconds = timeout_seconds
end

Instance Attribute Details

#nameObject (readonly)

Returns the value of attribute name.



12
13
14
# File 'lib/mammoth/webhook_sink.rb', line 12

def name
  @name
end

#timeout_secondsObject (readonly)

Returns the value of attribute timeout_seconds.



12
13
14
# File 'lib/mammoth/webhook_sink.rb', line 12

def timeout_seconds
  @timeout_seconds
end

#urlObject (readonly)

Returns the value of attribute url.



12
13
14
# File 'lib/mammoth/webhook_sink.rb', line 12

def url
  @url
end

Class Method Details

.from_config(config) ⇒ Mammoth::WebhookSink

Build a sink from Mammoth configuration.

Parameters:

Returns:



27
28
29
30
31
32
33
# File 'lib/mammoth/webhook_sink.rb', line 27

def self.from_config(config)
  new(
    name: config.dig("webhook", "name"),
    url: config.dig("webhook", "url"),
    timeout_seconds: config.dig("webhook", "timeout_seconds")
  )
end

Instance Method Details

#deliver(event) ⇒ Hash

Deliver an event to the webhook endpoint.

Parameters:

  • event (Hash, #to_h)

    normalized event

Returns:

  • (Hash)

    delivery result

Raises:



40
41
42
43
44
45
46
47
48
# File 'lib/mammoth/webhook_sink.rb', line 40

def deliver(event)
  payload = EventSerializer.call(event)
  response = perform_request(payload)
  return delivery_result(payload, response) if SUCCESS_RANGE.cover?(response.code.to_i)

  raise DeliveryError, "webhook #{name} returned HTTP #{response.code}"
rescue Timeout::Error, SystemCallError, SocketError, JSON::GeneratorError => e
  raise DeliveryError, "webhook #{name} delivery failed: #{e.message}"
end