Sha256: 4e661f11ed73deb78c5e032adfa88e9c46e7bc7a6dfe7126709b5800c5f4fe56

Contents?: true

Size: 1.12 KB

Versions: 7

Compression:

Stored size: 1.12 KB

Contents

# frozen_string_literal: true

# Read a file on localhost and return its contents using ruby's `File.read`. This will
# only read files on the machine you run Bolt on.
Puppet::Functions.create_function(:'file::read', Puppet::Functions::InternalFunction) do
  # @param filename Absolute path or Puppet file path.
  # @return The file's contents.
  # @example Read a file from disk
  #   file::read('/tmp/i_dumped_this_here')
  # @example Read a file from the modulepath
  #   file::read('example/VERSION')
  dispatch :read do
    scope_param
    required_param 'String', :filename
    return_type 'String'
  end

  def read(scope, filename)
    # Send Analytics Report
    executor = Puppet.lookup(:bolt_executor) {}
    executor&.report_function_call(self.class.name)

    found = Puppet::Parser::Files.find_file(filename, scope.compiler.environment)
    unless found && Puppet::FileSystem.exist?(found)
      raise Puppet::ParseErrorWithIssue.from_issue_and_stack(
        Puppet::Pops::Issues::NO_SUCH_FILE_OR_DIRECTORY, file: filename
      )
    end
    executor&.report_file_source(self.class.name, filename)
    File.read(found)
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
bolt-3.7.1 bolt-modules/file/lib/puppet/functions/file/read.rb
bolt-3.7.0 bolt-modules/file/lib/puppet/functions/file/read.rb
bolt-3.6.1 bolt-modules/file/lib/puppet/functions/file/read.rb
bolt-3.6.0 bolt-modules/file/lib/puppet/functions/file/read.rb
bolt-3.5.0 bolt-modules/file/lib/puppet/functions/file/read.rb
bolt-3.4.0 bolt-modules/file/lib/puppet/functions/file/read.rb
bolt-3.3.0 bolt-modules/file/lib/puppet/functions/file/read.rb