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
|
# frozen_string_literal: true
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
|