Activate jinja2 autoescaping
authorSylvain Thénault <sylvain.thenault@logilab.fr>
Fri, 24 Feb 2017 09:17:48 +0100
changeset 159 712aa8b2d0d1
parent 154 8b1cf160d386
child 162 243db7c6410e
Activate jinja2 autoescaping since this is one of the awaited benefit. Add a .html extension to templates to activate auto-escaping (and likely trigger proper colorization in your editor as bonus point).
MANIFEST.in
cubicweb_sherpa/__pkginfo__.py
cubicweb_sherpa/views/__init__.py
cubicweb_sherpa/views/templates/index.jinja2
cubicweb_sherpa/views/templates/index.jinja2.html
cubicweb_sherpa/views/templates/maintemplate.jinja2
cubicweb_sherpa/views/templates/maintemplate.jinja2.html
cubicweb_sherpa/views/templates/project.jinja2
cubicweb_sherpa/views/templates/project.jinja2.html
cubicweb_sherpa/views/templates/seda.jinja2
cubicweb_sherpa/views/templates/seda.jinja2.html
cubicweb_sherpa/views/templates/utilisation.jinja2
cubicweb_sherpa/views/templates/utilisation.jinja2.html
--- a/MANIFEST.in	Thu Feb 23 23:35:38 2017 +0100
+++ b/MANIFEST.in	Fri Feb 24 09:17:48 2017 +0100
@@ -1,7 +1,7 @@
 recursive-include cubicweb_sherpa *.py
 recursive-include cubicweb_sherpa/data *.gif *.png *.ico *.css *.js *.otf *.ttf *.txt
 recursive-include cubicweb_sherpa/i18n *.po
