This file is indexed.

/usr/lib/ruby/vendor_ruby/vagrant/config/top.rb is in vagrant 1.0.3-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
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
module Vagrant
  module Config
    # This class is the "top" configure class, which handles registering
    # other configuration classes as well as validation of all configured
    # classes. This is the object which is returned by {Environment#config}
    # and has accessors to all other configuration classes.
    #
    # If you're looking to create your own configuration class, see {Base}.
    class Top < Base
      attr_reader :keys

      def initialize(registry=nil)
        @keys = {}
        @registry = registry || Vagrant.config_keys
      end

      # We use method_missing as a way to get the configuration that is used
      # for Vagrant and load the proper configuration classes for each.
      def method_missing(name, *args)
        return @keys[name] if @keys.has_key?(name)

        config_klass = @registry.get(name.to_sym)
        if config_klass
          # Instantiate the class and return the instance
          @keys[name] = config_klass.new
          return @keys[name]
        else
          # Super it up to probably raise a NoMethodError
          super
        end
      end

      # Custom implementation to merge each key separately.
      def merge(other)
        result = self.class.new
        @keys.each do |key, value|
          result.keys[key] = value.merge(other.send(key))
        end

        other.keys.each do |key, value|
          if !@keys.has_key?(key)
            # This is a key that the other configuration class has
            # that we don't, so just copy it in.
            result.keys[key] = value.dup
          end
        end

        result
      end

      # Validates the configuration classes of this instance and raises an
      # exception if they are invalid. If you are implementing a custom configuration
      # class, the method you want to implement is {Base#validate}. This is
      # the method that checks all the validation, not one which defines
      # validation rules.
      def validate!(env)
        # Validate each of the configured classes and store the results into
        # a hash.
        errors = @keys.inject({}) do |container, data|
          key, instance = data
          recorder = ErrorRecorder.new
          instance.validate(env, recorder)
          container[key.to_sym] = recorder if !recorder.errors.empty?
          container
        end

        return if errors.empty?
        raise Errors::ConfigValidationFailed, :messages => Util::TemplateRenderer.render("config/validation_failed", :errors => errors)
      end
    end
  end
end