Class: GoodData::LCM2::ImportObjectCollections

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

Constant Summary collapse

DESCRIPTION =
'Import all objects in CollectXXX action to master projects'
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 'Number Of Threads'
  param :number_of_threads, instance_of(Type::StringType), required: false, default: '10'
end

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



29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
# File 'lib/gooddata/lcm/actions/import_object_collections.rb', line 29

def call(params)
  results = []

  GoodData.logger.info 'Starting ImportObjectCollections action'
  client = params.gdc_gd_client
  development_client = params.development_client
  number_of_threads = Integer(params.number_of_threads || '8')

  params.synchronize.peach(number_of_threads) do |info|
    from = info.from
    to_projects = info.to
    transfer_uris = info.transfer_uris

    from_project = development_client.projects(from) || fail("Invalid 'from' project specified - '#{from}'")

    to_projects.peach(number_of_threads) do |entry|
      pid = entry[:pid]
      to_project = client.projects(pid) || fail("Invalid 'to' project specified - '#{pid}'")

      if transfer_uris.any?
        logging_data(from, pid, transfer_uris, true)
        from_project.partial_md_export(transfer_uris, project: to_project)
        logging_data(from, pid, transfer_uris, false)
      end

      results << {
        from: from,
        to: pid,
        status: 'ok'
      }
    end
  end

  results
end