cgilsxml.py: désactiver le cache par défaut

This commit is contained in:
Jephté Clain 2015-12-24 11:14:57 +04:00
parent 881b3b441f
commit 6c73940ffb
1 changed files with 11 additions and 0 deletions

View File

@ -173,6 +173,11 @@ def select_file(files, name):
if matches: return matches[0] if matches: return matches[0]
else: return None else: return None
def cgi_nocache():
print "Cache-Control: private, no-cache, no-store, must-revalidate, max-age=0"
print "Pragma: no-cache"
print "Expires: Thu, 01 Jan 1970 00:00:00 GMT"
def print_files(files, fgroups=None, select_group=None, script_name=None, query_string=None, xslt=None): def print_files(files, fgroups=None, select_group=None, script_name=None, query_string=None, xslt=None):
xresult = ET.Element("result") xresult = ET.Element("result")
xenv = ET.SubElement(xresult, "env") xenv = ET.SubElement(xresult, "env")
@ -228,6 +233,8 @@ def run_cgilsxml():
+ u"\n Il est possible de spécifier plusieurs champs pour le tri en les séparant par des virgules.") + u"\n Il est possible de spécifier plusieurs champs pour le tri en les séparant par des virgules.")
OP.add_option('--cgi', dest='cgi_mode', action='store_true', OP.add_option('--cgi', dest='cgi_mode', action='store_true',
help=u"Activer le mode CGI. Ce mode est automatiquement activé si la variable d'environnement REQUEST_METHOD existe.") help=u"Activer le mode CGI. Ce mode est automatiquement activé si la variable d'environnement REQUEST_METHOD existe.")
OP.add_option('--cgi-allow-cache', dest='cgi_allow_cache', action='store_true',
help=u"En mode CGI, ne pas rajouter les en-tête désactivant la mise en cache du résultat.")
OP.add_option('-P', '--cgi-path-info', dest='path_info', OP.add_option('-P', '--cgi-path-info', dest='path_info',
help=u"Spécifier un chemin d'un fichier à télécharger. En mode CGI, cette valeur est prise dans la variable d'environnement PATH_INFO") help=u"Spécifier un chemin d'un fichier à télécharger. En mode CGI, cette valeur est prise dans la variable d'environnement PATH_INFO")
OP.add_option('-Q', '--cgi-query-string', dest='query_string', OP.add_option('-Q', '--cgi-query-string', dest='query_string',
@ -252,6 +259,7 @@ def run_cgilsxml():
sortby = o.sortby sortby = o.sortby
environ = os.environ environ = os.environ
cgi_cache = o.cgi_allow_cache and True or False
cgi_mode = o.cgi_mode cgi_mode = o.cgi_mode
if cgi_mode is None: if cgi_mode is None:
cgi_mode = 'REQUEST_METHOD' in environ cgi_mode = 'REQUEST_METHOD' in environ
@ -303,11 +311,13 @@ def run_cgilsxml():
file = select_file(files, cgi_path_info) file = select_file(files, cgi_path_info)
if file is None: if file is None:
if cgi_mode: if cgi_mode:
if not cgi_cache: cgi_nocache()
print "Content-Type: text/plain; charset=UTF-8" print "Content-Type: text/plain; charset=UTF-8"
print print
print "Impossible de trouver le fichier %s" % cgi_path_info print "Impossible de trouver le fichier %s" % cgi_path_info
else: else:
if cgi_mode: if cgi_mode:
if not cgi_cache: cgi_nocache()
dlname = file.dlname or file.name dlname = file.dlname or file.name
ctype = file.has_key('type') and file.type or None ctype = file.has_key('type') and file.type or None
if ctype is None: ctype, encoding = mimetypes.guess_type(dlname, False) if ctype is None: ctype, encoding = mimetypes.guess_type(dlname, False)
@ -321,6 +331,7 @@ def run_cgilsxml():
sys.exit() sys.exit()
if cgi_mode: if cgi_mode:
if not cgi_cache: cgi_nocache()
print "Content-Type: text/xml; charset=UTF-8" print "Content-Type: text/xml; charset=UTF-8"
print print
print_files(files, fgroups, cgi_select_group, cgi_script_name, cgi_query_string, cgi_xslt) print_files(files, fgroups, cgi_select_group, cgi_script_name, cgi_query_string, cgi_xslt)