app/lib/actions/katello/repository/errata_mail.rb in katello-4.6.2.1 vs app/lib/actions/katello/repository/errata_mail.rb in katello-4.7.0.rc1
- old
+ new
@@ -1,20 +1,23 @@
module Actions
module Katello
module Repository
class ErrataMail < Actions::EntryAction
- middleware.use Actions::Middleware::ExecuteIfContentsChanged
-
- def plan(repo, contents_changed = nil)
- last_updated = repo.repository_errata.order('updated_at ASC').last.try(:updated_at) || Time.now
- plan_self(:repo => repo.id, :contents_changed => contents_changed, :last_updated => last_updated.to_s)
+ def plan(repo)
+ plan_self(:repo => repo.id, :associated_errata_before_syncing => repo.repository_errata.pluck(:erratum_id).uniq.sort.reverse, :new_associated_errata => [])
end
def run
::User.current = ::User.anonymous_admin
repo = ::Katello::Repository.find(input[:repo])
+ input[:new_associated_errata] = repo.repository_errata.pluck(:erratum_id).uniq.sort.reverse - input[:associated_errata_before_syncing]
+
users = ::User.select { |user| user.receives?(:sync_errata) && user.organization_ids.include?(repo.organization.id) && user.can?(:view_products, repo.product) }.compact
- errata = ::Katello::Erratum.where(:id => repo.repository_errata.where('katello_repository_errata.updated_at > ?', input['last_updated'].to_datetime).pluck(:erratum_id))
+ errata = ::Katello::Erratum.where(:id => input[:new_associated_errata])
+
+ [:associated_errata_before_syncing, :new_associated_errata].each do |key|
+ input[key] = "Trimmed list... (#{input[key].length} #{key.to_s.gsub('_', ' ')})" if input[key].length > 3
+ end
begin
MailNotification[:sync_errata].deliver(:users => users, :repo => repo, :errata => errata) unless (users.blank? || errata.blank?)
rescue => e
message = _('Unable to send errata e-mail notification: %{error}' % {:error => e})