This file is indexed.

/usr/lib/ruby/vendor_ruby/octocatalog-diff/util/util.rb is in octocatalog-diff 1.5.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
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
# frozen_string_literal: true

# Handy methods that are not tied to one particular class

require 'fileutils'

module OctocatalogDiff
  module Util
    # Helper class to construct catalogs, performing all necessary steps such as
    # bootstrapping directories, installing facts, and running puppet.
    class Util
      # Utility Method!
      # `is_a?(class)` only allows one method, but this uses an array
      # @param object [?] Object to consider
      # @param classes [Array] Classes to determine if object is a member of
      # @return [Boolean] True if object is_a any of the classes, false otherwise
      def self.object_is_any_of?(object, classes)
        classes.each { |clazz| return true if object.is_a? clazz }
        false
      end

      # Utility Method!
      # `.dup` can't be called on certain objects (Fixnum for example). This
      # method returns the original object if it can't be duplicated.
      # @param object [?] Object to consider
      # @return [?] Duplicated object if possible, otherwise the original object
      def self.safe_dup(object)
        object.dup
      rescue TypeError
        # :nocov:
        object
        # :nocov:
      end

      # Utility Method!
      # This does a "deep" duplication via recursion. Handles hashes and arrays.
      # @param object [?] Object to consider
      # @return [?] Duplicated object
      def self.deep_dup(object)
        if object.is_a?(Hash)
          result = {}
          object.each { |k, v| result[k] = deep_dup(v) }
          result
        elsif object.is_a?(Array)
          object.map { |ele| deep_dup(ele) }
        else
          safe_dup(object)
        end
      end

      # Utility Method!
      # This creates a temporary directory. If the base directory is specified, then we
      # do not remove the temporary directory at exit, because we assume that something
      # else will remove the base directory.
      #
      # prefix  - A String with the prefix for the temporary directory
      # basedir - A String with the directory in which to make the tempdir
      #
      # Returns the full path to the temporary directory.
      def self.temp_dir(prefix = 'ocd-', basedir = ENV['OCTOCATALOG_DIFF_TEMPDIR'])
        # If the base directory is specified, make sure it exists, and then create the
        # temporary directory within it.
        if basedir
          unless File.directory?(basedir)
            raise Errno::ENOENT, "temp_dir: Base dir #{basedir.inspect} does not exist!"
          end
          return Dir.mktmpdir(prefix, basedir)
        end

        # If the base directory was not specified, then create a temporary directory, and
        # send the `at_exit` to clean it up at the conclusion.
        the_dir = Dir.mktmpdir(prefix)
        at_exit { remove_temp_dir(the_dir) }
        the_dir
      end

      # Utility method!
      # Remove a directory recursively that has been used as a temporary directory. This
      # should be called within an `at_exit` handler, and is only intended to be called via the
      # `temp_dir` method above.
      #
      # dir - A String with the directory to remove.
      def self.remove_temp_dir(dir)
        retries = 0
        while File.directory?(dir) && retries < 10
          retries += 1
          begin
            FileUtils.remove_entry_secure(dir)
          rescue Errno::ENOTEMPTY, Errno::ENOENT # rubocop:disable Lint/HandleExceptions
            # Errno::ENOTEMPTY will trigger a retry because the directory exists
            # Errno::ENOENT will break the loop because the directory won't exist next time it's checked
          end
        end
      end
    end
  end
end