ajout tp3 mail
This commit is contained in:
parent
435ef90b92
commit
a966c17bce
@ -6,3 +6,4 @@ UE4 :
|
||||
* [Durcissement Linux ANSSI (6h)](https://www.ssi.gouv.fr/guide/recommandations-de-securite-relatives-a-un-systeme-gnulinux/)
|
||||
* [TP Intrusion (6h)](tp1-intrusion.md)
|
||||
* [TP IDPS (6h)](tp2-idps.md)
|
||||
* [TP Messagerie](tp3-mail.md)
|
||||
|
139
tp3-files/global.json
Normal file
139
tp3-files/global.json
Normal file
@ -0,0 +1,139 @@
|
||||
{
|
||||
"prefix-containers":"mi-",
|
||||
"prefix-bridges":"mi-",
|
||||
"nat-bridge":"lxcbr0",
|
||||
"comment":"An interconnected network of different AS with internet services",
|
||||
"masters": [
|
||||
{
|
||||
"backend":"lxc",
|
||||
"template":"download",
|
||||
"parameters":{"dist": "debian", "release": "bullseye", "arch": "amd64", "no-validate": "true"},
|
||||
"family":"debian",
|
||||
"name":"bullseye"
|
||||
},
|
||||
{
|
||||
"backend":"lxc",
|
||||
"template":"download",
|
||||
"parameters":{"dist": "debian", "release": "buster", "arch": "amd64", "no-validate": "true"},
|
||||
"family":"debian",
|
||||
"name":"buster",
|
||||
"status":"disabled"
|
||||
},
|
||||
{
|
||||
"backend":"lxc",
|
||||
"template":"download",
|
||||
"parameters":{"dist": "debian", "release": "stretch", "arch": "amd64", "no-validate": "true"},
|
||||
"name":"stretch",
|
||||
"family":"debian",
|
||||
"status":"disabled"
|
||||
},
|
||||
{
|
||||
"backend":"lxc",
|
||||
"template":"download",
|
||||
"parameters":{"dist": "alpine", "release": "3.14", "arch": "amd64", "no-validate": "true"},
|
||||
"name":"alpine",
|
||||
"family":"alpine",
|
||||
"status":"enabled"
|
||||
},
|
||||
{
|
||||
"backend":"dynamips",
|
||||
"rom":"templates/groups/as-bgp-dynamips/bgprouter/bins/c3640-js-m.124-3g.bin",
|
||||
"name":"cisco-3640",
|
||||
"family":"c3640",
|
||||
"status":"disabled"
|
||||
}],
|
||||
"groups": {
|
||||
"transit-a": {
|
||||
"templates":[{"template":"as-bgp", "asn":"30", "neighbors4":"100.64.0.10 as 10;100.64.0.30 as 7;100.64.0.40 as 8; 100.64.0.2 as 31; 100.64.0.20 as 6; 100.64.0.50 as 13; 100.64.0.90 as 56",
|
||||
"neighbors6":"2001:db8:b000::10 as 10; 2001:db8:b000::30 as 7;2001:db8:b000::40 as 8; 2001:db8:b000::2 as 31; 2001:db8:b000::20 as 6; 2001:db8:b000::50 as 13; 2001:db8:b000::90 as 56",
|
||||
"interfaces":[
|
||||
{"bridge":"nat-bridge", "ipv4":"dhcp"},
|
||||
{"bridge":"transit-a", "ipv4":"100.64.0.1/24", "ipv6":"2001:db8:b000::1/48"}
|
||||
]
|
||||
}]},
|
||||
"transit-b": {
|
||||
"templates":[{"template":"as-bgp", "asn":"31", "neighbors4":"100.64.0.1 as 30;100.64.1.20 as 5;100.64.1.10 as 20;100.64.1.30 as 7;100.64.1.40 as 12;100.64.1.50 as 11",
|
||||
"neighbors6":"2001:db8:b000::1 as 30;2001:db8:b001::20 as 5;2001:db8:b001::10 as 20;2001:db8:b001::30 as 7;2001:db8:b001::40 as 12;2001:db8:b001::50 as 11",
|
||||
"interfaces":[
|
||||
{"bridge":"transit-b", "ipv4":"100.64.1.1/24", "ipv6":"2001:db8:b001::1/48"},
|
||||
{"bridge":"transit-a", "ipv4":"100.64.0.2/24", "ipv6":"2001:db8:b000::2/48"}
|
||||
]
|
||||
}]},
|
||||
"target": {
|
||||
"templates":[{"template":"as-bgp-debian", "asn":"10", "asdev":"eth1", "neighbors4":"100.64.0.1 as 30", "neighbors6":"2001:db8:b000::1 as 30",
|
||||
"interfaces":[
|
||||
{"bridge":"transit-a", "ipv4":"100.64.0.10/24", "ipv6":"2001:db8:b000::10/48"},
|
||||
{"bridge":"target-lan", "ipv4":"100.80.0.1/16", "ipv6":"2001:db8:80::0:1/48"}
|
||||
]
|
||||
}]},
|
||||
"mica": {
|
||||
"templates":[{"template":"as-bgp", "asn":"12", "asdev":"eth1", "neighbors4":"100.64.1.1 as 31", "neighbors6":"2001:db8:b001::1 as 31",
|
||||
"interfaces":[
|
||||
{"bridge":"transit-b", "ipv4":"100.64.1.40/24", "ipv6":"2001:db8:b001::40/48"},
|
||||
{"bridge":"mica-lan", "ipv4":"100.82.0.1/16", "ipv6":"2001:db8:82::1/48"}
|
||||
]
|
||||
}]},
|
||||
"ecorp": {
|
||||
"templates":[{"template":"as-bgp", "asn":"11", "asdev":"eth1", "neighbors4":"100.64.1.1 as 31","neighbors6":"2001:db8:b001::1 as 31",
|
||||
"interfaces":[
|
||||
{"bridge":"transit-b", "ipv4":"100.64.1.50/24", "ipv6":"2001:db8:b001::50/48"},
|
||||
{"bridge":"ecorp-lan", "ipv4":"100.81.0.1/16", "ipv6":"2001:db8:81::1/48"}
|
||||
]
|
||||
}]},
|
||||
"gozilla": {
|
||||
"templates":[{"template":"as-bgp", "asn":"13", "asdev":"eth1", "neighbors4":"100.64.0.1 as 30","neighbors6":"2001:db8:b000::1 as 30",
|
||||
"interfaces":[
|
||||
{"bridge":"transit-a", "ipv4":"100.64.0.50/24", "ipv6":"2001:db8:b000::50/48"},
|
||||
{"bridge":"gozilla-lan", "ipv4":"100.83.0.1/16", "ipv6":"2001:db8:83::1/48"}
|
||||
]
|
||||
}]},
|
||||
"isp-a": {
|
||||
"templates":[{"template":"as-bgp", "asn":"20", "asdev":"eth1;eth2", "neighbors4":"100.64.1.1 as 31","neighbors6":"2001:db8:b001::1 as 31",
|
||||
"interfaces":[
|
||||
{"bridge":"transit-b", "ipv4":"100.64.1.10/24", "ipv6":"2001:db8:b001::10/48"},
|
||||
{"bridge":"isp-a-cust", "ipv4":"100.120.0.1/24"},
|
||||
{"bridge":"isp-a-infra", "ipv4":"100.120.1.1/24", "ipv6":"2001:db8:120:1::1/64"}
|
||||
]
|
||||
}]},
|
||||
"root-o": {
|
||||
"templates":[{"template":"as-bgp", "asn":"5", "asdev":"eth1", "neighbors4":"100.64.1.1 as 31", "neighbors6":"2001:db8:b001::1 as 31",
|
||||
"interfaces":[
|
||||
{"bridge":"transit-b", "ipv4":"100.64.1.20/24", "ipv6":"2001:db8:b001::20/48"},
|
||||
{"bridge":"root-o-lan", "ipv4":"100.100.0.1/24", "ipv6":"2001:db8:a000::1/48"}
|
||||
]
|
||||
},
|
||||
{"template":"dns-root", "ipv4":"100.100.0.10/24", "gatewayv4":"100.100.0.1", "ipv6":"2001:db8:a000::10/48", "gatewayv6":"2001:db8:a000::1", "domain":"ns-root-o.milxc"}
|
||||
]},
|
||||
"root-p": {
|
||||
"templates":[{"template":"as-bgp", "asn":"6", "asdev":"eth1", "neighbors4":"100.64.0.1 as 30", "neighbors6":"2001:db8:b000::1 as 30",
|
||||
"interfaces":[
|
||||
{"bridge":"transit-a", "ipv4":"100.64.0.20/24", "ipv6":"2001:db8:b000::20/48"},
|
||||
{"bridge":"root-p-lan", "ipv4":"100.100.1.1/24", "ipv6":"2001:db8:a001::1/48"}
|
||||
]
|
||||
},
|
||||
{"template":"dns-root", "ipv4":"100.100.1.10/24", "gatewayv4":"100.100.1.1", "ipv6":"2001:db8:a001::10/48", "gatewayv6":"2001:db8:a001::1", "domain":"ns-root-p.milxc"}
|
||||
]},
|
||||
"opendns": {
|
||||
"templates":[{"template":"as-bgp", "asn":"7", "asdev":"eth2", "neighbors4":"100.64.0.1 as 30;100.64.1.1 as 31","neighbors6":"2001:db8:b000::1 as 30;2001:db8:b001::1 as 31",
|
||||
"interfaces":[
|
||||
{"bridge":"transit-a", "ipv4":"100.64.0.30/24", "ipv6":"2001:db8:b000::30/48"},
|
||||
{"bridge":"transit-b", "ipv4":"100.64.1.30/24", "ipv6":"2001:db8:b001::30/48"},
|
||||
{"bridge":"opendns-lan", "ipv4":"100.100.100.1/24", "ipv6":"2001:db8:a100::1/48"}
|
||||
]
|
||||
}]},
|
||||
"milxc": {
|
||||
"templates":[{"template":"as-bgp", "asn":"8", "asdev":"eth1", "neighbors4":"100.64.0.1 as 30","neighbors6":"2001:db8:b000::1 as 30",
|
||||
"interfaces":[
|
||||
{"bridge":"transit-a", "ipv4":"100.64.0.40/24", "ipv6":"2001:db8:b000::40/48"},
|
||||
{"bridge":"milxc-lan", "ipv4":"100.100.20.1/24", "ipv6":"2001:db8:a020::1/48"}
|
||||
]
|
||||
}]},
|
||||
"iutva": {
|
||||
"templates":[{"template":"as-bgp", "asn":"56", "asdev":"eth1", "neighbors4":"100.64.0.1 as 30","neighbors6":"2001:db8:b000::1 as 30",
|
||||
"interfaces":[
|
||||
{"bridge":"transit-a", "ipv4":"100.64.0.90/24", "ipv6":"2001:db8:b000::90/48"},
|
||||
{"bridge":"iutva-lan", "ipv4":"100.90.0.1/16", "ipv6":"2001:db8:90::1/48"}
|
||||
]
|
||||
}]}
|
||||
}
|
||||
}
|
13
tp3-files/iutva.milxc.zone
Normal file
13
tp3-files/iutva.milxc.zone
Normal file
@ -0,0 +1,13 @@
|
||||
$TTL 86400
|
||||
$ORIGIN iutva.milxc.
|
||||
@ 1D IN SOA ns.iutva.milxc. hostmaster.iutva.milxc. (
|
||||
2002022401 ; serial
|
||||
3H ; refresh
|
||||
15 ; retry
|
||||
1w ; expire
|
||||
3h ; nxdomain ttl
|
||||
)
|
||||
IN NS ns.iutva.milxc.
|
||||
ns IN A 100.90.0.2
|
||||
infra IN A 100.90.0.2
|
||||
www IN CNAME infra
|
38
tp3-files/local.json
Normal file
38
tp3-files/local.json
Normal file
@ -0,0 +1,38 @@
|
||||
{
|
||||
"comment": "IUTVA AS",
|
||||
"containers": {
|
||||
"infra": {
|
||||
"container": "infra",
|
||||
"interfaces": [
|
||||
{"bridge": "lan", "ipv4": "100.90.0.2/16", "ipv6": "2001:db8:90::2/48"}
|
||||
],
|
||||
"gatewayv4": "100.90.0.1",
|
||||
"gatewayv6": "2001:db8:90::1",
|
||||
"templates": [
|
||||
{"template": "nodhcp", "domain": "iutva.milxc", "ns": "100.100.100.100"}
|
||||
]
|
||||
},
|
||||
"mail": {
|
||||
"container": "mail",
|
||||
"interfaces": [
|
||||
{"bridge": "lan", "ipv4": "100.90.0.3/16", "ipv6": "2001:db8:90::3/48"}
|
||||
],
|
||||
"gatewayv4": "100.90.0.1",
|
||||
"gatewayv6": "2001:db8:90::1",
|
||||
"templates": [
|
||||
{"template": "nodhcp", "domain": "iutva.milxc", "ns": "100.100.100.100"}
|
||||
]
|
||||
},
|
||||
"poste": {
|
||||
"container": "poste",
|
||||
"interfaces": [
|
||||
{"bridge": "lan", "ipv4": "100.90.0.4/16", "ipv6": "2001:db8:90::4/48"}
|
||||
],
|
||||
"gatewayv4": "100.90.0.1",
|
||||
"gatewayv6": "2001:db8:90::1",
|
||||
"templates": [
|
||||
{"template": "nodhcp", "domain": "iutva.milxc", "ns": "100.100.100.100"}
|
||||
]
|
||||
}
|
||||
}
|
||||
}
|
29
tp3-files/milxc.zone
Normal file
29
tp3-files/milxc.zone
Normal file
@ -0,0 +1,29 @@
|
||||
$TTL 86400
|
||||
$ORIGIN milxc.
|
||||
@ 1D IN SOA ns.milxc. hostmaster.milxc. (
|
||||
2002022401 ; serial
|
||||
3H ; refresh
|
||||
15 ; retry
|
||||
1w ; expire
|
||||
3h ; nxdomain ttl
|
||||
)
|
||||
IN NS ns.milxc.
|
||||
ns IN A 100.100.20.10 ;name server definition
|
||||
ns IN AAAA 2001:db8:a020::10
|
||||
target.milxc. IN NS ns.target.milxc.
|
||||
ns.target.milxc. IN A 100.80.1.2
|
||||
ns.target.milxc. IN AAAA 2001:db8:80::1:2
|
||||
isp-a.milxc. IN NS ns.isp-a.milxc.
|
||||
ns.isp-a.milxc. IN A 100.120.1.2
|
||||
ns.isp-a.milxc. IN AAAA 2001:db8:120:1::2
|
||||
mica.milxc. IN NS ns.mica.milxc.
|
||||
ns.mica.milxc. IN A 100.82.0.2
|
||||
ns.mica.milxc. IN AAAA 2001:db8:82::2
|
||||
ecorp.milxc. IN NS ns.ecorp.milxc.
|
||||
ns.ecorp.milxc. IN A 100.81.0.2
|
||||
ns.ecorp.milxc. IN AAAA 2001:db8:81::2
|
||||
gozilla.milxc. IN NS ns.gozilla.milxc.
|
||||
ns.gozilla.milxc. IN A 100.83.0.2
|
||||
ns.gozilla.milxc. IN AAAA 2001:db8:83::2
|
||||
iutva.milxc. IN NS ns.iutva.milxc.
|
||||
ns.iutva.milxc. IN A 100.90.0.2
|
3
tp3-files/server.conf
Normal file
3
tp3-files/server.conf
Normal file
@ -0,0 +1,3 @@
|
||||
zone:
|
||||
name: "iutva.milxc."
|
||||
zonefile: "/etc/nsd/iutva.milxc.zone"
|
225
tp3-mail.md
Normal file
225
tp3-mail.md
Normal file
@ -0,0 +1,225 @@
|
||||
# TP 3 : Sécurité du mail
|
||||
|
||||
|
||||
_François Lesueur ([francois.lesueur@univ-ubs.fr](mailto:francois.lesueur@univ-ubs.fr))_
|
||||
|
||||
Ce TP couvre la sécurité du mail. Il s'agit dans un premier temps de déployer une infrastructure de mail afin de pouvoir ensuite creuser les aspects de sécurité. Le déploiement est très guidé, les aspects de sécurité ensuite vous demanderont plus de recherche personnelle et de mise au point. Soyez méthodiques dans votre travail car vous allez manipuler de nombreuses perspectives différentes !
|
||||
|
||||
Ce TP sera réalisé dans la VM MI-LXC disponible [ici](https://filesender.renater.fr/?s=download&token=2f121a18-f94d-45d1-a079-f68229ebdfa9) (identique à la première période). Avant de lancer la VM, il peut être nécessaire de diminuer la RAM allouée. Par défaut, la VM a 3GO : si vous avez 4GO sur votre machine physique, il vaut mieux diminuer à 2GO, voire 1.5GO pour la VM (la VM devrait fonctionner de manière correcte toujours).
|
||||
|
||||
> Si vous êtes sous Windows et que la VM ne fonctionne pas avec VirtualBox, vous pouvez utiliser à la place VMWare Player. Dans ce cas, il faudra cliquer sur "Retry" lors de l'import puis installer le paquet open-vm-tools-desktop dans la VM pour profiter du redimensionnement automatique du bureau (`apt install open-vm-tools-desktop` dans un shell).
|
||||
|
||||
|
||||
Cheat sheet
|
||||
===========
|
||||
|
||||
Voici un petit résumé des commandes dont vous aurez besoin :
|
||||
|
||||
| Commande | Description | Utilisation |
|
||||
| -------- | ----------- | ----------- |
|
||||
| print | Génère la cartographie du réseau | ./mi-lxc.py print |
|
||||
| attach | Permet d'avoir un shell sur une machine | ./mi-lxc.py attach iutva-infra |
|
||||
| display | Lance un affichage sur la machine cible | ./mi-lxc.py display isp-a-home |
|
||||
| start | Démarre la plateforme pédagogique | ./mi-lxc.py start |
|
||||
| stop | Éteint la plateforme pédagogique | ./mi-lxc.py stop |
|
||||
|
||||
Rappel: Vous devez être dans le répertoire `/root/mi-lxc/` pour exécuter ces commandes.
|
||||
|
||||
|
||||
Observation d'un mail
|
||||
=====================
|
||||
|
||||
En dehors de MI-LXC, ouvrez un mail quelconque sur une de vos boîtes mails personnelles. Affichez le code source de ce mail (souvent accessible par clic droit puis "Montrer l'original" (zimbra) ou "Afficher le source", ou Ctrl+u) et analysez le résultat. Vous y trouverez une partie d'en-têtes (au format `Mot-clé: Valeur`, en début de source) puis une partie contenu.
|
||||
|
||||
> Question 1 : Sur ce mail :
|
||||
>
|
||||
> 1. Dissociez la partie en-têtes de la partie contenu
|
||||
> 2. Décrivez les en-têtes qui vous paraissent clairs et transparents.
|
||||
> 3. Les en-têtes `Received:`, ajoutés par chaque serveur intermédiaire, permettent de retracer le chemin du mail. Dans quel sens ce chemin est-il décrit ?
|
||||
> 4. Décrivez le chemin de votre mail en analysant les adresses IP : où a lieu chaque étape ? Vous pouvez utiliser `dig -x 1.2.3.4` pour obtenir le DNS inversé de l'IP 1.2.3.4, ou des sites comme [https://ipinfo.io/](https://ipinfo.io/), [https://www.onyphe.io/](https://www.onyphe.io/) ou [https://www.ipinfodb.com/](https://www.ipinfodb.com/) pour obtenir des informations supplémentaires sur les adresses IP. Lorsque les adresses IP sont de type local, locales à quelle organisation ?
|
||||
|
||||
|
||||
Mise en place de l'infrastructure
|
||||
=================================
|
||||
|
||||
Vous allez créer un nouvel AS "iutva" dans MI-LXC. Il aura le numéro d'AS 56, 100.90.0.0/16, 2001:db8:90::/48, et le domaine iutva.milxc. Il faut d'abord créer les machines et les connecter dans la topologie :
|
||||
* Copier global.json dans /root/mi-lxc/global.json
|
||||
* Copier local.json vers /root/mi-lxc/groups/iutva/local.json (créer le répertoire groups/iutva/)
|
||||
* Exécuter :
|
||||
* `./mi-lxc.py destroy transit-a-router`
|
||||
* `./mi-lxc.py create`
|
||||
|
||||
Il faut ensuite paramétrer la partie DNS :
|
||||
* Sur la machine 'milxc-ns' (responsable de la zone .milxc), référencer l'existence de la zone iutva.milxc :
|
||||
* Copier milxc.zone en remplacement du fichier /etc/nsd/milxc.zone (les changements sont sur les 2 dernières lignes)
|
||||
* Exécuter 'systemctl restart nsd'
|
||||
* Exécuter 'journalctl -xe' pour vérifier qu'il n'y a pas d'erreur signalée
|
||||
* Sur la machine 'iutva-infra' (responsable de la zone iutva.milxc), configurer la zone iutva.milxc :
|
||||
* Exécuter 'apt install nsd'
|
||||
* Copier iutva.milxc.zone dans le fichier /etc/nsd/iutva.milxc.zone (nouveau fichier)
|
||||
* Copier server.conf dans le fichier /etc/nsd/nsd.conf.d/server.conf (nouveau fichier)
|
||||
* Exécuter 'systemctl restart nsd'
|
||||
* Exécuter 'journalctl -xe' pour vérifier qu'il n'y a pas d'erreur signalée
|
||||
* Sur la machine 'isp-a-home', valider le fonctionnement général :
|
||||
* Exécuter 'dig www.iutva.milxc'
|
||||
* Valider que la réponse reçue déclare que :
|
||||
* www.iutva.milxc est un CNAME vers infra.iutva.milxc
|
||||
* infra.iutva.milxc est un A vers 100.90.0.2
|
||||
|
||||
|
||||
Dans votre organisation "iutva", vous avez 4 machines :
|
||||
* router (100.90.0.1), juste pour le routage en sortie, rien de particulier à paramétrer
|
||||
* infra (100.90.0.2), qui héberge le serveur DNS pour la zone "iutva.milxc"
|
||||
* mail (100.90.0.3), qui hébergera les serveurs de mail (SMTP, IMAP) pour votre domaine, les adresses "@iutva.milxc"
|
||||
* poste (100.90.0.4), un poste de travail, sur lequel nous installerons un logiciel graphique pour écrire et lire des mails avec l'adresse `debian@iutva.milxc`
|
||||
|
||||
|
||||
Afin d'échanger des mails, vous aurez besoin d'un interlocuteur. Vous pourrez pour cela utiliser la machine target-commercial qui a un compte mail "commercial@target.milxc" configuré pour l'utilisateur local commercial. L'infrastructure DNS et mail de "target.milxc" est opérée sur la machine target-dmz.
|
||||
|
||||
Petit résumé :
|
||||
|
||||
| Machine | Description | Connexion |
|
||||
| ------- | ----------- | --------- |
|
||||
| iutva-mail | Serveur SMTP/IMAP pour les adresses "@iutva.milxc" | `./mi-lxc.py attach iutva-mail` |
|
||||
| iutva-poste | Bureau graphique pour écrire/lire des mails avec l'adresse "debian@iutva.milxc" | `./mi-lxc.py display iutva-poste` |
|
||||
| iutva-infra | Serveur DNS pour le domaine "iutva.milxc" | `./mi-lxc.py attach iutva-infra` |
|
||||
| target-commercial | Bureau graphique pour écrire/lire des mails avec l'adresse "commercial@target.milxc" | `./mi-lxc.py display commercial@target-commercial` |
|
||||
|
||||
**Attention ! La connexion à target-commercial se fait avec commercial@target-commercial (et non target-commercial tout court) afin de se connecter avec l'utilisateur local commercial, qui est celui pour lequel le mail est pré-configuré.**
|
||||
|
||||
> Question 2 : Faîtes un schéma global (capture de `./mi-lxc.py print` ou juste les machines impliquées) inventoriant les 5 machines iutva-poste, iutva-mail, iutva-infra, target-dmz, target-commercial, leurs adresses IPv4, leurs noms DNS (déjà existants ou à configurer par la suite) et leur rôle dans le système de mail. Pour la partie Target, vous pouvez aller consulter la zone sur la machine target-dmz.
|
||||
|
||||
SMTP
|
||||
----
|
||||
|
||||
### Installation
|
||||
|
||||
Nous allons installer un serveur SMTP (Postfix) sur la machine iutva-mail. Il aura pour rôle d'envoyer les mails issus de l'organisation iutva et de recevoir les mails à destination de "@iutva.milxc".
|
||||
|
||||
Il faut d'abord l'installer avec `apt install postfix`. Lors de la configuration du paquet, choisissez la configuration "Internet Site" (vous allez recevoir et envoyer des mails) et spécifiez "iutva.milxc" comme "System mail name".
|
||||
|
||||
### Envoi d'un mail avec netcat
|
||||
|
||||
Depuis un shell sur la machine iutva-mail, nous allons envoyer un mail à l'adresse "commercial@target.milxc". SMTP est un protocole en mode texte, nous allons utiliser netcat. Pour vous connecter au serveur SMTP avec netcat : `netcat localhost 25`
|
||||
|
||||
Ensuite, vous aurez à taper les textes suivants (sans les guillemets, entrée après chaque commande) :
|
||||
|
||||
* "HELO" : message de présentation, par exemple "HELO iutva.milxc"
|
||||
* "MAIL FROM: " : spécifie l'adresse d'expédition, par exemple "MAIL FROM: debian@iutva.milxc"
|
||||
* "RCPT TO: " : spécifie l'adresse du destinataire, par exemple "RCPT TO: commercial@target.milxc"
|
||||
* "DATA" : annonce le contenu du message ensuite
|
||||
* Après avoir entré la commande DATA (+ entrée), tapez votre texte. C'est au début de ce texte qu'iraient les champs (non strictement nécessaires ici) From, To, Subject tels que vus dans les en-têtes à la question 1, puis le contenu du mail
|
||||
* En fin de mail, un "." seul sur une ligne, puis encore entrée pour valider la fin du message
|
||||
* "QUIT" pour se déconnecter ensuite
|
||||
|
||||
> Question 3 : Faîtes une copie de votre session netcat.
|
||||
|
||||
Sur le claws-mail de `./mi-lxc.py display commercial@target-commercial`, validez que vous avez bien reçu ce mail. Essayez en changeant l'adresse d'expéditeur, ou en écrivant à une adresse réelle hors de MI-LXC.
|
||||
|
||||
**Attention ! Ne prenez pas une identité réelle comme expéditeur. Il s'agirait d'une usurpation d'identité qui est une infraction pénale.**
|
||||
|
||||
Sur la machine iutva-mail, affichez les logs de Postfix qui sont dans le fichier "/var/log/mail.log", retrouvez la trace du mail que vous venez d'émettre.
|
||||
|
||||
> Question 4 : Faîtes une copie de cette partie de log.
|
||||
|
||||
### Réception d'un mail par iutva-mail
|
||||
|
||||
Depuis le display de target-commercial, envoyez un mail à "debian@iutva.milxc". Vous constaterez a priori une erreur (un mail d'erreur qui arrive dans la boîte de réception de target-commercial); si vous ne recevez pas d'erreur explicite (dépendant d'éléments de configuration de votre côté), le mail est en fait toujours en tampon sur le serveur SMTP du côté de l'organisation Target, et donc non livré. En effet, le serveur SMTP côté Target ne sait pas trouver le serveur SMTP pour @iutva.milxc.
|
||||
|
||||
Ajoutez maintenant le champ MX adapté dans la zone DNS de iutva. Ce champ MX doit être situé avant les champs CNAME/A déjà existants dans la zone et doit mentionner un nom (pas une IP) qui sera défini par un champ A ou CNAME ensuite. Reprenez l'exemple du cours DNS [ici](https://git.kaz.bzh/francois.lesueur/M3102/src/branch/master/cm3-dns.md#exemple-de-zone-dns), mettez à jour votre zone sur iutva-infra puis redémarrez le serveur NSD.
|
||||
|
||||
> Question 5 : Faîtes une copie de votre zone DNS.
|
||||
|
||||
> Si le champ MX n'est pas placé au début de la zone, avant les enregistrements de type CNAME/A, il faut commencer sa ligne en ajoutant un @ pour "retourner en haut de zone".
|
||||
|
||||
Renvoyez un mail depuis target-commercial et vérifiez qu'il n'y a plus d'erreur retournée. S'il y a une erreur, depuis cette même machine, vérifiez que vous avez bien enregistré le champ MX avec `dig iutva.milxc MX`
|
||||
|
||||
Enfin, retrouvez la trace de ce mail dans les logs sur iutva-mail. Une fois arrivé, vous pouvez voir ce mail sur iutva-mail dans le fichier `/var/spool/mail/debian`. Il est reçu, stocké et prêt à être récupéré par le destinataire !
|
||||
|
||||
> Question 6 : Faîtes une copie de cette partie de log.
|
||||
|
||||
> Une documentation assez complète pour un déploiement complet et sain est proposée sur le [Wiki Debian](https://wiki.debian.org/Postfix).
|
||||
|
||||
IMAP
|
||||
----
|
||||
|
||||
Toujours sur iutva-mail, installez dovecot-imapd : `apt install dovecot-imapd`
|
||||
|
||||
IMAP est aussi un protocole en mode texte : `netcat localhost 143`. Ensuite, vous aurez à taper :
|
||||
|
||||
* a LOGIN debian debian
|
||||
* a SELECT INBOX
|
||||
* a FETCH 1 full
|
||||
* a LOGOUT
|
||||
|
||||
Vous verrez normalement ainsi le contenu du mail précédemment envoyé.
|
||||
|
||||
> Question 7 : Faîtes une copie de votre session netcat.
|
||||
|
||||
|
||||
Client
|
||||
------
|
||||
|
||||
Nous allons maintenant installer et configurer un client mail sur la machine iutva-poste. En graphique : `./mi-lxc.py display iutva-poste`
|
||||
|
||||
Installons claws-mail : `apt install claws-mail`. Lors du premier lancement, vous aurez à configurer le compte : le compte est debian, mot de passe debian, sur le serveur mail précédemment entré dans le DNS. Vous aurez à accepter des certificats auto-signés (c'est mal, cf cours crypto et rappels ensuite, on le fait ici car nous n'avons pas déployé la CA dans MI-LXC mais c'est évidemment à proscrire dans un vrai déploiement).
|
||||
|
||||
> La configuration des clients mail peut être plus ou moins automatisée. Par exemple, Thunderbird essaie automatiquement les serveurs dont l'entrée DNS vaut "mail.<le domaine de l'adresse>", "smtp.<le domaine de l'adresse>", etc. Des champs DNS de type SRV permettent également d'annoncer les serveurs :
|
||||
>
|
||||
> * _imap._tcp SRV 0 1 143 mail
|
||||
> * _submission._tcp SRV 0 1 587 mail
|
||||
|
||||
La consultation des mails doit fonctionner. Lors de l'envoi d'un mail vers commercial@target.milxc, votre serveur SMTP va par contre refuser votre demande : dans sa configuration par défaut, il n'accepte pas de relayer les mails qui ne sont pas pour son domaine (éviter d'être un relais ouvert). Il faudrait configurer une authentification sur le serveur SMTP (afin qu'il puisse authentifier ses utilisateurs légitimes à expédier du courrier par son biais), comme décrit par exemple [ici](https://doc.dovecot.org/configuration_manual/howto/postfix_and_dovecot_sasl/). Dans ce TD, on se contentera d'accepter le relai pour le réseau local : sur iutva-mail, éditez le fichier `/etc/postfix/main.cf` et modifiez le paramètre `mynetworks` pour lui faire accepter "100.90.0.0/16", ie, votre réseau interne, puis redémarrez Postfix.
|
||||
|
||||
> Question 8 : Faîtes une capture d'écran de la boîte de réception de claws-mail.
|
||||
|
||||
Un peu de Wireshark
|
||||
===================
|
||||
|
||||
Certaines communications passent en clair ici. Pour un vrai déploiement, il faudrait évidemment chiffrer toutes les communications avec des certificats valides, mais nous pouvons du coup observer le protocole.
|
||||
|
||||
> Question 9 : Proposez où lancer des wireshark pour observer, lors d'un mail envoyé depuis target-commercial vers l'adresse debian@iutva.milxc qui sera relevée sur iutva-poste : l'envoi depuis claws-mail, l'échange entre les SMTP, la relève par claws-mail. Décrivez les points de capture, intégrez des screenshots de vos captures, précisez les communications claires ou chiffrées.
|
||||
|
||||
> Question 10 : Avez-vous selon vous un "bon" certificat sur le SMTP de iutva-mail ? Qu'en déduire sur la sécurité de l'échange entre target-dmz et iutva-mail ? En notant que ceci est bien le comportement par défaut lors de l'installation.
|
||||
|
||||
|
||||
SpamAssassin
|
||||
============
|
||||
|
||||
SpamAssassin est un filtre antispam à intégrer sur les mails reçus. Pour l'installer sur iutva-mail : `apt install spamassassin`. Vous utliserez ensuite la partie "Setup Postfix with SA 3.4.2 (Buster) as a Content Filter", sous-partie "Postfix" du guide du [Wiki Debian](https://wiki.debian.org/DebianSpamAssassin)
|
||||
|
||||
Envoyez un mail depuis target-commercial à l'adresse debian@iutva.milxc et vérifiez, dans les logs de postfix (sur iutva-mail) et dans le code source du mail reçu, le bon passage par SpamAssassin.
|
||||
|
||||
> Question 11 : Intégrez la partie de log postfix et la partie d'en-têtes du mail reçu qui montre le bon passage par SpamAssassin.
|
||||
|
||||
|
||||
SPF/DKIM/DMARC
|
||||
==============
|
||||
|
||||
Vous trouverez un bon guide pour la configuration SPF/DKIM/DMARC pour Postfix sous Debian [ici](https://www.malekal.com/installer-configurer-postfix-spf-dkim-dmarc/)
|
||||
|
||||
> Question 12 : Décrivez les modifications de fichiers de configuration.
|
||||
|
||||
|
||||
Authentification SASL
|
||||
=====================
|
||||
|
||||
Actuellement, votre serveur SMTP n'authentifie pas les connexions à la soumission de mails. Activez SASL, soit avec saslauthd, soit avec dovecot, en suivant la doc [ici](https://wiki.debian.org/PostfixAndSASL)
|
||||
|
||||
> Question 13 : Décrivez les modifications de fichiers de configuration.
|
||||
|
||||
|
||||
Anti-relayage
|
||||
=============
|
||||
|
||||
Votre serveur mail doit accepter uniquement :
|
||||
* les mails venant de vos utilisateurs à destination de l'extérieur
|
||||
* les mails venant de l'extérieur à destination de vos utilisateurs
|
||||
|
||||
> Question 14 : Proposez une méthodologie pour tester le comportement actuel et validez que vous n'êtes pas un relai ouvert.
|
||||
|
||||
|
||||
Bonus
|
||||
=====
|
||||
|
||||
Recherchez des guides de bonnes pratiques, durcissement, _hardening_ pour un serveur mail en général ou pour Postfix en particulier. Évaluez ce que vous avez bien fait, ce qui pourrait être approfondi et faîtes-le si le temps le permet.
|
Loading…
x
Reference in New Issue
Block a user