Class: Chef::CookbookCacheCleaner

Inherits:
Object
  • Object
show all
Includes:
Singleton
Defined in:
lib/chef/cookbook/synchronizer.rb

Overview

Keep track of the filenames that we use in both eager cookbook downloading (during sync_cookbooks) and lazy (during the run itself, through FileVendor). After the run is over, clean up the cache.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeCookbookCacheCleaner

Returns a new instance of CookbookCacheCleaner.



29
30
31
# File 'lib/chef/cookbook/synchronizer.rb', line 29

def initialize
  reset!
end

Instance Attribute Details

#skip_removalObject

Returns the value of attribute skip_removal.



14
15
16
# File 'lib/chef/cookbook/synchronizer.rb', line 14

def skip_removal
  @skip_removal
end

Instance Method Details

#cacheObject



41
42
43
# File 'lib/chef/cookbook/synchronizer.rb', line 41

def cache
  Chef::FileCache
end

#cleanup_file_cacheObject



45
46
47
48
49
50
51
52
53
54
55
56
57
58
# File 'lib/chef/cookbook/synchronizer.rb', line 45

def cleanup_file_cache
  unless Chef::Config[:solo_legacy_mode] || skip_removal
    # Delete each file in the cache that we didn't encounter in the
    # manifest.
    cache.find(File.join(%w{cookbooks ** {*,.*}})).each do |cache_filename|
      unless @valid_cache_entries[cache_filename]
        Chef::Log.info("Removing #{cache_filename} from the cache; it is no longer needed by chef-client.")
        cache.delete(cache_filename)
      end
    end
  else
    Chef::Log.info("Skipping removal of unused files from the cache")
  end
end

#mark_file_as_valid(cache_path) ⇒ Object



37
38
39
# File 'lib/chef/cookbook/synchronizer.rb', line 37

def mark_file_as_valid(cache_path)
  @valid_cache_entries[cache_path] = true
end

#reset!Object



33
34
35
# File 'lib/chef/cookbook/synchronizer.rb', line 33

def reset!
  @valid_cache_entries = {}
end