Module: Deimos::PhobosConfig
- Extended by:
- ActiveSupport::Concern
- Included in:
- FigTree::ConfigStruct
- Defined in:
- lib/deimos/config/phobos_config.rb
Overview
Module to handle phobos.yml as well as outputting the configuration to save to Phobos itself.
Instance Method Summary collapse
- 
  
    
      #phobos_config  ⇒ Hash 
    
    
  
  
  
  
  
  
  
  
  
    Create a hash representing the config that Phobos expects. 
- 
  
    
      #phobos_config_file=(file)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Legacy method to parse Phobos config file. 
- 
  
    
      #reset!  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    :nodoc:. 
- #ssl_var_contents(key) ⇒ String
- #to_h ⇒ Hash
Instance Method Details
#phobos_config ⇒ Hash
Create a hash representing the config that Phobos expects.
| 31 32 33 34 35 36 37 38 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 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 101 102 103 104 105 106 107 108 109 | # File 'lib/deimos/config/phobos_config.rb', line 31 def phobos_config p_config = { logger: Logger.new(STDOUT), custom_logger: self.phobos_logger, custom_kafka_logger: self.kafka.logger, kafka: { client_id: self.kafka.client_id, connect_timeout: self.kafka.connect_timeout, socket_timeout: self.kafka.socket_timeout, ssl_verify_hostname: self.kafka.ssl.verify_hostname, ssl_ca_certs_from_system: self.kafka.ssl.ca_certs_from_system, seed_brokers: Array.wrap(self.kafka.seed_brokers) }, producer: { ack_timeout: self.producers.ack_timeout, required_acks: self.producers.required_acks, max_retries: self.producers.max_retries, retry_backoff: self.producers.retry_backoff, max_buffer_size: self.producers.max_buffer_size, max_buffer_bytesize: self.producers.max_buffer_bytesize, compression_codec: self.producers.compression_codec, compression_threshold: self.producers.compression_threshold, max_queue_size: self.producers.max_queue_size, delivery_threshold: self.producers.delivery_threshold, delivery_interval: self.producers.delivery_interval }, consumer: { session_timeout: self.consumers.session_timeout, offset_commit_interval: self.consumers.offset_commit_interval, offset_commit_threshold: self.consumers.offset_commit_threshold, heartbeat_interval: self.consumers.heartbeat_interval }, backoff: _backoff(self.consumers.backoff.to_a) } p_config[:listeners] = self.consumer_objects.map do |consumer| next nil if consumer.disabled hash = consumer.to_h.reject do |k, _| %i(class_name schema namespace key_config backoff disabled).include?(k) end hash = hash.map { |k, v| [k, v.is_a?(Symbol) ? v.to_s : v] }.to_h hash[:handler] = consumer.class_name if consumer.backoff hash[:backoff] = _backoff(consumer.backoff.to_a) end hash end p_config[:listeners].compact! if self.kafka.ssl.enabled %w(ca_cert client_cert client_cert_key).each do |key| next if self.kafka.ssl.send(key).blank? p_config[:kafka]["ssl_#{key}".to_sym] = ssl_var_contents(self.kafka.ssl.send(key)) end end if self.kafka.sasl.enabled p_config[:kafka][:sasl_over_ssl] = self.kafka.sasl.enforce_ssl %w( gssapi_principal gssapi_keytab plain_authzid plain_username plain_password scram_username scram_password scram_mechanism oauth_token_provider ).each do |key| value = self.kafka.sasl.send(key) next if value.blank? p_config[:kafka]["sasl_#{key}".to_sym] = value end end p_config end | 
#phobos_config_file=(file) ⇒ Object
Legacy method to parse Phobos config file
| 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 | # File 'lib/deimos/config/phobos_config.rb', line 118 def phobos_config_file=(file) pconfig = YAML.load(ERB.new(File.read(File.(file))).result). # rubocop:disable Security/YAMLLoad with_indifferent_access self.logger&.warn('phobos.yml is deprecated - use direct configuration instead.') pconfig[:kafka].each do |k, v| if k.starts_with?('ssl') k = k.sub('ssl_', '') self.kafka.ssl.send("#{k}=", v) elsif k.starts_with?('sasl') k = (k == 'sasl_over_ssl') ? 'enforce_ssl' : k.sub('sasl_', '') self.kafka.sasl.send("#{k}=", v) else self.kafka.send("#{k}=", v) end end pconfig[:producer].each do |k, v| self.producers.send("#{k}=", v) end pconfig[:consumer].each do |k, v| self.consumers.send("#{k}=", v) end self.consumers.backoff = pconfig[:backoff][:min_ms]..pconfig[:backoff][:max_ms] pconfig[:listeners].each do |listener_hash| self.consumer do listener_hash.each do |k, v| k = 'class_name' if k == 'handler' send(k, v) end end end end | 
#reset! ⇒ Object
:nodoc:
| 24 25 26 27 | # File 'lib/deimos/config/phobos_config.rb', line 24 def reset! super Phobos.configure(self.phobos_config) end | 
#ssl_var_contents(key) ⇒ String
| 113 114 115 | # File 'lib/deimos/config/phobos_config.rb', line 113 def ssl_var_contents(key) File.exist?(key) ? File.read(key) : key end | 
#to_h ⇒ Hash
| 12 13 14 15 16 17 18 19 20 21 | # File 'lib/deimos/config/phobos_config.rb', line 12 def to_h (FIELDS + [:handler]).map { |f| val = self.send(f) if f == :backoff && val [:backoff, _backoff(val)] elsif val.present? [f, val] end }.to_h end |