Class: Bolt::Outputter::JSON

Inherits:
Bolt::Outputter show all
Defined in:
lib/bolt/outputter/json.rb

Instance Method Summary collapse

Methods inherited from Bolt::Outputter

for_format

Constructor Details

#initialize(color, verbose, trace, stream = $stdout) ⇒ JSON

Returns a new instance of JSON.



6
7
8
9
10
11
# File 'lib/bolt/outputter/json.rb', line 6

def initialize(color, verbose, trace, stream = $stdout)
  super
  @items_open = false
  @object_open = false
  @preceding_item = false
end

Instance Method Details

#fatal_error(err) ⇒ Object



120
121
122
123
124
125
126
127
128
129
130
# File 'lib/bolt/outputter/json.rb', line 120

def fatal_error(err)
  @stream.puts "],\n" if @items_open
  @stream.puts '"_error": ' if @object_open
  err_obj = err.to_h
  if @trace && err.backtrace
    err_obj[:details] ||= {}
    err_obj[:details][:backtrace] = err.backtrace
  end
  @stream.puts err_obj.to_json
  @stream.puts '}' if @object_open
end

#handle_event(event) ⇒ Object



20
21
22
23
24
25
26
27
# File 'lib/bolt/outputter/json.rb', line 20

def handle_event(event)
  case event[:type]
  when :node_result
    print_result(event[:result])
  when :message
    print_message_event(event)
  end
end


85
86
87
# File 'lib/bolt/outputter/json.rb', line 85

def print_apply_result(apply_result, _elapsed_time)
  @stream.puts apply_result.to_json
end


114
115
116
117
118
# File 'lib/bolt/outputter/json.rb', line 114

def print_groups(groups)
  count = groups.count
  @stream.puts({ "groups": groups,
                 "count": count }.to_json)
end


13
14
15
16
17
18
# File 'lib/bolt/outputter/json.rb', line 13

def print_head
  @stream.puts '{ "items": ['
  @preceding_item = false
  @items_open = true
  @object_open = true
end


136
137
138
# File 'lib/bolt/outputter/json.rb', line 136

def print_message(message)
  $stderr.puts(message)
end


132
133
134
# File 'lib/bolt/outputter/json.rb', line 132

def print_message_event(event)
  print_message(event[:message])
end


71
72
73
74
75
76
77
78
79
# File 'lib/bolt/outputter/json.rb', line 71

def print_plan_info(plan)
  path = plan.delete('module')
  plan['module_dir'] = if path.start_with?(Bolt::PAL::MODULES_PATH)
                         "built-in module"
                       else
                         path
                       end
  @stream.puts plan.to_json
end


89
90
91
92
# File 'lib/bolt/outputter/json.rb', line 89

def print_plan_result(result)
  # Ruby JSON patches most objects to have a to_json method.
  @stream.puts result.to_json
end


81
82
83
# File 'lib/bolt/outputter/json.rb', line 81

def print_plans(plans, modulepath)
  print_table('plans' => plans, 'modulepath' => modulepath)
end


94
95
96
97
98
# File 'lib/bolt/outputter/json.rb', line 94

def print_puppetfile_result(success, puppetfile, moduledir)
  @stream.puts({ "success": success,
                 "puppetfile": puppetfile,
                 "moduledir": moduledir }.to_json)
end


29
30
31
32
33
# File 'lib/bolt/outputter/json.rb', line 29

def print_result(result)
  @stream.puts ',' if @preceding_item
  @stream.puts result.status_hash.to_json
  @preceding_item = true
end


35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
# File 'lib/bolt/outputter/json.rb', line 35

def print_summary(results, elapsed_time)
  @stream.puts "],\n"
  @preceding_item = false
  @items_open = false
  # rubocop:disable Style/GlobalVars
  if $future
    @stream.puts format('"target_count": %<size>d, "elapsed_time": %<elapsed>d }',
                        size: results.size,
                        elapsed: elapsed_time)
  else
    @stream.puts format('"node_count": %<size>d, "elapsed_time": %<elapsed>d }',
                        size: results.size,
                        elapsed: elapsed_time)
  end
  # rubocop:enable Style/GlobalVars
end


52
53
54
# File 'lib/bolt/outputter/json.rb', line 52

def print_table(results)
  @stream.puts results.to_json
end


107
108
109
110
111
112
# File 'lib/bolt/outputter/json.rb', line 107

def print_target_info(targets)
  @stream.puts ::JSON.pretty_generate(
    "targets": targets.map(&:detail),
    "count": targets.count
  )
end


100
101
102
103
104
105
# File 'lib/bolt/outputter/json.rb', line 100

def print_targets(targets)
  @stream.puts ::JSON.pretty_generate(
    "targets": targets.map(&:name),
    "count": targets.count
  )
end


57
58
59
60
61
62
63
64
65
# File 'lib/bolt/outputter/json.rb', line 57

def print_task_info(task)
  path = task['files'][0]['path'].chomp("/tasks/#{task['files'][0]['name']}")
  task['module_dir'] = if path.start_with?(Bolt::PAL::MODULES_PATH)
                         "built-in module"
                       else
                         path
                       end
  @stream.puts task.to_json
end


67
68
69
# File 'lib/bolt/outputter/json.rb', line 67

def print_tasks(tasks, modulepath)
  print_table('tasks' => tasks, 'modulepath' => modulepath)
end