logstash-core 6.8.7-java → 6.8.12-java
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/logstash/util/lazy_singleton.rb +33 -0
- data/lib/logstash/util/substitution_variables.rb +22 -1
- data/spec/logstash/settings_spec.rb +10 -0
- data/versions-gem-copy.yml +2 -2
- metadata +3 -2
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 3e478e4beabbbd0c5b7e191f18e9b3609fb4c331f27685bdacb1d12a97e3e7c1
         | 
| 4 | 
            +
              data.tar.gz: 23bab0fa74a87fa73ff4e6abe8a9e74586b0b2e6d529ea1f4116ccd881e707db
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: b26be1c6adcd036103fc6712a961e67615b8bb8d949e4ae33342ef04ca9e7665332b44d15d76deef664932a26390d046fb0095ed2cc423b5858c4bd071acfc73
         | 
| 7 | 
            +
              data.tar.gz: adca4e67478633905e470c31b221cd26412e3c0ee843c78af77e832c50bf5a9ef663d326474bda7f189f2142b076001aa9432b4515ef5a599c309b6a3a9581ed
         | 
| @@ -0,0 +1,33 @@ | |
| 1 | 
            +
            require 'thread' # Mutex
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            # A [LazySingleton] wraps the result of the provided block,
         | 
| 4 | 
            +
            # which is guaranteed to be called at-most-once, even if the
         | 
| 5 | 
            +
            # block's return value is nil.
         | 
| 6 | 
            +
            class ::LogStash::Util::LazySingleton
         | 
| 7 | 
            +
             | 
| 8 | 
            +
              def initialize(&block)
         | 
| 9 | 
            +
                @mutex = Mutex.new
         | 
| 10 | 
            +
                @block = block
         | 
| 11 | 
            +
                @instantiated = false
         | 
| 12 | 
            +
              end
         | 
| 13 | 
            +
             | 
| 14 | 
            +
              def instance
         | 
| 15 | 
            +
                unless @instantiated
         | 
| 16 | 
            +
                  @mutex.synchronize do
         | 
| 17 | 
            +
                    unless @instantiated
         | 
| 18 | 
            +
                      @instance = @block.call
         | 
| 19 | 
            +
                      @instantiated = true
         | 
| 20 | 
            +
                    end
         | 
| 21 | 
            +
                  end
         | 
| 22 | 
            +
                end
         | 
| 23 | 
            +
             | 
| 24 | 
            +
                return @instance
         | 
| 25 | 
            +
              end
         | 
| 26 | 
            +
             | 
| 27 | 
            +
              def reset!
         | 
| 28 | 
            +
                @mutex.synchronize do
         | 
| 29 | 
            +
                  @instantiated = false
         | 
| 30 | 
            +
                  @instance = nil
         | 
| 31 | 
            +
                end
         | 
| 32 | 
            +
              end
         | 
| 33 | 
            +
            end
         | 
| @@ -2,12 +2,17 @@ | |
| 2 2 |  | 
| 3 3 | 
             
            java_import "org.logstash.secret.store.SecretStoreExt"
         | 
| 4 4 |  | 
| 5 | 
            +
            require_relative 'lazy_singleton'
         | 
| 6 | 
            +
             | 
| 5 7 | 
             
            module ::LogStash::Util::SubstitutionVariables
         | 
| 6 8 |  | 
| 7 9 | 
             
              include LogStash::Util::Loggable
         | 
| 8 10 |  | 
| 9 11 | 
             
              SUBSTITUTION_PLACEHOLDER_REGEX = /\${(?<name>[a-zA-Z_.][a-zA-Z0-9_.]*)(:(?<default>[^}]*))?}/
         | 
| 10 12 |  | 
| 13 | 
            +
              SECRET_STORE = ::LogStash::Util::LazySingleton.new { load_secret_store }
         | 
| 14 | 
            +
              private_constant :SECRET_STORE
         | 
| 15 | 
            +
             | 
| 11 16 | 
             
              # Recursive method to replace substitution variable references in parameters
         | 
| 12 17 | 
             
              def deep_replace(value)
         | 
| 13 18 | 
             
                if value.is_a?(Hash)
         | 
| @@ -42,7 +47,7 @@ module ::LogStash::Util::SubstitutionVariables | |
| 42 47 | 
             
                  logger.debug("Replacing `#{placeholder}` with actual value")
         | 
| 43 48 |  | 
| 44 49 | 
             
                  #check the secret store if it exists
         | 
| 45 | 
            -
                  secret_store =  | 
| 50 | 
            +
                  secret_store = SECRET_STORE.instance
         | 
| 46 51 | 
             
                  replacement = secret_store.nil? ? nil : secret_store.retrieveSecret(SecretStoreExt.getStoreId(name))
         | 
