A cache store implementation which stores everything on the filesystem.
FileStore implements the Strategy::LocalCache strategy which implements an in-memory cache inside of a block.
# File activesupport/lib/active_support/cache/file_store.rb, line 23 def initialize(cache_path, options = nil) super(options) @cache_path = cache_path.to_s end
# File activesupport/lib/active_support/cache/file_store.rb, line 43 def cleanup(options = nil) options = merged_options(options) search_dir(cache_path) do |fname| entry = read_entry(fname, options) delete_entry(fname, options) if entry && entry.expired? end end
Preemptively iterates through all stored keys and removes the ones which have expired.
# File activesupport/lib/active_support/cache/file_store.rb, line 36 def clear(options = nil) root_dirs = (Dir.children(cache_path) - GITKEEP_FILES) FileUtils.rm_r(root_dirs.collect { |f| File.join(cache_path, f) }) rescue Errno::ENOENT end
Deletes all items from the cache. In this case it deletes all the entries in the specified file store directory except for .keep or .gitkeep. Be careful which directory is specified in your config file when using FileStore
because everything in that directory will be deleted.
# File activesupport/lib/active_support/cache/file_store.rb, line 63 def delete_matched(matcher, options = nil) options = merged_options(options) instrument(:delete_matched, matcher.inspect) do matcher = key_matcher(matcher, options) search_dir(cache_path) do |path| key = file_path_key(path) delete_entry(path, options) if key.match(matcher) end end end
© 2004–2019 David Heinemeier Hansson
Licensed under the MIT License.