Skip to content

breakthroughfuel/pyramid_cachebust

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Pyramid Cachebust

Bust cache on static assets via query string params.

Installation

Via pip:

pip install pyramid_cachebust

Setup

Add to your configurator via the include method:

config = Configurator()
config.include('pyramid_cachebust')
config.add_static_view('static', 'myapp:static')

Now pyramid.request.Request has two new methods: cachebusted_path and cachebusted_url. These methods are wrappers for request.static_path and request.static_url, with the addition of tagging on cache-busting query parameters:

request.cachebusted_path('myapp:static/file.css')
>>> '/static/file.css?_=394a82fdd72eed3ac45d113bd8af554e'

request.cachebusted_url('myapp:static/file.css')
>>> 'http://localhost/static/file.css?_=394a82fdd72eed3ac45d113bd8af554e'

The querystring gets generated in one of two ways. The default is an MD5 hexdigest of the file contents. The two alternatives are the file's mtime ('mtime') or the time of app init ('init'). Generation of the hash/lookup of the mtime happens once per asset. Results are cached and served upon resultant calls.

Configuration

To place in your Pyramid .ini:

name type default description
cachebust.enabled bool true toggles plugin on/off
cachebust.reload_files bool false when true, cache is ignored and query param is calculated on every request
cachebust.method str md5 method of file calculation (md5, mtime or init)
cachebust.param_key str _ key of query param

Contributors

Thanks for your contributions:

  • Richard Maisano (maisano)
  • Marius Gedminas (mgedmin)

About

Cachebusting for Pyramid

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%