| 47 52 | 
             
                  #check the environment
         | 
| 48 53 | 
             
                  replacement = ENV.fetch(name, default) if replacement.nil?
         | 
| @@ -54,4 +59,20 @@ module ::LogStash::Util::SubstitutionVariables | |
| 54 59 | 
             
                end
         | 
| 55 60 | 
             
              end # def replace_placeholders
         | 
| 56 61 |  | 
| 62 | 
            +
              class << self
         | 
| 63 | 
            +
                private
         | 
| 64 | 
            +
             | 
| 65 | 
            +
                # loads a secret_store from disk if available, or returns nil
         | 
| 66 | 
            +
                #
         | 
| 67 | 
            +
                # @api private
         | 
| 68 | 
            +
                # @return [SecretStoreExt,nil]
         | 
| 69 | 
            +
                def load_secret_store
         | 
| 70 | 
            +
                  SecretStoreExt.getIfExists(LogStash::SETTINGS.get_setting("keystore.file").value, LogStash::SETTINGS.get_setting("keystore.classname").value)
         | 
| 71 | 
            +
                end
         | 
| 72 | 
            +
             | 
| 73 | 
            +
                # @api test
         | 
| 74 | 
            +
                def reset_secret_store
         | 
| 75 | 
            +
                  SECRET_STORE.reset!
         | 
| 76 | 
            +
                end
         | 
| 77 | 
            +
              end
         | 
| 57 78 | 
             
            end
         | 
| @@ -158,6 +158,11 @@ describe LogStash::Settings do | |
| 158 158 |  | 
| 159 159 | 
             
                before :each do
         | 
| 160 160 | 
             
                  LogStash::SETTINGS.set("keystore.file", File.join(File.dirname(__FILE__), "../../src/test/resources/logstash.keystore.with.default.pass"))
         | 
| 161 | 
            +
                  LogStash::Util::SubstitutionVariables.send(:reset_secret_store)
         | 
| 162 | 
            +
                end
         | 
| 163 | 
            +
             | 
| 164 | 
            +
                after(:each) do
         | 
| 165 | 
            +
                  LogStash::Util::SubstitutionVariables.send(:reset_secret_store)
         | 
| 161 166 | 
             
                end
         | 
| 162 167 |  | 
| 163 168 | 
             
                context "placeholders in flat logstash.yml" do
         | 
| @@ -211,6 +216,7 @@ describe LogStash::Settings do | |
| 211 216 |  | 
| 212 217 | 
             
                before :each do
         | 
| 213 218 | 
             
                  LogStash::SETTINGS.set("keystore.file", File.join(File.dirname(__FILE__), "../../src/test/resources/logstash.keystore.with.default.pass"))
         | 
| 219 | 
            +
                  LogStash::Util::SubstitutionVariables.send(:reset_secret_store)
         | 
| 214 220 | 
             
                end
         | 
| 215 221 |  | 
| 216 222 | 
             
                before do
         | 
| @@ -225,6 +231,10 @@ describe LogStash::Settings do | |
| 225 231 | 
             
                  ENV.delete('a')
         | 
| 226 232 | 
             
                end
         | 
| 227 233 |  | 
| 234 | 
            +
                after(:each) do
         | 
| 235 | 
            +
                  LogStash::Util::SubstitutionVariables.send(:reset_secret_store)
         | 
| 236 | 
            +
                end
         | 
| 237 | 
            +
             | 
| 228 238 | 
             
                subject do
         | 
| 229 239 | 
             
                  settings = described_class.new
         | 
| 230 240 | 
             
                  settings.register(LogStash::Setting::ArrayCoercible.new("host", String, []))
         | 
    
        data/versions-gem-copy.yml
    CHANGED
    
    
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: logstash-core
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 6.8. | 
| 4 | 
            +
              version: 6.8.12
         | 
| 5 5 | 
             
            platform: java
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Elastic
         | 
| 8 8 | 
             
            autorequire:
         | 
| 9 9 | 
             
            bindir: bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date: 2020- | 
| 11 | 
            +
            date: 2020-08-12 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| @@ -455,6 +455,7 @@ files: | |
| 455 455 | 
             
            - lib/logstash/util/duration_formatter.rb
         | 
| 456 456 | 
             
            - lib/logstash/util/filetools.rb
         | 
| 457 457 | 
             
            - lib/logstash/util/java_version.rb
         | 
| 458 | 
            +
            - lib/logstash/util/lazy_singleton.rb
         | 
| 458 459 | 
             
            - lib/logstash/util/loggable.rb
         | 
| 459 460 | 
             
            - lib/logstash/util/manticore_ssl_config_helper.rb
         | 
| 460 461 | 
             
            - lib/logstash/util/modules_setting_array.rb
         |