-include cubicweb_sherpa/views/templates/*.jinja2
+include cubicweb_sherpa/views/templates/*.html
 include tox.ini
 include doc/Makefile doc/conf.py doc/*.rst
 
--- a/cubicweb_sherpa/__pkginfo__.py	Thu Feb 23 23:35:38 2017 +0100
+++ b/cubicweb_sherpa/__pkginfo__.py	Fri Feb 24 09:17:48 2017 +0100
@@ -19,7 +19,7 @@
     'cubicweb-registration': None,
     'cubicweb-rememberme': None,
     'cubicweb-relationwidget': None,
-    'jinja2': None,
+    'jinja2': '>= 2.9',
 }
 
 __recommends__ = {}
--- a/cubicweb_sherpa/views/__init__.py	Thu Feb 23 23:35:38 2017 +0100
+++ b/cubicweb_sherpa/views/__init__.py	Fri Feb 24 09:17:48 2017 +0100
@@ -15,19 +15,20 @@
 # You should have received a copy of the GNU Lesser General Public License along
 # with this program. If not, see <http://www.gnu.org/licenses/>.
 
-from jinja2 import Environment, PackageLoader
+from jinja2 import Environment, PackageLoader, select_autoescape
 
 from cubicweb.view import View
 from cubicweb.web.views import urlrewrite, startup
 
-_JINJA_ENV = Environment(loader=PackageLoader('cubicweb_sherpa.views'))
+_JINJA_ENV = Environment(loader=PackageLoader('cubicweb_sherpa.views'),
+                         autoescape=select_autoescape(enabled_extensions=('html',)))
 
 
 def jinja_render(template_name, **ctx):
     """Return a string containing result of rendering of Jinja2's `template_name` with
     `ctx` as context.
     """
-    template = _JINJA_ENV.get_template(template_name + '.jinja2')
+    template = _JINJA_ENV.get_template(template_name + '.jinja2.html')
     return template.render(**ctx)
 
 
--- a/cubicweb_sherpa/views/templates/index.jinja2	Thu Feb 23 23:35:38 2017 +0100
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,47 +0,0 @@
-<div class="col-md-12" id="accueil">
-
-  <section id="presentation">
-      <h2>Créer un profil</h2>
-      <div class="titleUnderline">
-        <span class="underline mr"></span>
-        <span class="losange"></span>
-        <span class="underline ml"></span>
-      </div>
-
-
-      <div class="col-md-10 col-md-offset-1">
-      <div id="buttons-wrapper">
-        <a href="/SEDAArchiveTransfer" class="btn btn-default">Profils Seda</a>
-      </div>
-
-        <p>
-SHERPA est un outil qui permet de créer des profils d'archivage conformes au standard d'échange en mode collaboratif.
-        </p>
-      </div>
-  </section>
-
-
-  <section id="seda">
-    <h2> Pour commencer </h2>
-    <div class="titleUnderline">
-      <span class="underline mr"></span>
-      <span class="losange"></span>
-      <span class="underline ml"></span>
-    </div>
-
-    <div id="buttons-wrapper">
-      <a href="/project" class="btn btn-default">SHERPA un générateur de profils</a>
-      <a href="/utilisation" class="btn btn-default">Comment utiliser SHERPA ?</a>
-      <a href="/seda" class="btn btn-default">Le SEDA</a>
-    </div>
-
-    <div class="col-md-12">
-      <p>
-      Le projet <span class="emphasis">SHERPA</span> a été conduit par le Service interministériel des Archives de France en 2016 afin de doter le <span class="emphasis">réseau des services publics d’archives</span> d’un outil disponible en ligne et permettant de <span class="emphasis">rédiger des profils d’archivage</span> conformes au <span class="emphasis">Standard</span> d’échange des données pour l’archivage, version 2.0.
-     <br>
-     Le projet SHERPA a été réalisé en collaboration avec le projet <a href="http://saem.e-bordeaux.org/">SAEM</a> auquel participent le Conseil départemental de la Gironde, Bordeaux Métropole et la Ville de Bordeaux, dans une optique de mutualisation des moyens. SHERPA a été réalisé par la société LOGILAB. Son code source est librement réutilisable.<br>
-     Licence : ### LICENCE ###
-      </p>
-    </div>
-  </section>
-</div>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/cubicweb_sherpa/views/templates/index.jinja2.html	Fri Feb 24 09:17:48 2017 +0100
@@ -0,0 +1,47 @@
+<div class="col-md-12" id="accueil">
+
+  <section id="presentation">
+      <h2>Créer un profil</h2>
+      <div class="titleUnderline">
+        <span class="underline mr"></span>
+        <span class="losange"></span>
+        <span class="underline ml"></span>
+      </div>
+
+
+      <div class="col-md-10 col-md-offset-1">
+      <div id="buttons-wrapper">
+        <a href="/SEDAArchiveTransfer" class="btn btn-default">Profils Seda</a>
+      </div>
+
+        <p>
+SHERPA est un outil qui permet de créer des profils d'archivage conformes au standard d'échange en mode collaboratif.
+        </p>
+      </div>
+  </section>
+
+
+  <section id="seda">
+    <h2> Pour commencer </h2>
+    <div class="titleUnderline">
+      <span class="underline mr"></span>
+      <span class="losange"></span>
+      <span class="underline ml"></span>
+    </div>
+
+    <div id="buttons-wrapper">
+      <a href="/project" class="btn btn-default">SHERPA un générateur de profils</a>
+      <a href="/utilisation" class="btn btn-default">Comment utiliser SHERPA ?</a>
+      <a href="/seda" class="btn btn-default">Le SEDA</a>
+    </div>
+
+    <div class="col-md-12">
+      <p>
+      Le projet <span class="emphasis">SHERPA</span> a été conduit par le Service interministériel des Archives de France en 2016 afin de doter le <span class="emphasis">réseau des services publics d’archives</span> d’un outil disponible en ligne et permettant de <span class="emphasis">rédiger des profils d’archivage</span> conformes au <span class="emphasis">Standard</span> d’échange des données pour l’archivage, version 2.0.
+     <br>
+     Le projet SHERPA a été réalisé en collaboration avec le projet <a href="http://saem.e-bordeaux.org/">SAEM</a> auquel participent le Conseil départemental de la Gironde, Bordeaux Métropole et la Ville de Bordeaux, dans une optique de mutualisation des moyens. SHERPA a été réalisé par la société LOGILAB. Son code source est librement réutilisable.<br>
+     Licence : ### LICENCE ###
+      </p>
+    </div>
+  </section>
+</div>
--- a/cubicweb_sherpa/views/templates/maintemplate.jinja2	Thu Feb 23 23:35:38 2017 +0100
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,73 +0,0 @@
-<body>
-  <nav class="navbar navbar-default navbar-sherpa" role="banner">
-    <div class="container-fluid">
-      <div class="col-md-2 hidden-xs hidden-sm">
-        <a href="{{ base_url }}"><img src="{{ data_url }}images/logo_SIAF.png" class="logoSIAF" /></a>
-      </div>
-      <div class="col-md-7 col-xs-8">
-        <a href="/">
-          <div class="logoSHERPA">
-            <img src="{{ data_url }}images/logo_SHERPA_2.png" class="img-responsive"/>
-          </div>
-          <div class="textSHERPA">
-            <h1>Service H&eacute;berg&eacute; pour la R&eacute;daction de Profils d&#39;Archivage</h1>
-          </div>
-        </a>
-      </div>
-      <div class="col-md-3 col-xs-4">
-        {{ right_header_component }}
-      </div>
-    </div>
-  </nav>
-  {% if breadcrumbs %}
-  <nav role="navigation" class="breadcrumbs_wrapper">
-    <div class="col-md-offset-2">
-      {{ breadcrumbs }}
-    </div>
-  </nav>
-  {% endif %}
-  <div id="{{page_id}}" class="container-fluid" role="main">
-    <aside id="aside-main-left" class="col-md-2 cwjs-aside">
-      {{ left_boxes }}
-      <div class="panel panel-default contextFreeBox facet_filterbox" id="facet_filterbox">
-        <div class="panel-heading">
-          <div class="panel-title">navigation</div>
-        </div>
-        <div class="panel-body">
-          <ul class="list-unstyled">
-            {% for page in side_box.goTo_links %}
-            <li class="facetvalue"><a href='{{ page.url }}'> {{ page.label }}</a></li>
-            {% endfor %}
-          </ul>
-        </div>
-      </div>
-    </aside>
-    <div class="col-md-10 page-content" id="pageContent">
-      {{ application_message }}
-      {{ contextual_components }}
-      {{ page_content }}
-    </div>
-  </div>
-  <div class="container-fluid">
-    <footer role="contentinfo" id="pagefooter">
-      <section class="links">
-        <div id="sherpa-resources">
-        <h3>Ressources</h3>
-        {% for resource in footer.resources %}
-          <a href='{{ resource.url }}'> {{ resource.label }}</a>
-        {% endfor %}
-        </div>
-        <div id="sherpa-navigation">
-        <h3>Navigation</h3>
-        {% for page in footer.navigation_Link %}
-          <a href='{{ page.url }}'> {{ page.label }}</a>
-        {% endfor %}
-        </div>
-      </section>
-      <div id="copyright">
-        <span>copyright</span> |
-        <span><a href="">contact</a></span>
-      </div>
-    </footer>
-  </div>
-</body>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/cubicweb_sherpa/views/templates/maintemplate.jinja2.html	Fri Feb 24 09:17:48 2017 +0100
@@ -0,0 +1,73 @@
+<body>
+  <nav class="navbar navbar-default navbar-sherpa" role="banner">
+    <div class="container-fluid">
+      <div class="col-md-2 hidden-xs hidden-sm">
+        <a href="{{ base_url }}"><img src="{{ data_url }}images/logo_SIAF.png" class="logoSIAF" /></a>
+      </div>
+      <div class="col-md-7 col-xs-8">
+        <a href="/">
+          <div class="logoSHERPA">
+            <img src="{{ data_url }}images/logo_SHERPA_2.png" class="img-responsive"/>
+          </div>
+          <div class="textSHERPA">
+            <h1>Service H&eacute;berg&eacute; pour la R&eacute;daction de Profils d&#39;Archivage</h1>
+          </div>
+        </a>
+      </div>
+      <div class="col-md-3 col-xs-4">
+        {{ right_header_component|safe }}
+      </div>
+    </div>
+  </nav>
+  {% if breadcrumbs %}
+  <nav role="navigation" class="breadcrumbs_wrapper">
+    <div class="col-md-offset-2">
+      {{ breadcrumbs|safe }}
+    </div>
+  </nav>
+  {% endif %}
+  <div id="{{page_id}}" class="container-fluid" role="main">
+    <aside id="aside-main-left" class="col-md-2 cwjs-aside">
+      {{ left_boxes|safe }}
+      <div class="panel panel-default contextFreeBox facet_filterbox" id="facet_filterbox">
+        <div class="panel-heading">
+          <div class="panel-title">navigation</div>
+        </div>
+        <div class="panel-body">
+          <ul class="list-unstyled">
+            {% for page in side_box.goTo_links %}
+            <li class="facetvalue"><a href='{{ page.url }}'> {{ page.label }}</a></li>
+            {% endfor %}
+          </ul>
+        </div>
+      </div>
+    </aside>
+    <div class="col-md-10 page-content" id="pageContent">
+      {{ application_message|safe }}
+      {{ contextual_components|safe }}
+      {{ page_content|safe }}
+    </div>
+  </div>
+  <div class="container-fluid">
+    <footer role="contentinfo" id="pagefooter">
+      <section class="links">
+        <div id="sherpa-resources">
+        <h3>Ressources</h3>
+        {% for resource in footer.resources %}
+          <a href='{{ resource.url }}'> {{ resource.label }}</a>
+        {% endfor %}
+        </div>
+        <div id="sherpa-navigation">
+        <h3>Navigation</h3>
+        {% for page in footer.navigation_Link %}
+          <a href='{{ page.url }}'> {{ page.label }}</a>
+        {% endfor %}
+        </div>
+      </section>
+      <div id="copyright">
+        <span>copyright</span> |
+        <span><a href="">contact</a></span>
+      </div>
+    </footer>
+  </div>
+</body>
--- a/cubicweb_sherpa/views/templates/project.jinja2	Thu Feb 23 23:35:38 2017 +0100
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,99 +0,0 @@
-<h1>{{ title }}</h1>
-
-<section id="sherpa-project-page">
-  <div class="column-wrap">
-    <div class="col-md-2 vcenter">
-      <img class="img-responsive project-image" src="{{ data_url }}images/sherpa_bordereau.png"/>
-    </div>
-    <div class="col-md-9">
-      <h2>Du bordereau de versement ...</h2>
-      <p>
-        Le bordereau de versement est le document qui accompagne toute entrée d’archives publiques dans un service d’archives. Le bordereau contient des informations sur le service producteur et/ou versant, le service d’archives et une description sommaire des archives qui constituent le versement. Le bordereau matérialise le transfert de responsabilité entre le service versant et le service d’archives. C’est donc un document indispensable.
-      </p>
-      <p>
-        Dans le monde numérique, le bordereau de versement peut être dématérialisé, mais il continue d’avoir la même utilité et doit comporter les mêmes informations qu’un bordereau papier. C’est pourquoi le Standard d’échange de données pour l’archivage propose une modélisation des informations qui constituent le bordereau de versement.
-      </p>
-    </div>
-  </div>
-  <div class="column-wrap">
-    <div class="col-md-2 vcenter">
-      <img class="img-responsive project-image" src="{{ data_url }}images/sherpa_profil.png"/>
-    </div>
-    <div class="col-md-9">
-      <h2>… au profil d’archivage</h2>
-      <p>
-        Toute entrée de documents dans un service d’archives fait l’objet d’une série de contrôles destinés à vérifier la conformité de cette entrée aux attentes du service en matière sanitaire, de conditionnement, etc. Le contrôle du bordereau de versement en fait partie.
-      </p>
-      <p>
-        Dans le monde numérique, le Système d’archivage électronique (SAE) va lui aussi effectuer une série de contrôles, pour la plupart automatisés et pré-paramétrés (format, taille des fichiers, etc.). Il va également réaliser un contrôle du bordereau de versement. Pour évaluer la conformité du bordereau, le SAE doit savoir précisément ce qui est attendu dans ce bordereau et donc disposer d’une matrice de bordereau appelée profil d’archivage. Le profil est, pour un flux donné, la matrice de référence à partir de laquelle le SAE va pouvoir contrôler la conformité des bordereaux de versement de ce flux.
-      </p>
-    </div>
-
-  </div>
-  <div class="img-bottom">
-    <img class="img-responsive project-image" src="{{ data_url }}images/sherpa_general.png"/>
-  </div>
-  
-  <div class="col-md-12">
-    <h2>Exemple</h2>
-
-    <table class="table">
-        <tbody>
-            <thead>
-            <tr>
-              <th>Profil</th>
-              <th>Bordereau</th>
-              <th>Vérification</th>
-            </tr>
-          </thead>
-          <tr>
-            <td>
-                <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_profil.png"/></p>
-                <p>J’attends un nom de service versant de façon obligatoire</p>
-            </td>
-            <td>
-              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_bordereau.png"/></p>
-              <p>Le service versant de mon versement est « Direction XXX »</p>
-            </td>
-            <td><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_valide.png"/></td>
-          </tr>
-          <tr>
-            <td>
-              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_profil.png"/></p>
-              <p>J’attends 35 fichiers dans le versement</p>
-            </td>
-            <td>
-              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_bordereau.png"/></p>
-              <p>Mon versement contient 40 fichiers</p>
-            </td>
-            <td><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_invalide.png"/></td>
-          </tr>
-          <tr>
-            <td>
-              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_profil.png"/></p>
-              <p>J’attends au niveau Dossier le terme d’indexation YYY</p>
-            </td>
-            <td>
-              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_bordereau.png"/></p>
-              <p>Mon versement contient au niveau Dossier le terme d’indexation YYY</p>
-            </td>
-            <td><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_valide.png"/></td>
-          </tr>
-        </tbody>
-      </table>
-
-  </div>
-
-  <div class="col-md-12">
-    <h2>Un générateur de profils</h2>
-    <p>
-    Les bordereaux de versement conformes au standard d’échange de données pour l’archivage sont des fichiers de format XML. Les profils d’archivage utilisent pour leur part des langages comme XSD ou RelaxNG qui permettent de définir la structure et le type de contenu d’un document XML.
-    </p>
-    <p>
-      SHERPA propose une interface simple et ergonomique pour rédiger des profils d’archivage et les exporter en RelaxNG. SHERPA permet également d’exporter une documentation associée au profil, lisible par un humain.
-    </p>
-  </div>
-
-
-
-</section>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/cubicweb_sherpa/views/templates/project.jinja2.html	Fri Feb 24 09:17:48 2017 +0100
@@ -0,0 +1,99 @@
+<h1>{{ title }}</h1>
+
+<section id="sherpa-project-page">
+  <div class="column-wrap">
+    <div class="col-md-2 vcenter">
+      <img class="img-responsive project-image" src="{{ data_url }}images/sherpa_bordereau.png"/>
+    </div>
+    <div class="col-md-9">
+      <h2>Du bordereau de versement ...</h2>
+      <p>
+        Le bordereau de versement est le document qui accompagne toute entrée d’archives publiques dans un service d’archives. Le bordereau contient des informations sur le service producteur et/ou versant, le service d’archives et une description sommaire des archives qui constituent le versement. Le bordereau matérialise le transfert de responsabilité entre le service versant et le service d’archives. C’est donc un document indispensable.
+      </p>
+      <p>
+        Dans le monde numérique, le bordereau de versement peut être dématérialisé, mais il continue d’avoir la même utilité et doit comporter les mêmes informations qu’un bordereau papier. C’est pourquoi le Standard d’échange de données pour l’archivage propose une modélisation des informations qui constituent le bordereau de versement.
+      </p>
+    </div>
+  </div>
+  <div class="column-wrap">
+    <div class="col-md-2 vcenter">
+      <img class="img-responsive project-image" src="{{ data_url }}images/sherpa_profil.png"/>
+    </div>
+    <div class="col-md-9">
+      <h2>… au profil d’archivage</h2>
+      <p>
+        Toute entrée de documents dans un service d’archives fait l’objet d’une série de contrôles destinés à vérifier la conformité de cette entrée aux attentes du service en matière sanitaire, de conditionnement, etc. Le contrôle du bordereau de versement en fait partie.
+      </p>
+      <p>
+        Dans le monde numérique, le Système d’archivage électronique (SAE) va lui aussi effectuer une série de contrôles, pour la plupart automatisés et pré-paramétrés (format, taille des fichiers, etc.). Il va également réaliser un contrôle du bordereau de versement. Pour évaluer la conformité du bordereau, le SAE doit savoir précisément ce qui est attendu dans ce bordereau et donc disposer d’une matrice de bordereau appelée profil d’archivage. Le profil est, pour un flux donné, la matrice de référence à partir de laquelle le SAE va pouvoir contrôler la conformité des bordereaux de versement de ce flux.
+      </p>
+    </div>
+
+  </div>
+  <div class="img-bottom">
+    <img class="img-responsive project-image" src="{{ data_url }}images/sherpa_general.png"/>
+  </div>
+  
+  <div class="col-md-12">
+    <h2>Exemple</h2>
+
+    <table class="table">
+        <tbody>
+            <thead>
+            <tr>
+              <th>Profil</th>
+              <th>Bordereau</th>
+              <th>Vérification</th>
+            </tr>
+          </thead>
+          <tr>
+            <td>
+                <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_profil.png"/></p>
+                <p>J’attends un nom de service versant de façon obligatoire</p>
+            </td>
+            <td>
+              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_bordereau.png"/></p>
+              <p>Le service versant de mon versement est « Direction XXX »</p>
+            </td>
+            <td><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_valide.png"/></td>
+          </tr>
+          <tr>
+            <td>
+              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_profil.png"/></p>
+              <p>J’attends 35 fichiers dans le versement</p>
+            </td>
+            <td>
+              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_bordereau.png"/></p>
+              <p>Mon versement contient 40 fichiers</p>
+            </td>
+            <td><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_invalide.png"/></td>
+          </tr>
+          <tr>
+            <td>
+              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_profil.png"/></p>
+              <p>J’attends au niveau Dossier le terme d’indexation YYY</p>
+            </td>
+            <td>
+              <p><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_bordereau.png"/></p>
+              <p>Mon versement contient au niveau Dossier le terme d’indexation YYY</p>
+            </td>
+            <td><img class="img-responsive exemple-image" src="{{ data_url }}images/exemple_valide.png"/></td>
+          </tr>
+        </tbody>
+      </table>
+
+  </div>
+
+  <div class="col-md-12">
+    <h2>Un générateur de profils</h2>
+    <p>
+    Les bordereaux de versement conformes au standard d’échange de données pour l’archivage sont des fichiers de format XML. Les profils d’archivage utilisent pour leur part des langages comme XSD ou RelaxNG qui permettent de définir la structure et le type de contenu d’un document XML.
+    </p>
+    <p>
+      SHERPA propose une interface simple et ergonomique pour rédiger des profils d’archivage et les exporter en RelaxNG. SHERPA permet également d’exporter une documentation associée au profil, lisible par un humain.
+    </p>
+  </div>
+
+
+
+</section>
--- a/cubicweb_sherpa/views/templates/seda.jinja2	Thu Feb 23 23:35:38 2017 +0100
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,39 +0,0 @@
-<h1>{{ title }}</h1>
-
-<section id="sherpa-seda-page">
-
-    <div class="col-md-3">
-      <img class="img-responsive seda-img" src="{{ data_url }}images/seda.png"/>
-    </div>
-
-    <div class="col-md-9">
-      <p>
-        Si les processus d’archivage et les documents qui leur sont associés (bordereaux) demeurent entièrement valables dans le monde numérique, celui-ci exige cependant une formalisation et une standardisation beaucoup plus fortes de ces processus et documents associés afin de pouvoir aller vers davantage d’automatisation.
-        Le standard d’échange de données pour l’archivage permet de modéliser les transactions d’un processus d’archivage (transfert, communication, élimination, modification et restitution) entre différents acteurs (service producteur, service versant, service d’archives et demandeur d’archives) . Il précise les types, l’ordre et la forme des messages échangés. Il définit d’autre part les métadonnées à utiliser pour décrire, gérer et pérenniser l’information.
-
-        Plusieurs versions du standard ont été successivement publiées en mars 2006 (version 0.1), janvier 2010 (version 0.2), septembre 2012 (version 1.0) et décembre 2015 (version 2.0 conforme à la norme MEDONA).
-      </p>
-
-      <p>
-        Le standard est une déclinaison technique des pratiques archivistiques utilisées dans le monde papier. Les principes du SEDA reprennent donc largement les concepts métier tels que l’usage des bordereaux (versement, élimination), l’application du contrôle scientifique et technique (transaction de demande d’autorisation), la définition des acteurs ou l’apposition de règles de gestion (sorts finaux et communicabilité).
-      </p>
-    </div>
-    <div class="col-md-12">
-      <h2>Les agents</h2>
-
-      <p>
-        Le SEDA permet d’associer aux transactions des Agents, qui sont des personnes ou des collectivités (concepts inspirés de la norme ISAAR-CPF) afin de décrire les archives échangées ou de spécifier des informations de gestion les concernant. Le modèle de métadonnées utilisé pour décrire ces agents est identique qu’il s’agisse d’identifier les acteurs de l’échange ou d’indiquer la provenance d’un document.
-        Un agent peut être utilisé plusieurs fois dans différentes transactions et peut également avoir plusieurs rôles attribués dans les messages du SEDA.
-
-        C’est pourquoi SHERPA propose de gérer un seul référentiel « Agents » dont les notices peuvent être utilisées dans tous les profils d’archivage rédigés dans l’application. Le rédacteur peut ainsi alimenter et maintenir une seule liste de référence pour l’ensemble de son corpus de profils.
-    </p>
-
-    <h2>Les vocabulaires </h2>
-    <p>
-      Le SEDA permet d’ajouter des termes d’indexation à tous les niveaux de description du plan de classement. Il s’inspire en la matière des pratiques d’indexation telles qu’elles sont recommandées par l’ EAD. Il est donc nécessaire de gérer des listes de vocabulaires d’indexation.
-      D’autres listes de valeurs contrôlées sont également utilisées dans le SEDA, notamment pour échanger les métadonnées techniques (telles que les référentiels de format, d’encodage…), les métadonnées descriptives (telles que les niveaux de description, les langues…) et les métadonnées de gestion (telles que les sorts finaux, les délais de communicabilité…).
-
-      C’est pourquoi SHERPA propose de gérer un seul référentiel « Vocabulaires » dont les références et les valeurs peuvent être utilisées dans l’ensemble des profils rédigés dans l’application. Le rédacteur peut ainsi alimenter et maintenir un ensemble de listes de références unique pour l’ensemble du corpus de profils.
-    </p>
-    </div>
-</section>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/cubicweb_sherpa/views/templates/seda.jinja2.html	Fri Feb 24 09:17:48 2017 +0100
@@ -0,0 +1,39 @@
+<h1>{{ title }}</h1>
+
+<section id="sherpa-seda-page">
+
+    <div class="col-md-3">
+      <img class="img-responsive seda-img" src="{{ data_url }}images/seda.png"/>
+    </div>
+
+    <div class="col-md-9">
+      <p>
+        Si les processus d’archivage et les documents qui leur sont associés (bordereaux) demeurent entièrement valables dans le monde numérique, celui-ci exige cependant une formalisation et une standardisation beaucoup plus fortes de ces processus et documents associés afin de pouvoir aller vers davantage d’automatisation.
+        Le standard d’échange de données pour l’archivage permet de modéliser les transactions d’un processus d’archivage (transfert, communication, élimination, modification et restitution) entre différents acteurs (service producteur, service versant, service d’archives et demandeur d’archives) . Il précise les types, l’ordre et la forme des messages échangés. Il définit d’autre part les métadonnées à utiliser pour décrire, gérer et pérenniser l’information.
+
+        Plusieurs versions du standard ont été successivement publiées en mars 2006 (version 0.1), janvier 2010 (version 0.2), septembre 2012 (version 1.0) et décembre 2015 (version 2.0 conforme à la norme MEDONA).
+      </p>
+
+      <p>
+        Le standard est une déclinaison technique des pratiques archivistiques utilisées dans le monde papier. Les principes du SEDA reprennent donc largement les concepts métier tels que l’usage des bordereaux (versement, élimination), l’application du contrôle scientifique et technique (transaction de demande d’autorisation), la définition des acteurs ou l’apposition de règles de gestion (sorts finaux et communicabilité).
+      </p>
+    </div>
+    <div class="col-md-12">
+      <h2>Les agents</h2>
+
+      <p>
+        Le SEDA permet d’associer aux transactions des Agents, qui sont des personnes ou des collectivités (concepts inspirés de la norme ISAAR-CPF) afin de décrire les archives échangées ou de spécifier des informations de gestion les concernant. Le modèle de métadonnées utilisé pour décrire ces agents est identique qu’il s’agisse d’identifier les acteurs de l’échange ou d’indiquer la provenance d’un document.
+        Un agent peut être utilisé plusieurs fois dans différentes transactions et peut également avoir plusieurs rôles attribués dans les messages du SEDA.
+
+        C’est pourquoi SHERPA propose de gérer un seul référentiel « Agents » dont les notices peuvent être utilisées dans tous les profils d’archivage rédigés dans l’application. Le rédacteur peut ainsi alimenter et maintenir une seule liste de référence pour l’ensemble de son corpus de profils.
+    </p>
+
+    <h2>Les vocabulaires </h2>
+    <p>
+      Le SEDA permet d’ajouter des termes d’indexation à tous les niveaux de description du plan de classement. Il s’inspire en la matière des pratiques d’indexation telles qu’elles sont recommandées par l’ EAD. Il est donc nécessaire de gérer des listes de vocabulaires d’indexation.
+      D’autres listes de valeurs contrôlées sont également utilisées dans le SEDA, notamment pour échanger les métadonnées techniques (telles que les référentiels de format, d’encodage…), les métadonnées descriptives (telles que les niveaux de description, les langues…) et les métadonnées de gestion (telles que les sorts finaux, les délais de communicabilité…).
+
+      C’est pourquoi SHERPA propose de gérer un seul référentiel « Vocabulaires » dont les références et les valeurs peuvent être utilisées dans l’ensemble des profils rédigés dans l’application. Le rédacteur peut ainsi alimenter et maintenir un ensemble de listes de références unique pour l’ensemble du corpus de profils.
+    </p>
+    </div>
+</section>
--- a/cubicweb_sherpa/views/templates/utilisation.jinja2	Thu Feb 23 23:35:38 2017 +0100
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,60 +0,0 @@
-<h1>{{ title }}</h1>
-<section id="utilisation">
-  <div id="utilisationWrapper">
-    <div class="utilisation col-xs-12">
-      <div>
-        <h2>Formulaire complet <span class="font-openSans">&amp;</span> formulaire simplifié</h2>
-        <p>
-          SHERPA est basé sur la version 2.0 du Standard d’échange de données pour l’archivage.
-        </p>
-          <div class="form">
-            <h4><span class="icon-right-dir"></span>Formulaire complet</h4>
-            <p>
-              Le formulaire complet propose l’exhaustivité des métadonnées du SEDA 2.0 mais ne permet pas d’exporter le profil créé dans les anciennes versions du SEDA, moins riches en métadonnées.
-            </p>
-          </div>
-
-          <div class="form">
-            <h4><span class="icon-right-dir"></span>Formulaire simplifié</h4>
-            <p>
-              Une version simplifiée de l’outil a également été développée afin d’une part de faciliter sa prise en main  et d’autre part d’exporter des profils simples dans toutes les versions du Standard (0.2, 1.0 et 2.0). Ces profils simples sont nécessairement moins riches en métadonnées que les profils complets conformes au SEDA 2.0.
-            </p>
-          </div>
-      </div>
-    </div>
-
-    <div class="utilisation col-xs-12">
-
-      <div>
-        <h2>Travail modulaire</h2>
-        <p>
-          Sherpa repose sur une approche modulaire. Il est donc possible de décrire des unités d'archives à n'importe quel niveau et de les agencer ensuite pour créer un ou plusieurs profils.
-        </p>
-      </div>
-  </div>
-
-    <div class="utilisation col-xs-12">
-
-      <div>
-        <h2>Travail en référentiel</h2>
-        <p>
-          Comme indiqué ci-dessus, le SEDA 2.0 fonctionne, pour un certain nombre de valeurs, avec des référentiels externes qu’il convient donc de définir à l’extérieur du profil. SHERPA met en œuvre ce principe en proposant des zones permettant d’alimenter et de mettre à jour les agents et les vocabulaires utilisés dans les échanges.
-          Le rédacteur peut gérer des listes de valeurs contrôlées référencées dans les bordereaux de transfert ainsi que des notices d’agents employées pour identifier les acteurs. Ces deux types de ressources centralisées peuvent être utilisés dans l’ensemble du corpus de profils.
-        </p>
-      </div>
-  </div>
-
-  <div class="utilisation col-xs-12">
-
-    <div>
-      <h2>Travail collaboratif</h2>
-      <p>
-        SHERPA est une application web et est proposé en tant que service hébergé par le Service interministériel des Archives de France. Les modules référentiels d’Agents et de Vocabulaires sont communs à toute la communauté d’utilisateurs, de même que le corpus de profils et d'unités d'archives.
-
-        Un système d’habilitation simplifié permet à tous les utilisateurs connectés de consulter le travail des autres utilisateurs. Le rédacteur d’un profil peut le modifier à tout moment et peut étendre les droits de modifications à d’autres utilisateurs s’il le souhaite.
-
-        L’ensemble des contenus est accessible en lecture à la communauté d’utilisateurs de SHERPA. Un utilisateur peut via la page gestion des permissions, donner des droits d’écriture sur les profils et les notices d’autorité qu’il a créés à un autre utilisateur. Sans avoir les droits d’écriture, il est néanmoins possible de copier un profil existant afin de le modifier.
-      </p>
-    </div>
-  </div>
-</section>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/cubicweb_sherpa/views/templates/utilisation.jinja2.html	Fri Feb 24 09:17:48 2017 +0100
@@ -0,0 +1,60 @@
+<h1>{{ title }}</h1>
+<section id="utilisation">
+  <div id="utilisationWrapper">
+    <div class="utilisation col-xs-12">
+      <div>
+        <h2>Formulaire complet <span class="font-openSans">&amp;</span> formulaire simplifié</h2>
+        <p>
+          SHERPA est basé sur la version 2.0 du Standard d’échange de données pour l’archivage.
+        </p>
+          <div class="form">
+            <h4><span class="icon-right-dir"></span>Formulaire complet</h4>
+            <p>
+              Le formulaire complet propose l’exhaustivité des métadonnées du SEDA 2.0 mais ne permet pas d’exporter le profil créé dans les anciennes versions du SEDA, moins riches en métadonnées.
+            </p>
+          </div>
+
+          <div class="form">
+            <h4><span class="icon-right-dir"></span>Formulaire simplifié</h4>
+            <p>
+              Une version simplifiée de l’outil a également été développée afin d’une part de faciliter sa prise en main  et d’autre part d’exporter des profils simples dans toutes les versions du Standard (0.2, 1.0 et 2.0). Ces profils simples sont nécessairement moins riches en métadonnées que les profils complets conformes au SEDA 2.0.
+            </p>
+          </div>
+      </div>
+    </div>
+
+    <div class="utilisation col-xs-12">
+
+      <div>
+        <h2>Travail modulaire</h2>
+        <p>
+          Sherpa repose sur une approche modulaire. Il est donc possible de décrire des unités d'archives à n'importe quel niveau et de les agencer ensuite pour créer un ou plusieurs profils.
+        </p>
+      </div>
+  </div>
+
+    <div class="utilisation col-xs-12">
+
+      <div>
+        <h2>Travail en référentiel</h2>
+        <p>
+          Comme indiqué ci-dessus, le SEDA 2.0 fonctionne, pour un certain nombre de valeurs, avec des référentiels externes qu’il convient donc de définir à l’extérieur du profil. SHERPA met en œuvre ce principe en proposant des zones permettant d’alimenter et de mettre à jour les agents et les vocabulaires utilisés dans les échanges.
+          Le rédacteur peut gérer des listes de valeurs contrôlées référencées dans les bordereaux de transfert ainsi que des notices d’agents employées pour identifier les acteurs. Ces deux types de ressources centralisées peuvent être utilisés dans l’ensemble du corpus de profils.
+        </p>
+      </div>
+  </div>
+
+  <div class="utilisation col-xs-12">
+
+    <div>
+      <h2>Travail collaboratif</h2>
+      <p>
+        SHERPA est une application web et est proposé en tant que service hébergé par le Service interministériel des Archives de France. Les modules référentiels d’Agents et de Vocabulaires sont communs à toute la communauté d’utilisateurs, de même que le corpus de profils et d'unités d'archives.
+
+        Un système d’habilitation simplifié permet à tous les utilisateurs connectés de consulter le travail des autres utilisateurs. Le rédacteur d’un profil peut le modifier à tout moment et peut étendre les droits de modifications à d’autres utilisateurs s’il le souhaite.
+
+        L’ensemble des contenus est accessible en lecture à la communauté d’utilisateurs de SHERPA. Un utilisateur peut via la page gestion des permissions, donner des droits d’écriture sur les profils et les notices d’autorité qu’il a créés à un autre utilisateur. Sans avoir les droits d’écriture, il est néanmoins possible de copier un profil existant afin de le modifier.
+      </p>
+    </div>
+  </div>
+</section>