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