Class: GoodData::LCM2::SynchronizeSchedules

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

Constant Summary collapse

DESCRIPTION =
'Synchronize ETL (CC/Ruby) Processes Schedules'
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 'Schedule Additional Parameters'
  param :additional_params, instance_of(Type::HashType), required: false, deprecated: true, replacement: :schedule_additional_params

  description 'Schedule Additional Secure Parameters'
  param :additional_hidden_params, instance_of(Type::HashType), required: false, deprecated: true, replacement: :schedule_additional_hidden_params

  description 'Schedule Additional Parameters'
  param :schedule_additional_params, instance_of(Type::HashType), required: false

  description 'Schedule Additional Secure Parameters'
  param :schedule_additional_hidden_params, instance_of(Type::HashType), required: false

  description 'Logger'
  param :gdc_logger, instance_of(Type::GdLogger), required: true
end
RESULT_HEADER =
[
  :from,
  :to,
  :process_name,
  :schedule_name,
  :type,
  :state
]

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



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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
# File 'lib/gooddata/lcm/actions/synchronize_schedules.rb', line 50

def call(params)
  results = []

  client = params.gdc_gd_client
  development_client = params.development_client

  schedule_additional_params = params.schedule_additional_params || params.additional_params
  schedule_additional_hidden_params = params.schedule_additional_hidden_params || params.additional_hidden_params

  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}'")
    has_cycle_trigger = exist_cycle_trigger(from)
    to_projects.peach do |entry|
      pid = entry[:pid]
      to_project = client.projects(pid) || fail("Invalid 'to' project specified - '#{pid}'")

      params.gdc_logger.info "Transferring Schedules, from project: '#{from.title}', PID: '#{from.pid}', to project: '#{to_project.title}', PID: '#{to_project.pid}'"
      res = GoodData::Project.transfer_schedules(from, to_project, has_cycle_trigger).sort_by do |item|
        item[:status]
      end

      results += res.map do |item|
        schedule = item[:schedule]

        # TODO: Review this and remove if not required or duplicate (GOODOT_CUSTOM_PROJECT_ID vs CLIENT_ID)
        # s.update_params('GOODOT_CUSTOM_PROJECT_ID' => c.id)
        # s.update_params('CLIENT_ID' => c.id)
        # s.update_params('SEGMENT_ID' => segment.id)
        schedule.update_params(schedule_additional_params || {})
        schedule.update_hidden_params(schedule_additional_hidden_params || {})
        schedule.disable
        schedule.save

        {
          from: from.pid,
          to: to_project.pid,
          process_name: item[:process].name,
          schedule_name: schedule.name,
          type: item[:process].type,
          state: item[:state]
        }
      end
    end
  end

  # Return results
  results
end