Cache TiddlyWeb ETags so that a 304 can be sent without checking store
Project description
This is a plugin for TiddlyWeb that creates a cache of ETags.
It uses the memcached handling provided by tiddlywebplugins.caching.
Cache invalidation is handled via store hooks and this trick: http://code.google.com/p/memcached/wiki/FAQ#Deleting_by_Namespace
Note the test files are not good tests, there were used to structure development but do not adequately assert anything.
The plugins keeps a cache of ETags so we don’t need to access the store to do validation.
This operates as a two tiered piece of middleware.
On the request side it checks if the request is a GET and if it includes an If-None-Match header. If it does it looks up the current URI in the cache and compares the value with what’s in the If-Match header. If they are the same we can raise a 304 right now.
On the response side, if the current request is a GET and the outgoing response has an ETag, put the current URI and ETag into the cache.
Store HOOKs are used to invalidate the cache through the management of namespaces.
Installation is simply adding the plugin name to system_plugins and twanager_plugins in tiddlywebconfig.py
Licensed as TiddlyWeb itself. Copyright 2011, Chris Dent <cdent@peermore.com>
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Hashes for tiddlywebplugins.etagcache-0.4.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2b5ab286bdae17b94dc88fcbeeee27c0213a12194b0977d71f42fe58d285e485 |
|
MD5 | c79692109721e677c8d7ed0e1540da6b |
|
BLAKE2b-256 | e06d462e20e8e44177c092c575fef14ba02c200717bed9493c974fc7aa025bbb |