la disposition, le type et l'encoding peuvent être spécifique à un expression --spec ou --glob
This commit is contained in:
parent
b7600aa43b
commit
6e67302691
|
@ -42,6 +42,9 @@ class Filter:
|
||||||
ex_vars = None
|
ex_vars = None
|
||||||
ex_group = None
|
ex_group = None
|
||||||
ex_break_on = None
|
ex_break_on = None
|
||||||
|
force_disposition = None
|
||||||
|
force_type = None
|
||||||
|
force_charset = None
|
||||||
|
|
||||||
def __init__(self, spec=None, glob=None):
|
def __init__(self, spec=None, glob=None):
|
||||||
if spec is not None:
|
if spec is not None:
|
||||||
|
@ -89,6 +92,9 @@ class Filter:
|
||||||
return None
|
return None
|
||||||
file.group = None
|
file.group = None
|
||||||
file.break_on = None
|
file.break_on = None
|
||||||
|
if self.force_disposition: file.content_disposition = self.force_disposition
|
||||||
|
if self.force_type: file.content_type = self.force_type
|
||||||
|
if self.force_charset: file.content_charset = self.force_charset
|
||||||
return True
|
return True
|
||||||
|
|
||||||
if self.deep_scan:
|
if self.deep_scan:
|
||||||
|
@ -118,6 +124,9 @@ class Filter:
|
||||||
else:
|
else:
|
||||||
break_on = None
|
break_on = None
|
||||||
file.break_on = break_on
|
file.break_on = break_on
|
||||||
|
if self.force_disposition: file.content_disposition = self.force_disposition
|
||||||
|
if self.force_type: file.content_type = self.force_type
|
||||||
|
if self.force_charset: file.content_charset = self.force_charset
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def match_allow(self, file):
|
def match_allow(self, file):
|
||||||
|
@ -379,6 +388,11 @@ def print_files(files, fgroups=None, select_group=None, script_name=None, xslt=N
|
||||||
ET.ElementTree(xresult).write(sys.stdout, "utf-8")
|
ET.ElementTree(xresult).write(sys.stdout, "utf-8")
|
||||||
|
|
||||||
def run_cgilsxml():
|
def run_cgilsxml():
|
||||||
|
class ContentInfos:
|
||||||
|
disposition = 'attachment'
|
||||||
|
type = None
|
||||||
|
charset = 'utf-8'
|
||||||
|
default_content = ContentInfos()
|
||||||
default_filter = Filter(r'(.*)')
|
default_filter = Filter(r'(.*)')
|
||||||
def add_spec(option, opt, value, parser, *args, **kw):
|
def add_spec(option, opt, value, parser, *args, **kw):
|
||||||
if env['filter'] is not None: env['filters'].append(env['filter'])
|
if env['filter'] is not None: env['filters'].append(env['filter'])
|
||||||
|
@ -398,6 +412,24 @@ def run_cgilsxml():
|
||||||
def set_break_on(option, opt_str, value, parser, *args, **kw):
|
def set_break_on(option, opt_str, value, parser, *args, **kw):
|
||||||
if env['filter'] is None: env['filter'] = default_filter
|
if env['filter'] is None: env['filter'] = default_filter
|
||||||
env['filter'].set_break_on(value)
|
env['filter'].set_break_on(value)
|
||||||
|
def set_content_disposition(option, opt_str, value, parser, *args, **kw):
|
||||||
|
if value in ('attachment', 'inline'): pass
|
||||||
|
elif value == 'none': value = None
|
||||||
|
else:
|
||||||
|
if cgi_mode:
|
||||||
|
if not cgi_cache: cgi_nocache()
|
||||||
|
print "Content-Type: text/plain; charset=utf-8"
|
||||||
|
print
|
||||||
|
print "%s: Disposition de contenu invalide. Ce soit être attachment, inline ou none" % cgi_content_disposition
|
||||||
|
sys.exit(1)
|
||||||
|
if env['filter'] is None: default_content.disposition = value
|
||||||
|
else: env['filter'].force_disposition = value
|
||||||
|
def set_content_type(option, opt_str, value, parser, *args, **kw):
|
||||||
|
if env['filter'] is None: default_content.type = value
|
||||||
|
else: env['filter'].force_type = value
|
||||||
|
def set_content_charset(option, opt_str, value, parser, *args, **kw):
|
||||||
|
if env['filter'] is None: default_content.charset = value
|
||||||
|
else: env['filter'].force_charset = value
|
||||||
|
|
||||||
from optparse import OptionParser
|
from optparse import OptionParser
|
||||||
OP = OptionParser(usage=u"\n\t%prog [options] /path/to/dir", description=__doc__)
|
OP = OptionParser(usage=u"\n\t%prog [options] /path/to/dir", description=__doc__)
|
||||||
|
@ -418,48 +450,70 @@ def run_cgilsxml():
|
||||||
+ u"Si l'expression ne contient pas le caractère '/', la correspondance est faite uniquement sur le nom de fichier avec le module fnmatch, et le point n'a plus de signification particulière. "
|
+ u"Si l'expression ne contient pas le caractère '/', la correspondance est faite uniquement sur le nom de fichier avec le module fnmatch, et le point n'a plus de signification particulière. "
|
||||||
+ u"Cette méthode de correspondance ne permet pas de définir des groupes et ne permet donc pas d'extraire des variables.")
|
+ u"Cette méthode de correspondance ne permet pas de définir des groupes et ne permet donc pas d'extraire des variables.")
|
||||||
OP.add_option('-E', '--allow-spec', dest='spec', action='callback', callback=allow_spec, type='string',
|
OP.add_option('-E', '--allow-spec', dest='spec', action='callback', callback=allow_spec, type='string',
|
||||||
help=u"Ajouter une spécification de fichier qui peut être demandé avec --cgi-path-info. Ces fichiers ne sont pas inclus dans la liste.")
|
help=u"Ajouter une spécification de fichier qui peut être demandé avec --cgi-path-info. "
|
||||||
|
+ u"Ces fichiers ne sont pas inclus dans la liste.")
|
||||||
OP.add_option('-v', '--var', dest='var', action='callback', callback=add_var, type='string',
|
OP.add_option('-v', '--var', dest='var', action='callback', callback=add_var, type='string',
|
||||||
help=u"Définir la variable NAME à la valeur de l'expression VAR_EXPR. Dans cette expression, il est possible d'utiliser des expressions de la forme %(var)s pour inclure des variables déjà définies, ou \\N et \\g<NAME> pour inclure respectivement le groupe numéro N et le groupe nommé NAME de l'expression régulière --spec."
|
help=u"Définir la variable NAME à la valeur de l'expression VAR_EXPR. "
|
||||||
+ u"\n Cette option peut être spécifiée plusieurs fois. Elle s'applique à l'expression régulière définie par la dernière option --spec")
|
+ u"Dans cette expression, il est possible d'utiliser des expressions de la forme %(var)s pour inclure des variables déjà définies, ou \\N et \\g<NAME> pour inclure respectivement le groupe numéro N et le groupe nommé NAME de l'expression régulière --spec."
|
||||||
|
+ u"\n Cette option peut être spécifiée plusieurs fois. "
|
||||||
|
+ u"Elle s'applique à l'expression régulière définie par la dernière option --spec")
|
||||||
OP.add_option('-g', '--group', dest='group', action='callback', callback=set_group, type='string',
|
OP.add_option('-g', '--group', dest='group', action='callback', callback=set_group, type='string',
|
||||||
help=u"Spécifier l'expression qui permet de construire des ensembles de fichiers sur la base des groupes définis dans l'expression régulière de l'option --spec. Dans cette expression, il est possible d'utiliser des expressions de la forme %(var)s pour inclure des variables déjà définies, ou \\N ou \\g<NAME> pour inclure respectivement le groupe numéro N et le groupe nommé NAME de l'expression régulière --spec."
|
help=u"Spécifier l'expression qui permet de construire des ensembles de fichiers sur la base des groupes définis dans l'expression régulière de l'option --spec. "
|
||||||
|
+ u"Dans cette expression, il est possible d'utiliser des expressions de la forme %(var)s pour inclure des variables déjà définies, ou \\N ou \\g<NAME> pour inclure respectivement le groupe numéro N et le groupe nommé NAME de l'expression régulière --spec."
|
||||||
+ u"\n Cette option ne peut être spécifiée qu'une seule fois par option --spec")
|
+ u"\n Cette option ne peut être spécifiée qu'une seule fois par option --spec")
|
||||||
OP.add_option('-b', '--break-on', dest='break_on', action='callback', callback=set_break_on, type='string',
|
OP.add_option('-b', '--break-on', dest='break_on', action='callback', callback=set_break_on, type='string',
|
||||||
help=u"Spécifier une expression qui permet de partitionner la list des fichiers au sein d'un même groupe. Dans cette expression, il est possible d'utiliser des expressions de la forme %(var)s pour inclure des variables déjà définies, ou \\N ou \\g<NAME> pour inclure respectivement le groupe numéro N et le groupe nommé NAME de l'expression régulière --spec."
|
help=u"Spécifier une expression qui permet de partitionner la list des fichiers au sein d'un même groupe. "
|
||||||
|
+ u"Dans cette expression, il est possible d'utiliser des expressions de la forme %(var)s pour inclure des variables déjà définies, ou \\N ou \\g<NAME> pour inclure respectivement le groupe numéro N et le groupe nommé NAME de l'expression régulière --spec."
|
||||||
+ u"\n Bien que ce ne soit pas une obligation, il est logique de trier la liste sur cette expression pour que les groupes de fichiers soient ensembles dans la liste."
|
+ u"\n Bien que ce ne soit pas une obligation, il est logique de trier la liste sur cette expression pour que les groupes de fichiers soient ensembles dans la liste."
|
||||||
+ u"\n Cette option ne peut être spécifiée qu'une seule fois par option --spec")
|
+ u"\n Cette option ne peut être spécifiée qu'une seule fois par option --spec")
|
||||||
OP.add_option('-s', '--sort', dest='sortby',
|
OP.add_option('-s', '--sort', dest='sortby',
|
||||||
help=u"Spécifier le champ sur lequel trier ainsi que le type de tri à utiliser. SORT_EXPR est de la forme FIELD:TYPE où FIELD est le nom du champ et TYPE est le type de tri: A, D, C et/ou N pour (A)scendant, (D)escendant, (C)haine, (N)numérique. Si un champ est spécifié mais que le type de tri ne l'est pas, la valeur par défaut est AC. Si cette option n'est pas spécifiée, le tri par défaut est 'mtime:DN'."
|
help=u"Spécifier le champ sur lequel trier ainsi que le type de tri à utiliser. "
|
||||||
|
+ u"SORT_EXPR est de la forme FIELD:TYPE où FIELD est le nom du champ et TYPE est le type de tri: A, D, C et/ou N pour (A)scendant, (D)escendant, (C)haine, (N)numérique. "
|
||||||
|
+ u"Si un champ est spécifié mais que le type de tri ne l'est pas, la valeur par défaut est AC. "
|
||||||
|
+ u"Si cette option n'est pas spécifiée, le tri par défaut est 'mtime:DN'."
|
||||||
+ 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. "
|
||||||
|
+ u"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',
|
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.")
|
help=u"En mode CGI, ne pas rajouter les en-tête désactivant la mise en cache du résultat.")
|
||||||
OP.add_option('--cgi-content-type', '--cgict', dest='cgi_content_type',
|
OP.add_option('--cgi-content-disposition', '--cgicd', dest='content-disposition', action='callback', callback=set_content_disposition, type='string',
|
||||||
help=u"En mode CGI, forcer le type de contenu avec lequel servir le fichier.")
|
help=u"En mode CGI, forcer la disposition de contenu avec lequel servir le fichier. "
|
||||||
OP.add_option('--cgi-content-charset', '--cgicc', dest='cgi_content_charset',
|
+ u"Les valeurs valides sont attachment (par défaut), inline, none. "
|
||||||
help=u"En mode CGI, forcer l'encoding de contenu avec lequel servir le fichier.")
|
+ u"Si cette option est spécifiée après une option --spec ou --glob, elle ne s'applique qu'aux fichiers qui correspondent à ce modèle")
|
||||||
OP.add_option('--cgi-content-disposition', '--cgicd', dest='cgi_content_disposition',
|
OP.add_option('--cgi-content-type', '--cgict', dest='content-type', action='callback', callback=set_content_type, type='string',
|
||||||
help=u"En mode CGI, forcer la disposition de contenu avec lequel servir le fichier. Les valeurs valides sont attachment (par défaut), inline, none")
|
help=u"En mode CGI, forcer le type de contenu avec lequel servir le fichier."
|
||||||
|
+ u"Si cette option est spécifiée après une option --spec ou --glob, elle ne s'applique qu'aux fichiers qui correspondent à ce modèle")
|
||||||
|
OP.add_option('--cgi-content-charset', '--cgicc', dest='content-charset', action='callback', callback=set_content_charset, type='string',
|
||||||
|
help=u"En mode CGI, forcer l'encoding de contenu avec lequel servir le fichier."
|
||||||
|
+ u"Si cette option est spécifiée après une option --spec ou --glob, elle ne s'applique qu'aux fichiers qui correspondent à ce modèle")
|
||||||
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. "
|
||||||
|
+ u"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',
|
||||||
help=u"Spécifier la valeur de QUERY_STRING pour provisionner l'environnement du fichier résultat. En mode CGI, cette valeur est prise dans la variable d'environnement QUERY_STRING.")
|
help=u"Spécifier la valeur de QUERY_STRING pour provisionner l'environnement du fichier résultat. "
|
||||||
|
+ u"En mode CGI, cette valeur est prise dans la variable d'environnement QUERY_STRING.")
|
||||||
OP.add_option('-N', '--cgi-script-name', dest='script_name',
|
OP.add_option('-N', '--cgi-script-name', dest='script_name',
|
||||||
help=u"Spécifier la valeur de SCRIPT_NAME pour provisionner l'environnement du fichier résultat. En mode CGI, cette option est automatiquement activée si QUERY_STRING contient le paramètre script_name=SCRIPT_NAME, la valeur par défaut étant la valeur de la variable d'environnement SCRIPT_NAME."
|
help=u"Spécifier la valeur de SCRIPT_NAME pour provisionner l'environnement du fichier résultat. "
|
||||||
|
+ u"En mode CGI, cette option est automatiquement activée si QUERY_STRING contient le paramètre script_name=SCRIPT_NAME, la valeur par défaut étant la valeur de la variable d'environnement SCRIPT_NAME."
|
||||||
+ u"\n L'ordre de priorité pour le calcul de cette valeur est: d'abord le paramètre script_name dans QUERY_STRING, puis l'option de la ligne de commande, enfin la valeur de la variable d'environnement")
|
+ u"\n L'ordre de priorité pour le calcul de cette valeur est: d'abord le paramètre script_name dans QUERY_STRING, puis l'option de la ligne de commande, enfin la valeur de la variable d'environnement")
|
||||||
OP.add_option('-G', '--cgi-param-group', dest='select_group',
|
OP.add_option('-G', '--cgi-param-group', dest='select_group',
|
||||||
help=u"Sélectionner le groupe spécifié. Seuls les fichiers du groupe sont affichés. En mode CGI, cette option est automatiquement activée si QUERY_STRING contient le paramètre group=GROUP."
|
help=u"Sélectionner le groupe spécifié. "
|
||||||
|
+ u"Seuls les fichiers du groupe sont affichés. "
|
||||||
|
+ u"En mode CGI, cette option est automatiquement activée si QUERY_STRING contient le paramètre group=GROUP."
|
||||||
+ u"\n S'il n'y a qu'un seul groupe, il est automatiquement sélectionné."
|
+ u"\n S'il n'y a qu'un seul groupe, il est automatiquement sélectionné."
|
||||||
+ u"\n L'ordre de priorité pour le calcul de cette valeur est: d'abord le paramètre group dans QUERY_STRING, puis l'option de la ligne de commande")
|
+ u"\n L'ordre de priorité pour le calcul de cette valeur est: d'abord le paramètre group dans QUERY_STRING, puis l'option de la ligne de commande")
|
||||||
OP.add_option('-t', '--cgi-param-xslt', dest='xslt',
|
OP.add_option('-t', '--cgi-param-xslt', dest='xslt',
|
||||||
help=u"Ajouter le chemin vers la feuille de style XSLT dans le flux XML généré. En mode CGI, cette option est automatiquement activée si QUERY_STRING contient le paramètre xslt=XSLT."
|
help=u"Ajouter le chemin vers la feuille de style XSLT dans le flux XML généré. "
|
||||||
|
+ u"En mode CGI, cette option est automatiquement activée si QUERY_STRING contient le paramètre xslt=XSLT."
|
||||||
+ u"\n L'ordre de priorité pour le calcul de cette valeur est: d'abord le paramètre xslt dans QUERY_STRING, puis l'option de la ligne de commande")
|
+ u"\n L'ordre de priorité pour le calcul de cette valeur est: d'abord le paramètre xslt dans QUERY_STRING, puis l'option de la ligne de commande")
|
||||||
OP.add_option('-i', '--include', dest='includes', action='append',
|
OP.add_option('-i', '--include', dest='includes', action='append',
|
||||||
help=u"Spécifier un paramètre à inclure pour construire la valeur du chemin xpath /result/env/query_string dans le résultat. Il est possible de spécifier plusieurs paramètres en les séparant par des virgules. Par défaut, prendre tous les paramètres de la requête.")
|
help=u"Spécifier un paramètre à inclure pour construire la valeur du chemin xpath /result/env/query_string dans le résultat. "
|
||||||
|
+ u"Il est possible de spécifier plusieurs paramètres en les séparant par des virgules. "
|
||||||
|
+ u"Par défaut, prendre tous les paramètres de la requête.")
|
||||||
OP.add_option('-x', '--exclude', dest='excludes', action='append',
|
OP.add_option('-x', '--exclude', dest='excludes', action='append',
|
||||||
help=u"Spécifier un paramètre à exclure pour construire la valeur du chemin xpath /result/env/query_string dans le résultat. Il est possible de spécifier plusieurs paramètres en les séparant par des virgules.")
|
help=u"Spécifier un paramètre à exclure pour construire la valeur du chemin xpath /result/env/query_string dans le résultat. "
|
||||||
|
+ u"Il est possible de spécifier plusieurs paramètres en les séparant par des virgules.")
|
||||||
OP.add_option('-p', '--prefix', dest="prefix",
|
OP.add_option('-p', '--prefix', dest="prefix",
|
||||||
help=u"Ajouter les paramètres supplémentaires spécifiés à /result/env/query_string.")
|
help=u"Ajouter les paramètres supplémentaires spécifiés à /result/env/query_string.")
|
||||||
env = dict(filters=[], filter=None)
|
env = dict(filters=[], filter=None)
|
||||||
|
@ -471,18 +525,6 @@ def run_cgilsxml():
|
||||||
environ = os.environ
|
environ = os.environ
|
||||||
cgi_mode = o.cgi_mode
|
cgi_mode = o.cgi_mode
|
||||||
cgi_cache = o.cgi_allow_cache and True or False
|
cgi_cache = o.cgi_allow_cache and True or False
|
||||||
cgi_content_type = o.cgi_content_type
|
|
||||||
cgi_content_charset = o.cgi_content_charset or 'utf-8'
|
|
||||||
cgi_content_disposition = o.cgi_content_disposition or 'attachment'
|
|
||||||
if cgi_content_disposition in ('attachment', 'inline'): pass
|
|
||||||
elif cgi_content_disposition == 'none': cgi_content_disposition = None
|
|
||||||
else:
|
|
||||||
if cgi_mode:
|
|
||||||
if not cgi_cache: cgi_nocache()
|
|
||||||
print "Content-Type: text/plain; charset=utf-8"
|
|
||||||
print
|
|
||||||
print "%s: Disposition de contenu invalide. Ce soit être attachment, inline ou none" % cgi_content_disposition
|
|
||||||
sys.exit(1)
|
|
||||||
cgi_query_string = o.query_string
|
cgi_query_string = o.query_string
|
||||||
if cgi_query_string is not None: environ['QUERY_STRING'] = cgi_query_string
|
if cgi_query_string is not None: environ['QUERY_STRING'] = cgi_query_string
|
||||||
if cgi_mode is None:
|
if cgi_mode is None:
|
||||||
|
@ -543,13 +585,18 @@ def run_cgilsxml():
|
||||||
if cgi_mode:
|
if cgi_mode:
|
||||||
if not cgi_cache: cgi_nocache()
|
if not cgi_cache: cgi_nocache()
|
||||||
dlname = file.dlname or file.name
|
dlname = file.dlname or file.name
|
||||||
ctype = cgi_content_type
|
if file.has_key('content_disposition'): content_disposition = file.content_disposition
|
||||||
if ctype is None: ctype = file.has_key('type') and file.type or None
|
else: content_disposition = default_content.disposition
|
||||||
if ctype is None: ctype, encoding = mimetypes.guess_type(dlname, False)
|
if file.has_key('content_type'): content_type = file.content_type
|
||||||
if ctype is None: ctype = "application/octet-stream"
|
else: content_type = default_content.type
|
||||||
print "Content-Type: %s; charset=%s" % (ctype, cgi_content_charset)
|
if content_type is None: content_type, encoding = mimetypes.guess_type(dlname, False)
|
||||||
if cgi_content_disposition is not None:
|
if content_type is None: content_type = "application/octet-stream"
|
||||||
print "Content-Disposition: %s; filename=\"%s\"" % (cgi_content_disposition, dlname)
|
if file.has_key('content_charset'): content_charset = file.content_charset
|
||||||
|
else: content_charset = default_content.charset
|
||||||
|
|
||||||
|
print "Content-Type: %s; charset=%s" % (content_type, content_charset)
|
||||||
|
if content_disposition is not None:
|
||||||
|
print "Content-Disposition: %s; filename=\"%s\"" % (content_disposition, dlname)
|
||||||
print
|
print
|
||||||
inf = open(file.pf, 'rb')
|
inf = open(file.pf, 'rb')
|
||||||
try: shutil.copyfileobj(inf, sys.stdout)
|
try: shutil.copyfileobj(inf, sys.stdout)
|
||||||
|
|
Loading…
Reference in New Issue