Class: GoodData::LCM2::SynchronizeComputedAttributes

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

Constant Summary collapse

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

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

  description 'Specifies whether to transfer computed attributes'
  param :include_computed_attributes, instance_of(Type::BooleanType), required: false, default: true

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

  description 'Additional Hidden Parameters'
  param :additional_hidden_params, instance_of(Type::HashType), required: false

  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

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



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

def call(params)
  # set default value for include_computed_attributes
  # (we won't have to do this after TMA-690)
  include_ca = params.include_computed_attributes
  include_ca = true if include_ca.nil?
  include_ca = include_ca.to_b

  results = []
  return results unless include_ca

  client = params.gdc_gd_client
  collect_synced_status = collect_synced_status(params)
  failed_projects = ThreadSafe::Array.new

  params.synchronize.each do |info|
    from = info.from
    to_projects = info.to

    params.gdc_logger.info "Synchronize Computed Attributes from project pid: #{from}"

    to_projects.peach do |entry|
      ca_scripts = entry[:ca_scripts]
      next unless ca_scripts

      pid = entry[:pid]
      next if sync_failed_project(pid, params)

      ca_chunks = ca_scripts[:maqlDdlChunks]
      to_project = client.projects(pid)
      unless to_project
        process_failed_project(pid, "Invalid 'to' project specified - '#{pid}'", failed_projects, collect_synced_status)
        next
      end

      params.gdc_logger.info "Synchronizing Computed Attributes to project: '#{to_project.title}', PID: #{pid}"
      error_message = nil
      begin
        ca_chunks.each { |chunk| to_project.execute_maql(chunk) }
      rescue => e
        error_message = "Error occurred when executing MAQL for project: \"#{to_project.title}\" reason: \"#{e.message}\", chunks: #{ca_chunks.inspect}"
        process_failed_project(pid, error_message, failed_projects, collect_synced_status)
      end

      results << {
        from: from,
        to: pid,
        status: error_message.nil? ? 'ok' : 'failed'
      }
    end
  end

  process_failed_projects(failed_projects, short_name, params) if collect_synced_status
  results
end