module Imports class UserImportService < ImportService def create_users(folder) import_from(folder, :create_user) end private PROVIDER_TYPE = { "Data Provider" => User.roles[:data_provider], }.freeze def create_user(xml_document) organisation = Organisation.find_by(old_org_id: user_field_value(xml_document, "institution")) old_user_id = user_field_value(xml_document, "id") email = user_field_value(xml_document, "email").downcase.strip name = user_field_value(xml_document, "full-name") || email deleted = user_field_value(xml_document, "deleted") if User.find_by(old_user_id:, organisation:) @logger.warn("User #{name} with old user id #{old_user_id} is already present, skipping.") elsif deleted == "true" @logger.warn("User #{name} with old user id #{old_user_id} is deleted, skipping.") elsif (user = User.find_by(email:, organisation:)) is_dpo = user.is_data_protection_officer? || is_dpo?(user_field_value(xml_document, "user-type")) role = highest_role(user.role, role(user_field_value(xml_document, "user-type"))) user.update!(role:, is_dpo:) @logger.info("Found duplicated email, updating user #{user.id} with role #{role} and is_dpo #{is_dpo}") else User.create!( email:, name:, password: Devise.friendly_token, phone: user_field_value(xml_document, "telephone-no"), old_user_id:, organisation:, role: role(user_field_value(xml_document, "user-type")), is_dpo: is_dpo?(user_field_value(xml_document, "user-type")), is_key_contact: is_key_contact?(user_field_value(xml_document, "contact-priority-id")), active: user_field_value(xml_document, "active"), ) end end def user_field_value(xml_document, field) field_value(xml_document, "user", field) end def role(field_value) return unless field_value { "co-ordinator" => "data_coordinator", "data provider" => "data_provider", "private data downloader" => "data_accessor", }[field_value.downcase.strip] end def highest_role(role_a, role_b) return unless role_a || role_b return role_a unless role_b return role_b unless role_a [role_a, role_b].map(&:to_sym).sort! { |a, b| User::ROLES[b] <=> User::ROLES[a] }.first end def is_dpo?(field_value) return false if field_value.blank? field_value.downcase.strip == "data protection officer" end def is_key_contact?(field_value) return false if field_value.blank? ["ecore contact", "key performance contact"].include?(field_value.downcase.strip) end end end