Class: GoodData::LCM2::SynchronizeDataSetMapping

Inherits:
BaseAction show all
Defined in:
lib/gooddata/lcm/actions/synchronize_dataset_mappings.rb

Constant Summary collapse

DESCRIPTION =
'Synchronize Dataset Mappings'
PARAMS =
define_params(self) do
  description 'Client Used for Connecting to GD'
  param :gdc_gd_client, instance_of(Type::GdClientType), required: true

  description 'Client used to connecting to development domain'
  param :development_client, instance_of(Type::GdClientType), required: true

  description 'Synchronization Info'
  param :synchronize, array_of(instance_of(Type::SynchronizationInfoType)), required: true, generated: true

  description 'Logger'
  param :gdc_logger, instance_of(Type::GdLogger), required: true

  description 'Abort on error'
  param :abort_on_error, instance_of(Type::StringType), required: false

  description 'Collect synced status'
  param :collect_synced_status, instance_of(Type::BooleanType), required: false

  description 'Sync failed list'
  param :sync_failed_list, instance_of(Type::HashType), required: false
end
RESULT_HEADER =
%i[from to count status]

Constants inherited from BaseAction

BaseAction::FAILED_CLIENTS, BaseAction::FAILED_PROJECTS, BaseAction::FAILED_SEGMENTS, BaseAction::SYNC_FAILED_LIST

Constants included from Dsl::Dsl

Dsl::Dsl::DEFAULT_OPTS, Dsl::Dsl::TYPES

Class Method Summary collapse

Methods inherited from BaseAction

add_failed_client, add_failed_project, add_failed_segment, add_new_clients_to_project_client_mapping, check_params, collect_synced_status, continue_on_error, print_result, process_failed_project, process_failed_projects, sync_failed_client, sync_failed_project, sync_failed_segment, without_check

Methods included from Dsl::Dsl

#define_params, #define_type, #process

Class Method Details

.call(params) ⇒ Object



41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
# File 'lib/gooddata/lcm/actions/synchronize_dataset_mappings.rb', line 41

def call(params)
  results = []
  collect_synced_status = collect_synced_status(params)
  failed_projects = ThreadSafe::Array.new

  client = params.gdc_gd_client
  development_client = params.development_client

  params.synchronize.peach do |info|
    from_project = info.from
    to_projects = info.to

    from = development_client.projects(from_project)
    unless from
      process_failed_project(from_project, "Invalid 'from' project specified - '#{from_project}'", failed_projects, collect_synced_status)
      next
    end

    dataset_mapping = from.dataset_mapping
    if dataset_mapping&.dig('datasetMappings', 'items').nil? || dataset_mapping['datasetMappings']['items'].empty?
      params.gdc_logger.info "Project: '#{from.title}', PID: '#{from.pid}' has no model mapping, skip synchronizing model mapping."
    else
      to_projects.peach do |to|
        pid = to[:pid]
        next if sync_failed_project(pid, params)

        to_project = client.projects(pid)
        process_failed_project(pid, "Invalid 'to' project specified - '#{pid}'", failed_projects, collect_synced_status) unless to_project

        message_to_project = "to project: '#{to_project.title}', PID: '#{to_project.pid}'"
        params.gdc_logger.info "Transferring model mapping, from project: '#{from.title}', PID: '#{from.pid}', #{message_to_project}"
        res = to_project.update_dataset_mapping(dataset_mapping)
        res[:from] = from.pid
        results << res

        failed_message = "Failed to transfer model mapping from project '#{from.pid}' to project '#{to_project.pid}'"
        process_failed_project(pid, failed_message, failed_projects, collect_synced_status) if collect_synced_status && res[:status] != 'OK'
      end
    end
  end

  process_failed_projects(failed_projects, short_name, params) if collect_synced_status
  # Return results
  results.flatten
end