lib/eco/api/usecases/default_cases/update_case.rb in eco-helpers-1.3.7 vs lib/eco/api/usecases/default_cases/update_case.rb in eco-helpers-1.3.8

- old
+ new

@@ -8,11 +8,11 @@ @cases.define("update", type: :sync) do |entries, people, session, options, usecase| update = session.job_group("main").new("update", usecase: usecase, type: :update, sets: [:core, :details, :account]) supers = session.job_group("post").new("supers", usecase: usecase, type: :update, sets: :core) strict_search = session.config.people.strict_search? && (!options[:search]&.key?(:strict) || options.dig(:search, :strict)) - pgs = session.policy_groups + pgs = session.policy_groups entries.each.with_index do |entry, i| if person = people.find(entry, strict: strict_search) unless options.dig(:exclude, :core) @@ -45,9 +45,10 @@ entry.set_account(person, exclude: account_excluded) person.account.send_invites = options[:send_invites] if options.key?(:send_invites) unless options.dig(:exclude, :policy_groups) + # avoid false updates by preserving the original order person.account.policy_group_ids = pgs.user_pg_ids( initial: ini_pg_ids, final: person.account.policy_group_ids ) end