diff --git a/EXERCICE.md b/EXERCICE.md
new file mode 100644
index 0000000..8977baf
--- /dev/null
+++ b/EXERCICE.md
@@ -0,0 +1,402 @@
+# đŻ Exercice : AmĂ©liorer le serveur Nginx avec Ansible
+
+## đ Objectif de l'exercice
+
+Tu vas améliorer ton projet Ansible actuel en ajoutant 3 fonctionnalités importantes :
+1. â
**HTTPS** (sécuriser le site avec un certificat SSL)
+2. â
**Authentification** (protéger l'accÚs avec login/password)
+3. â
**Déployer des pages web** (mettre ton propre site HTML)
+
+---
+
+## đ Partie 1 : Configurer HTTPS avec Let's Encrypt
+
+### đ€ C'est quoi HTTPS ?
+- HTTP = ton site est accessible mais **pas sĂ©curisĂ©** (pas de cadenas đ)
+- HTTPS = ton site est **sĂ©curisĂ©** avec un certificat SSL (cadenas vert đ)
+- Les données sont **chiffrées** entre le navigateur et le serveur
+
+### đ Ce que tu dois faire :
+
+#### Ătape 1.1 : Installer Certbot
+Certbot = outil gratuit pour obtenir un certificat SSL
+
+**Ajoute cette tĂąche dans `playbook.yml`** (aprĂšs l'installation de Nginx) :
+```yaml
+- name: Installer Certbot pour Let's Encrypt
+ apt:
+ name:
+ - certbot
+ - python3-certbot-nginx
+ state: present
+```
+
+**đĄ Explication** :
+- `certbot` = l'outil principal
+- `python3-certbot-nginx` = plugin pour configurer automatiquement Nginx
+
+#### Ătape 1.2 : GĂ©nĂ©rer le certificat SSL
+**Ajoute cette tĂąche** :
+```yaml
+- name: Obtenir un certificat SSL avec Certbot
+ command: certbot --nginx -d defder.fr --non-interactive --agree-tos --email ton-email@exemple.com
+ args:
+ creates: /etc/letsencrypt/live/defder.fr/fullchain.pem
+```
+
+**đĄ Explication** :
+- `--nginx` = configure automatiquement Nginx
+- `-d defder.fr` = ton nom de domaine
+- `--non-interactive` = pas de questions (automatique)
+- `--agree-tos` = accepte les conditions
+- `--email` = **REMPLACE par ton vrai email !**
+- `creates: ...` = ne refait pas si le certificat existe dĂ©jĂ
+
+#### Ătape 1.3 : Renouvellement automatique
+Les certificats expirent tous les 90 jours. Il faut les renouveler automatiquement.
+
+**Ajoute cette tĂąche** :
+```yaml
+- name: Configurer le renouvellement automatique du certificat
+ cron:
+ name: "Renouveler certificat SSL"
+ minute: "0"
+ hour: "3"
+ job: "certbot renew --quiet"
+```
+
+**đĄ Explication** :
+- VĂ©rifie chaque jour Ă 3h du matin si le certificat doit ĂȘtre renouvelĂ©
+- `--quiet` = ne fait pas de bruit dans les logs
+
+#### â
Vérification Partie 1
+Lance ton playbook : `./run.sh`
+
+Ensuite, teste dans ton navigateur : `https://defder.fr`
+- Tu dois voir le **cadenas vert đ**
+- Le site est maintenant sécurisé !
+
+---
+
+## đ Partie 2 : Ajouter une authentification
+
+### đ€ C'est quoi l'authentification ?
+Une popup qui demande **login + password** avant d'accéder au site.
+Utile pour protéger un site privé, un backoffice, etc.
+
+### đ Ce que tu dois faire :
+
+#### Ătape 2.1 : Installer les outils nĂ©cessaires
+**Ajoute cette tĂąche** :
+```yaml
+- name: Installer apache2-utils pour htpasswd
+ apt:
+ name: apache2-utils
+ state: present
+```
+
+**đĄ Explication** :
+- `htpasswd` = outil pour créer des fichiers de mots de passe
+
+#### Ătape 2.2 : CrĂ©er un utilisateur avec mot de passe
+**Ajoute cette tĂąche** :
+```yaml
+- name: Créer un fichier de mots de passe
+ htpasswd:
+ path: /etc/nginx/.htpasswd
+ name: admin
+ password: "MonMotDePasse123"
+ owner: root
+ group: www-data
+ mode: '0640'
+```
+
+**đĄ Explication** :
+- Crée un fichier `/etc/nginx/.htpasswd`
+- Utilisateur : `admin`
+- Mot de passe : `MonMotDePasse123` (**CHANGE-LE !**)
+- `mode: '0640'` = permissions sécurisées
+
+#### Ătape 2.3 : CrĂ©er un fichier de configuration Nginx
+Tu vas créer un fichier de config personnalisé pour Nginx.
+
+**D'abord, crée un dossier `templates/` dans ton projet** :
+```
+iaac/
+âââ templates/
+â âââ nginx-auth.conf.j2
+âââ playbook.yml
+âââ inventory.yml
+...
+```
+
+**Crée le fichier `templates/nginx-auth.conf.j2`** avec ce contenu :
+```nginx
+server {
+ listen 80;
+ server_name defder.fr;
+
+ # Redirection HTTP vers HTTPS
+ return 301 https://$server_name$request_uri;
+}
+
+server {
+ listen 443 ssl;
+ server_name defder.fr;
+
+ # Certificats SSL (générés par Certbot)
+ ssl_certificate /etc/letsencrypt/live/defder.fr/fullchain.pem;
+ ssl_certificate_key /etc/letsencrypt/live/defder.fr/privkey.pem;
+
+ # Dossier racine du site
+ root /var/www/html;
+ index index.html;
+
+ # AUTHENTIFICATION
+ auth_basic "Zone protégée - Connexion requise";
+ auth_basic_user_file /etc/nginx/.htpasswd;
+
+ location / {
+ try_files $uri $uri/ =404;
+ }
+}
+```
+
+**đĄ Explication** :
+- Redirige automatiquement HTTP â HTTPS
+- Active l'authentification avec `auth_basic`
+- Pointe vers le fichier de mots de passe
+
+#### Ătape 2.4 : DĂ©ployer la configuration
+**Ajoute cette tĂąche dans `playbook.yml`** :
+```yaml
+- name: Déployer la configuration Nginx avec authentification
+ template:
+ src: templates/nginx-auth.conf.j2
+ dest: /etc/nginx/sites-available/defder
+ notify: Recharger Nginx
+
+- name: Activer le site
+ file:
+ src: /etc/nginx/sites-available/defder
+ dest: /etc/nginx/sites-enabled/defder
+ state: link
+
+- name: Désactiver le site par défaut
+ file:
+ path: /etc/nginx/sites-enabled/default
+ state: absent
+ notify: Recharger Nginx
+```
+
+#### Ătape 2.5 : Ajouter un handler pour recharger Nginx
+**Ă la fin de `playbook.yml`**, ajoute :
+```yaml
+ handlers:
+ - name: Recharger Nginx
+ systemd:
+ name: nginx
+ state: reloaded
+```
+
+**đĄ Explication** :
+- Un handler = une action qui se déclenche quand un fichier change
+- Recharge Nginx quand la config est modifiée
+
+#### â
Vérification Partie 2
+Lance ton playbook : `./run.sh`
+
+Visite `https://defder.fr` â Une popup apparaĂźt !
+- Login : `admin`
+- Password : `MonMotDePasse123` (ou celui que tu as choisi)
+
+---
+
+## đš Partie 3 : DĂ©ployer des pages web personnalisĂ©es
+
+### đ€ C'est quoi dĂ©ployer des pages ?
+Remplacer la page par défaut de Nginx par **ton propre site HTML**.
+
+### đ Ce que tu dois faire :
+
+#### Ătape 3.1 : CrĂ©er un dossier pour ton site
+**Dans ton projet, crée un dossier `files/`** :
+```
+iaac/
+âââ files/
+â âââ index.html
+â âââ style.css
+âââ templates/
+âââ playbook.yml
+...
+```
+
+#### Ătape 3.2 : CrĂ©er une page HTML
+**Crée `files/index.html`** :
+```html
+
+
+
+
+
+ Mon site déployé avec Ansible
+
+
+
+
+
đ Bienvenue sur mon serveur !
+
Ce site a été déployé automatiquement avec Ansible.
+
+ - â
Serveur : Nginx
+ - â
Sécurité : HTTPS activé
+ - â
Protection : Authentification activée
+ - â
Automatisation : 100% IaaC
+
+
+
+
+
+```
+
+#### Ătape 3.3 : CrĂ©er un fichier CSS
+**Crée `files/style.css`** :
+```css
+* {
+ margin: 0;
+ padding: 0;
+ box-sizing: border-box;
+}
+
+body {
+ font-family: Arial, sans-serif;
+ background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
+ min-height: 100vh;
+ display: flex;
+ justify-content: center;
+ align-items: center;
+}
+
+.container {
+ background: white;
+ padding: 3rem;
+ border-radius: 15px;
+ box-shadow: 0 10px 40px rgba(0,0,0,0.3);
+ max-width: 600px;
+ text-align: center;
+}
+
+h1 {
+ color: #667eea;
+ margin-bottom: 1rem;
+ font-size: 2.5rem;
+}
+
+p {
+ color: #333;
+ margin-bottom: 1rem;
+ font-size: 1.1rem;
+}
+
+ul {
+ list-style: none;
+ margin: 2rem 0;
+}
+
+ul li {
+ background: #f0f0f0;
+ padding: 0.8rem;
+ margin: 0.5rem 0;
+ border-radius: 8px;
+ font-size: 1rem;
+}
+
+.footer {
+ margin-top: 2rem;
+ font-style: italic;
+ color: #667eea;
+}
+```
+
+#### Ătape 3.4 : DĂ©ployer les fichiers sur le serveur
+**Ajoute ces tĂąches dans `playbook.yml`** (avant le handler) :
+```yaml
+- name: Créer le dossier du site web
+ file:
+ path: /var/www/html
+ state: directory
+ owner: www-data
+ group: www-data
+ mode: '0755'
+
+- name: Déployer la page HTML
+ template:
+ src: files/index.html
+ dest: /var/www/html/index.html
+ owner: www-data
+ group: www-data
+ mode: '0644'
+
+- name: Déployer le fichier CSS
+ copy:
+ src: files/style.css
+ dest: /var/www/html/style.css
+ owner: www-data
+ group: www-data
+ mode: '0644'
+```
+
+**đĄ Explication** :
+- `template:` pour index.html = permet d'utiliser des variables Ansible (comme la date)
+- `copy:` pour style.css = copie simple du fichier
+- `owner: www-data` = donne les bons droits Ă Nginx
+
+#### â
Vérification Partie 3
+Lance ton playbook : `./run.sh`
+
+Visite `https://defder.fr` :
+- Entre login/password
+- Tu vois **ton site personnalisĂ©** ! đ
+
+---
+
+## đ RĂ©sumĂ© de ce que tu as appris
+
+| Fonctionnalité | Module Ansible | Utilité |
+|---------------|----------------|---------|
+| **HTTPS** | `command` (certbot) | Sécuriser le site |
+| **Authentification** | `htpasswd` | Protéger l'accÚs |
+| **Configuration Nginx** | `template` | Personnaliser le serveur |
+| **Déploiement de fichiers** | `copy` / `template` | Mettre en ligne ton site |
+| **Handlers** | `handlers` | Recharger Nginx automatiquement |
+
+---
+
+## đ Pour aller plus loin (Bonus)
+
+### Idées d'améliorations :
+1. **Plusieurs utilisateurs** : Ajoute plusieurs logins dans htpasswd
+2. **Variables** : Mets le nom de domaine, email, etc. dans un fichier `vars.yml`
+3. **RĂŽles Ansible** : Organise ton code en rĂŽles (nginx, ssl, web)
+4. **CI/CD** : Automatise le déploiement avec GitHub Actions
+5. **Monitoring** : Ajoute un outil pour surveiller le serveur
+
+---
+
+## đ Ressources utiles
+
+- **Documentation Ansible** : https://docs.ansible.com
+- **Certbot** : https://certbot.eff.org
+- **Nginx** : https://nginx.org/en/docs/
+
+---
+
+## â
Checklist finale
+
+- [ ] HTTPS fonctionne (cadenas vert)
+- [ ] Authentification demande login/password
+- [ ] Page personnalisée affichée
+- [ ] Certificat SSL se renouvelle automatiquement
+- [ ] Code versionné sur Git
+- [ ] Playbook s'exécute sans erreur
+
+**Bravo ! Tu as créé une infrastructure complĂšte et sĂ©curisĂ©e avec Ansible ! đ**
diff --git a/files/index.html b/files/index.html
new file mode 100644
index 0000000..2e070cc
--- /dev/null
+++ b/files/index.html
@@ -0,0 +1,22 @@
+
+
+
+
+
+ Mon site déployé avec Ansible
+
+
+
+
+
đ Bienvenue sur mon serveur !
+
Ce site a été déployé automatiquement avec Ansible.
+
+ - â
Serveur : Nginx
+ - â
Sécurité : HTTPS activé
+ - â
Protection : Authentification activée
+ - â
Automatisation : 100% IaaC
+
+
+
+
+
diff --git a/files/style.css b/files/style.css
new file mode 100644
index 0000000..2cfdcd6
--- /dev/null
+++ b/files/style.css
@@ -0,0 +1,54 @@
+* {
+ margin: 0;
+ padding: 0;
+ box-sizing: border-box;
+}
+
+body {
+ font-family: Arial, sans-serif;
+ background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
+ min-height: 100vh;
+ display: flex;
+ justify-content: center;
+ align-items: center;
+}
+
+.container {
+ background: white;
+ padding: 3rem;
+ border-radius: 15px;
+ box-shadow: 0 10px 40px rgba(0,0,0,0.3);
+ max-width: 600px;
+ text-align: center;
+}
+
+h1 {
+ color: #667eea;
+ margin-bottom: 1rem;
+ font-size: 2.5rem;
+}
+
+p {
+ color: #333;
+ margin-bottom: 1rem;
+ font-size: 1.1rem;
+}
+
+ul {
+ list-style: none;
+ margin: 2rem 0;
+}
+
+ul li {
+ background: #f0f0f0;
+ padding: 0.8rem;
+ margin: 0.5rem 0;
+ border-radius: 8px;
+ font-size: 1rem;
+}
+
+.footer {
+ margin-top: 2rem;
+ font-style: italic;
+ color: #667eea;
+}
diff --git a/playbook.yml b/playbook.yml
index 5c3d64e..ed9b785 100644
--- a/playbook.yml
+++ b/playbook.yml
@@ -14,6 +14,46 @@
name: nginx
state: present
+ - name: Installer apache2-utils pour htpasswd
+ apt:
+ name: apache2-utils
+ state: present
+
+ - name: Installer la librairie Python passlib
+ apt:
+ name: python3-passlib
+ state: present
+
+ - name: Créer un fichier de mots de passe
+ htpasswd:
+ path: /etc/nginx/.htpasswd
+ name: admin
+ password: "mdp123"
+ owner: root
+ group: www-data
+ mode: '0640'
+
+ - name: Installer Certbot pour Let's Encrypt
+ apt:
+ name:
+ - certbot
+ - python3-certbot-nginx
+ state: present
+
+ - name: Obtenir un certificat SSL avec Certbot
+ command: certbot --nginx -d defder.fr --non-interactive --agree-tos --email bottero.romain1811@gmail.com --redirect
+ notify: Restart Nginx
+ args:
+ creates: /etc/letsencrypt/live/defder.fr/fullchain.pem
+
+ - name: Configurer le renouvellement automatique du certificat
+ cron:
+ name: "Renouveler le certificat SSL"
+ minute: "0"
+ hour: "3"
+ job: "certbot renew --quiet"
+
+
- name: S'assurer qu'UFW est installé
apt:
name: ufw
@@ -47,6 +87,25 @@
state: started
enabled: yes
+ - name: Déployer la configuration Nginx avec authentification
+ template:
+ src: templates/nginx-auth.conf.j2
+ dest: /etc/nginx/sites-available/defder
+ notify: Recharger Nginx
+
+ - name: Activer le site
+ file:
+ src: /etc/nginx/sites-available/defder
+ dest: /etc/nginx/sites-enabled/defder
+ state: link
+ notify: Recharger Nginx
+
+ - name: Désactiver le site par défaut
+ file:
+ path: /etc/nginx/sites-enabled/default
+ state: absent
+ notify: Recharger Nginx
+
- name: Vérifier que Nginx est en cours d'exécution
service:
name: nginx
@@ -57,11 +116,47 @@
debug:
msg: "Nginx est installé et en cours d'exécution"
+
- name: Récupérer l'IP du serveur
command: hostname -I
register: server_ip
changed_when: false
+ - name: Créer le dossier du site web
+ file:
+ path: /var/www/html
+ state: directory
+ owner: www-data
+ group: www-data
+ mode: '0755'
+
+ - name: Déployer la page HTML
+ template:
+ src: files/index.html
+ dest: /var/www/html/index.html
+ owner: www-data
+ group: www-data
+ mode: '0644'
+
+ - name: Déployer le fichier CSS
+ copy:
+ src: files/style.css
+ dest: /var/www/html/style.css
+ owner: www-data
+ group: www-data
+ mode: '0644'
+
- name: Afficher l'URL d'accĂšs
debug:
- msg: "Nginx est accessible Ă l'adresse : http://{{ server_ip.stdout.split()[0] }}"
+ msg: "Nginx est accessible Ă l'adresse : https://defder.fr (ou http://{{ server_ip.stdout.split()[0] }} qui redirige vers HTTPS)"
+
+ handlers:
+ - name: Restart Nginx
+ service:
+ name: nginx
+ state: restarted
+
+ - name: Recharger Nginx
+ systemd:
+ name: nginx
+ state: reloaded
\ No newline at end of file
diff --git a/templates/nginx-auth.conf.j2 b/templates/nginx-auth.conf.j2
new file mode 100644
index 0000000..a56875f
--- /dev/null
+++ b/templates/nginx-auth.conf.j2
@@ -0,0 +1,28 @@
+server {
+ listen 80;
+ server_name defder.fr;
+
+ # Redirection HTTP vers HTTPS
+ return 301 https://$server_name$request_uri;
+}
+
+server {
+ listen 443 ssl;
+ server_name defder.fr;
+
+ # Certificats SSL (générés par Certbot)
+ ssl_certificate /etc/letsencrypt/live/defder.fr/fullchain.pem;
+ ssl_certificate_key /etc/letsencrypt/live/defder.fr/privkey.pem;
+
+ # Dossier racine du site
+ root /var/www/html;
+ index index.html;
+
+ # AUTHENTIFICATION
+ auth_basic "Zone protégée - Connexion requise";
+ auth_basic_user_file /etc/nginx/.htpasswd;
+
+ location / {
+ try_files $uri $uri/ =404;
+ }
+}
\ No newline at end of file