192 lines
4.5 KiB
Markdown
192 lines
4.5 KiB
Markdown
# La bibliothèque rougail
|
|
|
|
Rougail est une bibliothèque simple a utiliser.
|
|
|
|
Dans les exemples suivant, nous utilisons la configuration par défaut de Rougail. Vous pouvez [personnaliser les répertoires utilisés](config.md).
|
|
|
|
## Convertisons un dictionnaire en objet tiramisu
|
|
|
|
Commençons par créer un dictionnaire simple.
|
|
|
|
Voici un premier dictionnaire /srv/rougail/dictionaries/00-base.xml :
|
|
|
|
```
|
|
<?xml version='1.0' encoding='UTF-8'?>
|
|
<rougail>
|
|
<variables>
|
|
<variable name="my_variable">
|
|
<value>my_value</value>
|
|
</variable>
|
|
</variables>
|
|
</rougail>
|
|
```
|
|
|
|
Construisons les objets tiramisu :
|
|
|
|
```python
|
|
from rougail import RougailConvert
|
|
|
|
rougail = RougailConvert()
|
|
rougail.save('example.py')
|
|
```
|
|
|
|
Un nouveau fichier 'example.py' va être créé dans le répertoire local
|
|
|
|
## Convertisons un dictionnaire extra en objet tiramisu
|
|
|
|
En plus du dictionnaire précédent, créons un dictionnaire extra /srv/rougail/extra_dictionaries/00-base.xml
|
|
|
|
```
|
|
<?xml version='1.0' encoding='UTF-8'?>
|
|
<rougail>
|
|
<variables>
|
|
<variable name="my_variable_extra">
|
|
<value>my_value_extra</value>
|
|
</variable>
|
|
</variables>
|
|
</rougail>
|
|
```
|
|
|
|
Construisons les objets tiramisu :
|
|
|
|
```python
|
|
from rougail import RougailConvert, RougailConfig
|
|
|
|
RougailConfig['extra_dictionaries']['example'] = ['/srv/rougail/extra_dictionaries/']
|
|
|
|
rougail = RougailConvert()
|
|
rougail.save('example.py')
|
|
```
|
|
|
|
## Templatisons un template
|
|
|
|
Nous créons un dictionnaire complémentaire pour ajouter notre template /srv/rougail/dictionaries/00-template.xml :
|
|
|
|
```
|
|
<?xml version='1.0' encoding='UTF-8'?>
|
|
<rougail>
|
|
<services>
|
|
<service name="example">
|
|
<file name="/etc/example.conf"/>
|
|
</service>
|
|
</services>
|
|
</rougail>
|
|
```
|
|
|
|
Et un template /srv/rougail/templates/example.conf :
|
|
|
|
```
|
|
The value: %%my_variable
|
|
|
|
The extra value: %%example.my_variable_extra
|
|
```
|
|
|
|
Générons le fichier tiramisu :
|
|
|
|
```python
|
|
from rougail import RougailConvert, RougailConfig
|
|
|
|
RougailConfig['extra_dictionaries']['example'] = ['/srv/rougail/extra_dictionaries/']
|
|
|
|
rougail = RougailConvert()
|
|
rougail.save('example.py')
|
|
```
|
|
|
|
Créer les répertoires utils pour la templatisation :
|
|
|
|
```bash
|
|
mkdir /srv/rougail/destinations /srv/rougail/tmp
|
|
```
|
|
|
|
Générons le template :
|
|
|
|
```python
|
|
import asyncio
|
|
from example import option_0
|
|
from tiramisu import Config
|
|
from rougail import RougailSystemdTemplate
|
|
|
|
async def template():
|
|
config = await Config(option_0)
|
|
engine = RougailSystemdTemplate(config)
|
|
await engine.instance_files()
|
|
|
|
loop = asyncio.get_event_loop()
|
|
loop.run_until_complete(template())
|
|
loop.close()
|
|
```
|
|
|
|
Le fichier /srv/rougail/destinations/etc/example.conf est maintenant créé avec le contenu attendu suivant :
|
|
|
|
```
|
|
The value: my_value
|
|
|
|
The extra value: my_value_extra
|
|
```
|
|
|
|
## Appliquons un patch au template
|
|
|
|
Il peut être intéressant de réaliser un patch à un template pour corriger un problème spécifique à notre environnement, sans attendre que le mainteneur du template n'est fait la correction.
|
|
|
|
Testons en créant le patch /srv/rougail/patches/example.conf.patch :
|
|
|
|
```
|
|
--- /srv/rougail/templates/example.conf 2021-02-13 19:41:38.677491087 +0100
|
|
+++ tmp/example.conf 2021-02-13 20:12:55.525089820 +0100
|
|
@@ -1,3 +1,5 @@
|
|
The value: %%my_variable
|
|
|
|
The extra value: %%example.my_variable_extra
|
|
+
|
|
+Add by a patch
|
|
```
|
|
|
|
Le patch est bien appliquer sur notre fichier /srv/rougail/destinations/etc/example.conf :
|
|
|
|
```
|
|
The value: my_value
|
|
|
|
The extra value: my_value_extra
|
|
|
|
Add by a patch
|
|
```
|
|
|
|
Deux choses importantes à savoir sur les patchs :
|
|
|
|
- le nom du patch est obligatoire le nom du template source + ".patch"
|
|
- la deuxième ligne doit toujours commencer par "+++ tmp/" + le nom du template source
|
|
|
|
## Créons une fonction personnalisé
|
|
|
|
Nous créons un dictionnaire complémentaire pour ajouter un calcul à la variable "my_variable" dans /srv/rougail/dictionaries/00-fill.xml :
|
|
|
|
```
|
|
<?xml version='1.0' encoding='UTF-8'?>
|
|
<rougail>
|
|
<constraints>
|
|
<fill name="return_no">
|
|
<target>my_variable</target>
|
|
</fill>
|
|
</constraints>
|
|
</rougail>
|
|
```
|
|
|
|
Puis créons la fonction "return_no" dans /srv/rougail/functions.py :
|
|
|
|
```python
|
|
def return_no():
|
|
return 'no'
|
|
```
|
|
|
|
Après avoir reconverti les dictionnaires et regénérer le template nous avons donc le contenu du fichier /srv/rougail/destinations/etc/example.conf :
|
|
|
|
```
|
|
The value: no
|
|
|
|
The extra value: my_value_extra
|
|
|
|
Add by a patch
|
|
```
|
|
|
|
La valeur de la variable "my_variable" est bien calculé à partir de la fonction "return_no".
|