module Eco module API module UseCases class DefaultCases class UpdateCase < BaseCase def process @cases.define("update", type: :sync) do |entries, people, session, options| update = session.job_group("main").new("update", type: :update, sets: [:core, :details, :account]) pgs = session.policy_groups entries.each.with_index do |entry, i| if person = people.find(entry) core_excluded = ["supervisor_id"] core_excluded.push("email") if options.dig(:exclude, :email) entry.set_core(person, exclude: core_excluded) unless options.dig(:exclude, :core) entry.set_details(person) unless options.dig(:exclude, :details) unless options.dig(:exclude, :account) ini_pg_ids = person.account&.policy_group_ids || [] ini_tags = person.account&.filter_tags || [] entry.set_account(person) person.account.policy_group_ids = pgs.user_pg_ids( initial: ini_pg_ids, final: person.account.policy_group_ids ) person.account.permissions_custom = session.new_preset(person) unless options.dig(:exclude, :abilities) if session.tagtree person.account.filter_tags = session.tagtree.user_tags( initial: ini_tags, final: person.account.filter_tags, preserve_custom: true, add_custom: true ) person.account.default_tag = session.tagtree.default_tag(*person.account.filter_tags) else tags = person.account.filter_tags person.account.default_tag = tags.first unless tags.length > 1 end end update.add(person) else session.logger.error("Entry(#{i}) - this person does not exist: #{entry.to_s(:identify)}") end end end end end end end end end