]> kaliko git repositories - mpd-sima.git/commitdiff
http client hardcoded caching (workaround for #7)
authorkaliko <kaliko@azylum.org>
Mon, 14 May 2018 14:31:00 +0000 (16:31 +0200)
committerkaliko <kaliko@azylum.org>
Mon, 14 May 2018 14:31:00 +0000 (16:31 +0200)
doc/Changelog
sima/lib/http.py
sima/plugins/internal/lastfm.py

index d5106edc05965989b85d11232579d02bb126513d..dcb72d90232046efb16456a6dba2a590aa79f4ec 100644 (file)
@@ -5,6 +5,7 @@ MPD_sima v0.15.0
  * 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
 
index f9a08bed869e961292d6911d03b53a5639f6b0d4..d253568419b56d82b7033494aa1560a4982bff7b 100644 (file)
@@ -48,6 +48,8 @@ def parse_uri(uri):
 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
@@ -102,7 +104,6 @@ class CacheController(object):
         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:
@@ -229,6 +230,12 @@ class CacheController(object):
             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
index 125f0090291655dc60656998b5a541a36869e6cd..280519729bbafec13de7aff60f7ea5fc20514169 100644 (file)
@@ -30,6 +30,7 @@ from os.path import join
 from ...lib.simafm import SimaFM
 from ...lib.webserv import WebService
 from ...lib.cache import FileCache
+from ...lib.http import CacheController
 
 
 class Lastfm(WebService):
@@ -42,6 +43,7 @@ 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()