Sha256: 192ce36f7aba68c4af5f6278e6bd3e482efd72bbe05f00526a346af1085e40a9
Contents?: true
Size: 1.12 KB
Versions: 3
Compression:
Stored size: 1.12 KB
Contents
# frozen_string_literal: true require "dry/core/constants" require "dry/events/publisher" module Dry module Monitor class Clock def measure start = current result = yield [result, current - start] end def current Process.clock_gettime(Process::CLOCK_MONOTONIC, :millisecond) end end CLOCK = Clock.new class Notifications include Core::Constants include Events::Publisher["Dry::Monitor::Notifications"] attr_reader :id, :clock def initialize(id) @id = id @clock = CLOCK end def start(event_id, payload) instrument(event_id, payload) end def stop(event_id, payload) instrument(event_id, payload) end def instrument(event_id, payload = EMPTY_HASH, &block) result, time = @clock.measure(&block) if block_given? process(event_id, payload) do |event, listener| if time listener.(event.payload(payload.merge(time: time))) else listener.(event) end end result end end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
dry-monitor-0.6.3 | lib/dry/monitor/notifications.rb |
dry-monitor-0.6.2 | lib/dry/monitor/notifications.rb |
dry-monitor-0.6.1 | lib/dry/monitor/notifications.rb |