Class: GoodData::LCM2::ImportObjectCollections
- Inherits:
-
BaseAction
- Object
- BaseAction
- GoodData::LCM2::ImportObjectCollections
- 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 |