Class: LogStash::Settings
  
  
  
  Constant Summary
  
  
  Util::EnvironmentVariables::ENV_PLACEHOLDER_REGEX
  
    
      Instance Method Summary
      collapse
    
    
  
  
  
  
  
  
  
  
  
  
  #deep_replace, #replace_env_placeholders
  Constructor Details
  
    
  
  
    
Returns a new instance of Settings.
   
 
  
  
    | 
13
14
15
16
17
18
19
20 | # File 'lib/logstash/settings.rb', line 13
def initialize
  @settings = {}
          @transient_settings = {}
end | 
 
  
 
  
    Instance Method Details
    
      
  
  
    #clone  ⇒ Object 
  
  
  
  
    | 
50
51
52 | # File 'lib/logstash/settings.rb', line 50
def clone
  get_subset(".*")
end | 
 
    
      
  
  
    | 
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105 | # File 'lib/logstash/settings.rb', line 87
def format_settings
  output = []
  output << "-------- Logstash Settings (* means modified) ---------"
  @settings.each do |setting_name, setting|
    value = setting.value
    default_value = setting.default
    if default_value == value       output << "#{setting_name}: #{value.inspect}" unless value.nil?
    elsif default_value.nil?       output << "*#{setting_name}: #{value.inspect}"
    elsif value.nil?       output << "#{setting_name}: #{default_value.inspect}"
    else       output << "*#{setting_name}: #{value.inspect} (default: #{default_value.inspect})"
    end
  end
  output << "--------------- Logstash Settings -------------------"
  output
end | 
 
    
      
  
  
    #from_yaml(yaml_path)  ⇒ Object 
  
  
  
  
    | 
111
112
113
114
115
116
117
118 | # File 'lib/logstash/settings.rb', line 111
def from_yaml(yaml_path)
  settings = read_yaml(::File.join(yaml_path, "logstash.yml"))
  self.merge(
    deep_replace(flatten_hash(settings)),
    true
  )
  self
end | 
 
    
      
  
  
    #get_default(setting_name)  ⇒ Object 
  
  
  
  
    | 
54
55
56 | # File 'lib/logstash/settings.rb', line 54
def get_default(setting_name)
  get_setting(setting_name).default
end | 
 
    
      
  
  
    #get_setting(setting_name)  ⇒ Object 
  
  
  
  
    | 
30
31
32
33
34 | # File 'lib/logstash/settings.rb', line 30
def get_setting(setting_name)
  setting = @settings[setting_name]
  raise ArgumentError.new("Setting \"#{setting_name}\" hasn't been registered") if setting.nil?
  setting
end | 
 
    
      
  
  
    #get_subset(setting_regexp)  ⇒ Object 
  
  
  
  
    | 
36
37
38
39
40
41
42
43
44 | # File 'lib/logstash/settings.rb', line 36
def get_subset(setting_regexp)
  regexp = setting_regexp.is_a?(Regexp) ? setting_regexp : Regexp.new(setting_regexp)
  settings = self.class.new
  @settings.each do |setting_name, setting|
    next unless setting_name.match(regexp)
    settings.register(setting.clone)
  end
  settings
end | 
 
    
      
  
  
    #get_value(setting_name)  ⇒ Object 
  
  
    Also known as:
    get
    
  
  
  
    | 
58
59
60 | # File 'lib/logstash/settings.rb', line 58
def get_value(setting_name)
  get_setting(setting_name).value
end | 
 
    
      
  
  
    #merge(hash, graceful = false)  ⇒ Object 
  
  
  
  
    | 
82
83
84
85 | # File 'lib/logstash/settings.rb', line 82
def merge(hash, graceful = false)
  hash.each {|key, value| set_value(key, value, graceful) }
  self
end | 
 
    
      
  
  
    #on_post_process(&block)  ⇒ Object 
  
  
  
  
    | 
128
129
130
131 | # File 'lib/logstash/settings.rb', line 128
def on_post_process(&block)
  @post_process_callbacks ||= []
  @post_process_callbacks << block
end | 
 
    
      
  
  
    #post_process  ⇒ Object 
  
  
  
  
    | 
120
121
122
123
124
125
126 | # File 'lib/logstash/settings.rb', line 120
def post_process
  if @post_process_callbacks
    @post_process_callbacks.each do |callback|
      callback.call(self)
    end
  end
end | 
 
    
      
  
  
    #register(setting)  ⇒ Object 
  
  
  
  
    | 
22
23
24
25
26
27
28 | # File 'lib/logstash/settings.rb', line 22
def register(setting)
  if @settings.key?(setting.name)
    raise ArgumentError.new("Setting \"#{setting.name}\" has already been registered as #{setting.inspect}")
  else
    @settings[setting.name] = setting
  end
end | 
 
    
      
  
  
    #reset  ⇒ Object 
  
  
  
  
    | 
107
108
109 | # File 'lib/logstash/settings.rb', line 107
def reset
  @settings.values.each(&:reset)
end | 
 
    
      
  
  
    #set?(setting_name)  ⇒ Boolean 
  
  
  
  
    | 
46
47
48 | # File 'lib/logstash/settings.rb', line 46
def set?(setting_name)
  get_setting(setting_name).set?
end | 
 
    
      
  
  
    #set_value(setting_name, value, graceful = false)  ⇒ Object 
  
  
    Also known as:
    set
    
  
  
  
    | 
63
64
65
66
67
68
69
70
71 | # File 'lib/logstash/settings.rb', line 63
def set_value(setting_name, value, graceful = false)
  get_setting(setting_name).set(value)
rescue ArgumentError => e
  if graceful
    @transient_settings[setting_name] = value
  else
    raise e
  end
end | 
 
    
      
  
  
    #to_hash  ⇒ Object 
  
  
  
  
    | 
74
75
76
77
78
79
80 | # File 'lib/logstash/settings.rb', line 74
def to_hash
  hash = {}
  @settings.each do |name, setting|
    hash[name] = setting.value
  end
  hash
end | 
 
    
      
  
  
    #validate_all  ⇒ Object 
  
  
  
  
    | 
133
134
135
136
137
138
139
140 | # File 'lib/logstash/settings.rb', line 133
def validate_all
    self.merge(@transient_settings)
  @settings.each do |name, setting|
    setting.validate_value
  end
end |