Class: GoodData::LCM2::SynchronizeProcesses

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

Constant Summary collapse

DESCRIPTION =
'Synchronize ETL (CC/Ruby) Processes'
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 'Additional Hidden Parameters of Processes'
  param :process_additional_hidden_params, instance_of(Type::HashType), required: false
end
RESULT_HEADER =
[
  :from,
  :to,
  :name,
  :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



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
64
65
66
67
68
69
70
71
72
73
74
# File 'lib/gooddata/lcm/actions/synchronize_processes.rb', line 39

def call(params)
  results = []

  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) || fail("Invalid 'from' project specified - '#{from_project}'")

    to_projects.peach do |to|
      pid = to[:pid]
      client_id = to[:client_id]

      to_project = client.projects(pid) || fail("Invalid 'to' project specified - '#{pid}'")

      params.gdc_logger.info "Transferring processes, from project: '#{from.title}', PID: '#{from.pid}', to project: '#{to_project.title}', PID: '#{to_project.pid}'"
      res = GoodData::Project.transfer_processes(
        from,
        to_project,
        ads_output_stage_uri: info.ads_output_stage_uri,
        ads_output_stage_prefix: info.ads_output_stage_prefix,
        additional_hidden_params: params.process_additional_hidden_params
      )

      to_project.add.output_stage.client_id = client_id if client_id && to_project.add.output_stage

      results << res
    end
  end

  # Return results
  results.flatten
end