151 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			151 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
| # Copyright 2013 Google Inc.
 | |
| #
 | |
| # Licensed under the Apache License, Version 2.0 (the "License");
 | |
| # you may not use this file except in compliance with the License.
 | |
| # You may obtain a copy of the License at
 | |
| #
 | |
| #      http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing, software
 | |
| # distributed under the License is distributed on an "AS IS" BASIS,
 | |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| # See the License for the specific language governing permissions and
 | |
| # limitations under the License.
 | |
| 
 | |
| module Google
 | |
|   class APIClient
 | |
|     class Service
 | |
| 
 | |
|       # Simple file store to be used in the event no ActiveSupport cache store
 | |
|       # is provided. This is not thread-safe, and does not support a number of
 | |
|       # features (such as expiration), but it's useful for the simple purpose of
 | |
|       # caching discovery documents to disk.
 | |
|       # Implements the basic cache methods of ActiveSupport::Cache::Store in a
 | |
|       # limited fashion.
 | |
|       class SimpleFileStore
 | |
| 
 | |
|         # Creates a new SimpleFileStore.
 | |
|         #
 | |
|         # @param [String] file_path
 | |
|         #   The path to the cache file on disk.
 | |
|         # @param [Object] options
 | |
|         #   The options to be used with this SimpleFileStore. Not implemented.
 | |
|         def initialize(file_path, options = nil)
 | |
|           @file_path = file_path.to_s
 | |
|         end
 | |
| 
 | |
|         # Returns true if a key exists in the cache.
 | |
|         #
 | |
|         # @param [String] name
 | |
|         #   The name of the key. Will always be converted to a string.
 | |
|         # @param [Object] options
 | |
|         #   The options to be used with this query. Not implemented.
 | |
|         def exist?(name, options = nil)
 | |
|           read_file
 | |
|           @cache.nil? ? nil : @cache.include?(name.to_s)
 | |
|         end
 | |
| 
 | |
|         # Fetches data from the cache and returns it, using the given key.
 | |
|         # If the key is missing and no block is passed, returns nil.
 | |
|         # If the key is missing and a block is passed, executes the block, sets
 | |
|         # the key to its value, and returns it.
 | |
|         #
 | |
|         # @param [String] name
 | |
|         #   The name of the key. Will always be converted to a string.
 | |
|         # @param [Object] options
 | |
|         #   The options to be used with this query. Not implemented.
 | |
|         # @yield [String]
 | |
|         #   optional block with the default value if the key is missing
 | |
|         def fetch(name, options = nil)
 | |
|           read_file
 | |
|           if block_given?
 | |
|             entry = read(name.to_s, options)
 | |
|             if entry.nil?
 | |
|               value = yield name.to_s
 | |
|               write(name.to_s, value)
 | |
|               return value
 | |
|             else
 | |
|               return entry
 | |
|             end
 | |
|           else
 | |
|             return read(name.to_s, options)
 | |
|           end
 | |
|         end
 | |
| 
 | |
|         # Fetches data from the cache, using the given key.
 | |
|         # Returns nil if the key is missing.
 | |
|         #
 | |
|         # @param [String] name
 | |
|         #   The name of the key. Will always be converted to a string.
 | |
|         # @param [Object] options
 | |
|         #   The options to be used with this query. Not implemented.
 | |
|         def read(name, options = nil)
 | |
|           read_file
 | |
|           @cache.nil? ? nil : @cache[name.to_s]
 | |
|         end
 | |
| 
 | |
|         # Writes the value to the cache, with the key.
 | |
|         #
 | |
|         # @param [String] name
 | |
|         #   The name of the key. Will always be converted to a string.
 | |
|         # @param [Object] value
 | |
|         #   The value to be written.
 | |
|         # @param [Object] options
 | |
|         #   The options to be used with this query. Not implemented.
 | |
|         def write(name, value, options = nil)
 | |
|           read_file
 | |
|           @cache = {} if @cache.nil?
 | |
|           @cache[name.to_s] = value
 | |
|           write_file
 | |
|           return nil
 | |
|         end
 | |
| 
 | |
|         # Deletes an entry in the cache.
 | |
|         # Returns true if an entry is deleted.
 | |
|         #
 | |
|         # @param [String] name
 | |
|         #   The name of the key. Will always be converted to a string.
 | |
|         # @param [Object] options
 | |
|         #   The options to be used with this query. Not implemented.
 | |
|         def delete(name, options = nil)
 | |
|           read_file
 | |
|           return nil if @cache.nil?
 | |
|           if @cache.include? name.to_s
 | |
|             @cache.delete name.to_s
 | |
|             write_file
 | |
|             return true
 | |
|           else
 | |
|             return nil
 | |
|           end
 | |
|         end
 | |
| 
 | |
|         protected
 | |
| 
 | |
|         # Read the entire cache file from disk.
 | |
|         # Will avoid reading if there have been no changes.
 | |
|         def read_file
 | |
|           if !File.exists? @file_path
 | |
|             @cache = nil
 | |
|           else
 | |
|             # Check for changes after our last read or write.
 | |
|             if @last_change.nil? || File.mtime(@file_path) > @last_change
 | |
|               File.open(@file_path) do |file|
 | |
|                 @cache = Marshal.load(file)
 | |
|                 @last_change = file.mtime
 | |
|               end
 | |
|             end
 | |
|           end
 | |
|           return @cache
 | |
|         end
 | |
| 
 | |
|         # Write the entire cache contents to disk.
 | |
|         def write_file
 | |
|           File.open(@file_path, 'w') do |file|
 | |
|             Marshal.dump(@cache, file)
 | |
|           end
 | |
|           @last_change = File.mtime(@file_path)
 | |
|         end
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end |