email_digest_agent.rb 2.6KB

    module Agents class EmailDigestAgent < Agent include EmailConcern default_schedule "5am" cannot_create_events! description <<-MD The Email Digest Agent collects any Events sent to it and sends them all via email when scheduled. The number of used events also relies on the `Keep events` option of the emitting Agent, meaning that if events expire before this agent is scheduled to run, they will not appear in the email. By default, the will have a `subject` and an optional `headline` before listing the Events. If the Events' payloads contain a `message`, that will be highlighted, otherwise everything in their payloads will be shown. You can specify one or more `recipients` for the email, or skip the option in order to send the email to your account's default email address. You can provide a `from` address for the email, or leave it blank to default to the value of `EMAIL_FROM_ADDRESS` (`#{ENV['EMAIL_FROM_ADDRESS']}`). You can provide a `content_type` for the email and specify `text/plain` or `text/html` to be sent. If you do not specify `content_type`, then the recipient email server will determine the correct rendering. Set `expected_receive_period_in_days` to the maximum amount of time that you'd expect to pass between Events being received by this Agent. MD def default_options { 'subject' => "You have some notifications!", 'headline' => "Your notifications:", 'expected_receive_period_in_days' => "2" } end def working? received_event_without_error? end def receive(incoming_events) self.memory['events'] ||= [] incoming_events.each do |event| self.memory['events'] << event.id end end def check if self.memory['events'] && self.memory['events'].length > 0 payloads = received_events.reorder("events.id ASC").where(id: self.memory['events']).pluck(:payload).to_a groups = payloads.map { |payload| present(payload) } recipients.each do |recipient| begin SystemMailer.send_message( to: recipient, from: interpolated['from'], subject: interpolated['subject'], headline: interpolated['headline'], content_type: interpolated['content_type'], groups: groups ).deliver_now log "Sent digest mail to #{recipient}" rescue => e error("Error sending digest mail to #{recipient}: #{e.message}") raise end end self.memory['events'] = [] end end end end