PK œqhYî¶J‚ßF ßF ) nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/
| Dir : /opt/puppetlabs/puppet/lib/ruby/vendor_ruby/puppet/module_tool/applications/ |
| Server: Linux server1.ngambekcore.com 4.18.0-553.51.1.el8_10.x86_64 #1 SMP Wed Apr 30 04:00:07 EDT 2025 x86_64 IP: 159.198.77.92 |
| Dir : //opt/puppetlabs/puppet/lib/ruby/vendor_ruby/puppet/module_tool/applications/checksummer.rb |
require_relative '../../../puppet/util/json'
require_relative '../../../puppet/module_tool/checksums'
module Puppet::ModuleTool
module Applications
class Checksummer < Application
def initialize(path, options = {})
@path = Pathname.new(path)
super(options)
end
def run
changes = []
sums = Puppet::ModuleTool::Checksums.new(@path)
checksums.each do |child_path, canonical_checksum|
# Avoid checksumming the checksums.json file
next if File.basename(child_path) == "checksums.json"
path = @path + child_path
unless path.exist? && canonical_checksum == sums.checksum(path)
changes << child_path
end
end
# Return an Array of strings representing file paths of files that have
# been modified since this module was installed. All paths are relative
# to the installed module directory. This return value is used by the
# module_tool face changes action, and displayed on the console.
#
# Example return value:
#
# [ "REVISION", "manifests/init.pp"]
#
changes
end
private
def checksums
if checksums_file.exist?
Puppet::Util::Json.load(checksums_file.read)
elsif metadata_file.exist?
# Check metadata.json too; legacy modules store their checksums there.
Puppet::Util::Json.load(metadata_file.read)['checksums'] or
raise ArgumentError, _("No file containing checksums found.")
else
raise ArgumentError, _("No file containing checksums found.")
end
end
def metadata_file
@path + 'metadata.json'
end
def checksums_file
@path + 'checksums.json'
end
end
end
end