* Add option to prevent single & repeat mode to disable queuing (Closes #19)
* Honor MPC password/host format on command line option 'host'
* Fixed fuzzy search for short artist names
+ * Client side hardcoded one month caching (ugly workaround for #7)
-- kaliko jack <kaliko@azylum.org> UNRELEASED
class CacheController(object):
"""An interface to see if request should cached or not.
"""
+ CACHE_ANYWAY = False
+
def __init__(self, cache=None, cache_etags=True):
self.cache = cache or DictCache()
self.cache_etags = cache_etags
no_cache = True if 'no-cache' in cc else False
if 'max-age' in cc and cc['max-age'] == 0:
no_cache = True
-
# see if it is in the cache anyways
in_cache = self.cache.get(cache_url)
if no_cache or not in_cache:
elif 'expires' in resp.headers:
if resp.headers['expires']:
self.cache.set(cache_url, resp)
+ # Force one month max age if no Cache-Control header is found
+ # Overriding header disappearance on LastFM web service...
+ # https://getsatisfaction.com/lastfm/topics/-web-api-http-cache-control-header
+ elif CacheController.CACHE_ANYWAY:
+ resp.headers['Cache-Control'] = 'max-age=2419200'
+ self.cache.set(cache_url, resp)
def update_cached_response(self, request, response):
"""On a 304 we will get a new set of headers that we want to
from ...lib.simafm import SimaFM
from ...lib.webserv import WebService
from ...lib.cache import FileCache
+from ...lib.http import CacheController
class Lastfm(WebService):
vardir = daemon.config['sima']['var_dir']
persitent_cache = daemon.config.getboolean('lastfm', 'cache')
if persitent_cache:
+ CacheController.CACHE_ANYWAY = True
self.log.debug('Persistant cache enabled in {}'.format(join(vardir, 'http', 'LastFM')))
SimaFM.cache = FileCache(join(vardir, 'http', 'LastFM'))
self.ws = SimaFM()