Current File : //opt/puppetlabs/puppet/lib/ruby/vendor_ruby/puppet/file_serving/content.rb
require_relative '../../puppet/indirector'
require_relative '../../puppet/file_serving'
require_relative '../../puppet/file_serving/base'

# A class that handles retrieving file contents.
# It only reads the file when its content is specifically
# asked for.
class Puppet::FileServing::Content < Puppet::FileServing::Base
  extend Puppet::Indirector
  indirects :file_content, :terminus_class => :selector

  attr_writer :content

  def self.supported_formats
    [:binary]
  end

  def self.from_binary(content)
    instance = new("/this/is/a/fake/path")
    instance.content = content
    instance
  end

  # This is no longer used, but is still called by the file server implementations when interacting
  # with their model abstraction.
  def collect(source_permissions = nil)
  end

  # Read the content of our file in.
  def content
    unless @content
      # This stat can raise an exception, too.
      raise(ArgumentError, _("Cannot read the contents of links unless following links")) if stat.ftype == "symlink"

      @content = Puppet::FileSystem.binread(full_path)
    end
    @content
  end

  def to_binary
    File.new(full_path, "rb")
  end
end
Site is undergoing maintenance

PACJA Events

Maintenance mode is on

Site will be available soon. Thank you for your patience!