index.html 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520
  1. <!DOCTYPE html>
  2. <!--[if IE 8]><html class="no-js lt-ie9" lang="en" > <![endif]-->
  3. <!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]-->
  4. <head>
  5. <meta charset="utf-8">
  6. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  7. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  8. <link rel="shortcut icon" href="../img/favicon.ico">
  9. <title>Installation d'un serveur de courriers basique - Les Tutoriels du Yojik</title>
  10. <link rel="stylesheet" href="../css/theme.css" />
  11. <link rel="stylesheet" href="../css/theme_extra.css" />
  12. <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/styles/github.min.css" />
  13. <script>
  14. // Current page data
  15. var mkdocs_page_name = "Installation d'un serveur de courriers basique";
  16. var mkdocs_page_input_path = "Installation-courrier-basique.md";
  17. var mkdocs_page_url = null;
  18. </script>
  19. <script src="../js/jquery-2.1.1.min.js" defer></script>
  20. <script src="../js/modernizr-2.8.3.min.js" defer></script>
  21. <script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/highlight.min.js"></script>
  22. <script>hljs.initHighlightingOnLoad();</script>
  23. </head>
  24. <body class="wy-body-for-nav" role="document">
  25. <div class="wy-grid-for-nav">
  26. <nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
  27. <div class="wy-side-scroll">
  28. <div class="wy-side-nav-search">
  29. <a href=".." class="icon icon-home"> Les Tutoriels du Yojik</a>
  30. <div role="search">
  31. <form id ="rtd-search-form" class="wy-form" action="../search.html" method="get">
  32. <input type="text" name="q" placeholder="Search docs" title="Type search term here" />
  33. </form>
  34. </div>
  35. </div>
  36. <div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="main navigation">
  37. <p class="caption"><span class="caption-text">Installation d'un serveur sécurisé, version Debian/Buster sur RaspberryPI</span></p>
  38. <ul class="current">
  39. <li class="toctree-l1"><a class="reference internal" href="..">Résumé</a>
  40. </li>
  41. <li class="toctree-l1"><a class="reference internal" href="../tutoraspi/">Présentation</a>
  42. </li>
  43. <li class="toctree-l1"><a class="reference internal" href="../Installation-de-base/">Installation de base</a>
  44. </li>
  45. <li class="toctree-l1"><a class="reference internal" href="../Premier-d%C3%A9marrage/">Premier démarrage</a>
  46. </li>
  47. <li class="toctree-l1"><a class="reference internal" href="../Etat-des-lieux/">État des lieux</a>
  48. </li>
  49. <li class="toctree-l1"><a class="reference internal" href="../S%C3%A9curisation-SSH/">Sécurisation SSH</a>
  50. </li>
  51. <li class="toctree-l1"><a class="reference internal" href="../R%C3%A9seau/">Réseau (des IPs fixes)</a>
  52. </li>
  53. <li class="toctree-l1"><a class="reference internal" href="../Knot/">Installation de Knot-resolver</a>
  54. </li>
  55. <li class="toctree-l1"><a class="reference internal" href="../Firewall/">Installation d'un pare-feux</a>
  56. </li>
  57. <li class="toctree-l1"><a class="reference internal" href="../Fail2ban/">Contrer les attaques de force brute</a>
  58. </li>
  59. <li class="toctree-l1"><a class="reference internal" href="../Logwatch/">Surveillance du serveur</a>
  60. </li>
  61. <li class="toctree-l1 current"><a class="reference internal current" href="./">Installation d'un serveur de courriers basique</a>
  62. <ul class="current">
  63. <li class="toctree-l2"><a class="reference internal" href="#installation">Installation</a>
  64. </li>
  65. <li class="toctree-l2"><a class="reference internal" href="#suppression-complete-de-exim4">Suppression complète de exim4</a>
  66. </li>
  67. <li class="toctree-l2"><a class="reference internal" href="#ouverture-des-ports-25">Ouverture des ports 25</a>
  68. <ul>
  69. <li class="toctree-l3"><a class="reference internal" href="#liste-des-services-disponibles">Liste des services disponibles</a>
  70. </li>
  71. <li class="toctree-l3"><a class="reference internal" href="#ajout-du-service-smtp">Ajout du service smtp</a>
  72. </li>
  73. <li class="toctree-l3"><a class="reference internal" href="#verification">Vérification</a>
  74. </li>
  75. </ul>
  76. </li>
  77. <li class="toctree-l2"><a class="reference internal" href="#installation-des-utilitaire-courriers">Installation des utilitaire courriers</a>
  78. </li>
  79. <li class="toctree-l2"><a class="reference internal" href="#test-denvoi-de-courriers-entre-comptes-internes">Test d'envoi de courriers entre comptes internes.</a>
  80. </li>
  81. <li class="toctree-l2"><a class="reference internal" href="#configuration-de-postfix">Configuration de postfix</a>
  82. <ul>
  83. <li class="toctree-l3"><a class="reference internal" href="#courriers-sortants">Courriers sortants</a>
  84. </li>
  85. <li class="toctree-l3"><a class="reference internal" href="#courriers-entrants">Courriers entrants</a>
  86. </li>
  87. </ul>
  88. </li>
  89. <li class="toctree-l2"><a class="reference internal" href="#amelioration-de-la-gestion-du-courrier">Amélioration de la gestion du courrier</a>
  90. </li>
  91. <li class="toctree-l2"><a class="reference internal" href="#protection-par-fail2ban">Protection par Fail2ban</a>
  92. </li>
  93. </ul>
  94. </li>
  95. <li class="toctree-l1"><a class="reference internal" href="../Exemple-d-utilisation-serveur-Web/">Exemple d'utilisation avec un serveur Web</a>
  96. </li>
  97. <li class="toctree-l1"><a class="reference internal" href="../Annexe/">Annexe</a>
  98. </li>
  99. </ul>
  100. </div>
  101. </div>
  102. </nav>
  103. <section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
  104. <nav class="wy-nav-top" role="navigation" aria-label="top navigation">
  105. <i data-toggle="wy-nav-top" class="fa fa-bars"></i>
  106. <a href="..">Les Tutoriels du Yojik</a>
  107. </nav>
  108. <div class="wy-nav-content">
  109. <div class="rst-content">
  110. <div role="navigation" aria-label="breadcrumbs navigation">
  111. <ul class="wy-breadcrumbs">
  112. <li><a href="..">Docs</a> &raquo;</li>
  113. <li>Installation d'un serveur sécurisé, version Debian/Buster sur RaspberryPI &raquo;</li>
  114. <li>Installation d'un serveur de courriers basique</li>
  115. <li class="wy-breadcrumbs-aside">
  116. </li>
  117. </ul>
  118. <hr/>
  119. </div>
  120. <div role="main">
  121. <div class="section">
  122. <h1 id="installation-dun-serveur-de-courrier-basique">Installation d'un serveur de courrier basique</h1>
  123. <p>Debian installe par défaut <strong>exim4</strong>. Nous allons le remplacer par postfix (que nous étendrons par la suite pour obtenir un serveur de mail complet)</p>
  124. <p>Il faut penser à ouvrir les ports 25 en IPV4 et IPV6 avec <strong>firewalld</strong>.</p>
  125. <h2 id="installation">Installation</h2>
  126. <pre><code>pi@raspberrypi:~ $ sudo apt install postfix
  127. Lecture des listes de paquets... Fait
  128. Construction de l'arbre des dépendances
  129. Lecture des informations d'état... Fait
  130. Les paquets suivants ont été installés automatiquement et ne sont plus nécessaires :
  131. libgnutls-dane0 libunbound8
  132. Veuillez utiliser « sudo apt autoremove » pour les supprimer.
  133. Les paquets supplémentaires suivants seront installés :
  134. ssl-cert
  135. Paquets suggérés :
  136. procmail postfix-mysql postfix-pgsql postfix-ldap postfix-pcre postfix-lmdb postfix-sqlite sasl2-bin | dovecot-common postfix-cdb ufw
  137. postfix-doc openssl-blacklist
  138. Les paquets suivants seront ENLEVÉS :
  139. exim4-base exim4-config exim4-daemon-light
  140. Les NOUVEAUX paquets suivants seront installés :
  141. postfix ssl-cert
  142. 0 mis à jour, 2 nouvellement installés, 3 à enlever et 0 non mis à jour.
  143. Il est nécessaire de prendre 1 423 ko dans les archives.
  144. Après cette opération, 0 o d'espace disque supplémentaires seront utilisés.
  145. Souhaitez-vous continuer ? [O/n] o
  146. Réception de :1 http://ftp.igh.cnrs.fr/pub/os/linux/raspbian/raspbian buster/main armhf postfix armhf 3.4.14-0+deb10u1 [1 402 kB]
  147. Réception de :2 http://mirrors.ircam.fr/pub/raspbian/raspbian buster/main armhf ssl-cert all 1.0.39 [20,8 kB]
  148. 1 423 ko réceptionnés en 3s (524 ko/s)
  149. Préconfiguration des paquets...
  150. dpkg: exim4-daemon-light : problème de dépendance, mais suppression comme demandé :
  151. logwatch dépend de default-mta | mail-transport-agent ; cependant :
  152. Le paquet default-mta n'est pas installé.
  153. Le paquet exim4-daemon-light qui fournit default-mta doit être supprimé.
  154. Le paquet mail-transport-agent n'est pas installé.
  155. Le paquet exim4-daemon-light qui fournit mail-transport-agent doit être supprimé.
  156. logwatch dépend de default-mta | mail-transport-agent ; cependant :
  157. Le paquet default-mta n'est pas installé.
  158. Le paquet exim4-daemon-light qui fournit default-mta doit être supprimé.
  159. Le paquet mail-transport-agent n'est pas installé.
  160. Le paquet exim4-daemon-light qui fournit mail-transport-agent doit être supprimé.
  161. (Lecture de la base de données... 46982 fichiers et répertoires déjà installés.)
  162. Suppression de exim4-daemon-light (4.92-8+deb10u4) ...
  163. dpkg: exim4-config : problème de dépendance, mais suppression comme demandé :
  164. exim4-base dépend de exim4-config (&gt;= 4.82) | exim4-config-2 ; cependant :
  165. Le paquet exim4-config doit être supprimé.
  166. Le paquet exim4-config-2 n'est pas installé.
  167. Le paquet exim4-config qui fournit exim4-config-2 doit être supprimé.
  168. exim4-base dépend de exim4-config (&gt;= 4.82) | exim4-config-2 ; cependant :
  169. Le paquet exim4-config doit être supprimé.
  170. Le paquet exim4-config-2 n'est pas installé.
  171. Le paquet exim4-config qui fournit exim4-config-2 doit être supprimé.
  172. Suppression de exim4-config (4.92-8+deb10u4) ...
  173. Sélection du paquet postfix précédemment désélectionné.
  174. (Lecture de la base de données... 46922 fichiers et répertoires déjà installés.)
  175. Préparation du dépaquetage de .../postfix_3.4.14-0+deb10u1_armhf.deb ...
  176. Dépaquetage de postfix (3.4.14-0+deb10u1) ...
  177. (Lecture de la base de données... 47112 fichiers et répertoires déjà installés.)
  178. Suppression de exim4-base (4.92-8+deb10u4) ...
  179. Sélection du paquet ssl-cert précédemment désélectionné.
  180. (Lecture de la base de données... 47038 fichiers et répertoires déjà installés.)
  181. Préparation du dépaquetage de .../ssl-cert_1.0.39_all.deb ...
  182. Dépaquetage de ssl-cert (1.0.39) ...
  183. Paramétrage de ssl-cert (1.0.39) ...
  184. Paramétrage de postfix (3.4.14-0+deb10u1) ...
  185. Ajout du groupe « postfix » (GID 118)...
  186. Fait.
  187. Ajout de l'utilisateur système « postfix » (UID 112) ...
  188. Ajout du nouvel utilisateur « postfix » (UID 112) avec pour groupe d'appartenance « postfix » ...
  189. Le répertoire personnel « /var/spool/postfix » n'a pas été créé.
  190. Creating /etc/postfix/dynamicmaps.cf
  191. Ajout du groupe « postdrop » (GID 119)...
  192. Fait.
  193. setting myhostname: raspberrypi
  194. setting alias maps
  195. setting alias database
  196. changing /etc/mailname to yojik.net
  197. setting myorigin
  198. setting destinations: $myhostname, yojik.net, raspberrypi, localhost.localdomain, localhost
  199. setting relayhost:
  200. setting mynetworks: 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128
  201. setting mailbox_size_limit: 0
  202. setting recipient_delimiter: +
  203. setting inet_interfaces: all
  204. setting inet_protocols: all
  205. WARNING: /etc/aliases exists, but does not have a root alias.
  206. Postfix (main.cf) is now set up with a default configuration. If you need to
  207. make changes, edit /etc/postfix/main.cf (and others) as needed. To view
  208. Postfix configuration values, see postconf(1).
  209. After modifying main.cf, be sure to run 'service postfix reload'.
  210. Running newaliases
  211. Created symlink /etc/systemd/system/multi-user.target.wants/postfix.service → /lib/systemd/system/postfix.service.
  212. Traitement des actions différées (« triggers ») pour systemd (241-7~deb10u6+rpi1) ...
  213. Traitement des actions différées (« triggers ») pour man-db (2.8.5-2) ...
  214. Traitement des actions différées (« triggers ») pour rsyslog (8.1901.0-1) ...
  215. pi@raspberrypi:~ $
  216. </code></pre>
  217. <h2 id="suppression-complete-de-exim4">Suppression complète de <strong>exim4</strong></h2>
  218. <p>On supprime complètement <strong>exim4</strong>, fichiers de configuration inclus.</p>
  219. <pre><code>pi@raspberrypi:~ $ sudo apt remove --purge exim4*
  220. Lecture des listes de paquets... Fait
  221. Construction de l'arbre des dépendances
  222. Lecture des informations d'état... Fait
  223. Note : sélection de exim4-base pour l'expression rationnelle « exim4* »
  224. Note : sélection de exim4-config-2 pour l'expression rationnelle « exim4* »
  225. Note : sélection de exim4-doc-info pour l'expression rationnelle « exim4* »
  226. Note : sélection de exim4-daemon-light pour l'expression rationnelle « exim4* »
  227. Note : sélection de exim4-daemon-heavy pour l'expression rationnelle « exim4* »
  228. Note : sélection de exim4-daemon-custom pour l'expression rationnelle « exim4* »
  229. Note : sélection de exim4-config pour l'expression rationnelle « exim4* »
  230. Note : sélection de exim4-doc-html pour l'expression rationnelle « exim4* »
  231. Note : sélection de exim4-localscanapi-2.0 pour l'expression rationnelle « exim4* »
  232. Note : sélection de exim4-dev pour l'expression rationnelle « exim4* »
  233. Note : sélection de exim4 pour l'expression rationnelle « exim4* »
  234. Le paquet « exim4-daemon-custom » n'est pas installé, et ne peut donc être supprimé
  235. Note : sélection de « exim4-config » au lieu de « exim4-config-2 »
  236. Le paquet « exim4 » n'est pas installé, et ne peut donc être supprimé
  237. Le paquet « exim4-daemon-heavy » n'est pas installé, et ne peut donc être supprimé
  238. Le paquet « exim4-dev » n'est pas installé, et ne peut donc être supprimé
  239. Le paquet « exim4-doc-html » n'est pas installé, et ne peut donc être supprimé
  240. Le paquet « exim4-doc-info » n'est pas installé, et ne peut donc être supprimé
  241. Les paquets suivants ont été installés automatiquement et ne sont plus nécessaires :
  242. libgnutls-dane0 libunbound8
  243. Veuillez utiliser « sudo apt autoremove » pour les supprimer.
  244. Les paquets suivants seront ENLEVÉS :
  245. exim4-base* exim4-config* exim4-daemon-light*
  246. 0 mis à jour, 0 nouvellement installés, 3 à enlever et 0 non mis à jour.
  247. Après cette opération, 0 o d'espace disque supplémentaires seront utilisés.
  248. Souhaitez-vous continuer ? [O/n] o
  249. (Lecture de la base de données... 47047 fichiers et répertoires déjà installés.)
  250. Purge des fichiers de configuration de exim4-base (4.92-8+deb10u4) ...
  251. Purge des fichiers de configuration de exim4-config (4.92-8+deb10u4) ...
  252. dpkg-statoverride: avertissement: pas de dérogation (« override ») présente
  253. Purge des fichiers de configuration de exim4-daemon-light (4.92-8+deb10u4) ...
  254. Traitement des actions différées (« triggers ») pour systemd (241-7~deb10u6+rpi1) ...
  255. pi@raspberrypi:~ $
  256. </code></pre>
  257. <h2 id="ouverture-des-ports-25">Ouverture des ports 25</h2>
  258. <p>Ajout du protocole <strong>smtp</strong> à notre zone.</p>
  259. <h3 id="liste-des-services-disponibles">Liste des services disponibles</h3>
  260. <pre><code>pi@piras:~ $ sudo firewall-cmd --get-services
  261. RH-Satellite-6 amanda-client amanda-k5-client amqp amqps apcupsd audit bacula
  262. bacula-client bgp bitcoin bitcoin-rpc bitcoin-testnet bitcoin-testnet-rpc
  263. ceph ceph-mon cfengine cockpit condor-collector ctdb dhcp dhcpv6
  264. dhcpv6-client distcc dns docker-registry docker-swarm dropbox-lansync
  265. elasticsearch etcd-client etcd-server finger freeipa-ldap freeipa-ldaps
  266. freeipa-replication freeipa-trust ftp ganglia-client ganglia-master
  267. git gre high-availability http https imap imaps ipp ipp-client
  268. ipsec irc ircs iscsi-target isns jenkins kadmin kerberos kibana klogin
  269. kpasswd kprop kshell ldap ldaps libvirt libvirt-tls lightning-network
  270. llmnr managesieve matrix mdns minidlna mongodb mosh mountd mqtt mqtt-tls
  271. ms-wbt mssql murmur mysql nfs nfs3 nmea-0183 nrpe ntp nut openvpn
  272. ovirt-imageio ovirt-storageconsole ovirt-vmconsole plex pmcd pmproxy
  273. pmwebapi pmwebapis pop3 pop3s postgresql privoxy proxy-dhcp ptp
  274. pulseaudio puppetmaster quassel radius redis rpc-bind rsh rsyncd
  275. rtsp salt-master samba samba-client samba-dc sane sip sips slp smtp
  276. smtp-submission smtps snmp snmptrap spideroak-lansync squid ssh
  277. steam-streaming svdrp svn syncthing syncthing-gui synergy syslog syslog-tls
  278. telnet tftp tftp-client tinc tor-socks transmission-client upnp-client vdsm
  279. vnc-server wbem-http wbem-https wsman wsmans xdmcp xmpp-bosh xmpp-client
  280. xmpp-local xmpp-server zabbix-agent zabbix-server
  281. pi@piras:~ $
  282. </code></pre>
  283. <p>Le protocole qui nous intéresse est : <strong>smtp</strong></p>
  284. <h3 id="ajout-du-service-smtp">Ajout du service smtp</h3>
  285. <pre><code>pi@piras:~ $ sudo firewall-cmd --permanent --zone=public --add-service=smtp
  286. success
  287. pi@piras:~ $
  288. </code></pre>
  289. <p>Il faut recharger <strong>firewalld</strong> pour que ce soit pris en compte.</p>
  290. <pre><code>pi@piras:~ $ sudo systemctl restart firewalld
  291. pi@piras:~ $
  292. </code></pre>
  293. <p>Dans mon cas, j'ai été obligé de redémarrer le serveur pour que ce soit pris en compte: pas d'explication ... mais comme ça, ça marche!</p>
  294. <h3 id="verification">Vérification</h3>
  295. <pre><code>pi@piras:~ $ sudo firewall-cmd --list-all
  296. public (active)
  297. target: default
  298. icmp-block-inversion: no
  299. interfaces: eth0
  300. sources:
  301. services: dhcpv6-client smtp ssh
  302. ports:
  303. protocols:
  304. masquerade: no
  305. forward-ports:
  306. source-ports:
  307. icmp-blocks:
  308. rich rules:
  309. pi@piras:~ $
  310. </code></pre>
  311. <h2 id="installation-des-utilitaire-courriers">Installation des utilitaire courriers</h2>
  312. <pre><code>pi@raspberrypi:~ $ sudo apt install mailutils
  313. Lecture des listes de paquets... Fait
  314. Construction de l'arbre des dépendances
  315. Lecture des informations d'état... Fait
  316. mailutils est déjà la version la plus récente (1:3.5-4).
  317. mailutils passé en « installé manuellement ».
  318. Les paquets suivants ont été installés automatiquement et ne sont plus nécessaires :
  319. libgnutls-dane0 libunbound8
  320. Veuillez utiliser « sudo apt autoremove » pour les supprimer.
  321. 0 mis à jour, 0 nouvellement installés, 0 à enlever et 0 non mis à jour.
  322. pi@raspberrypi:~ $
  323. </code></pre>
  324. <p>Ils étaient déjà installés.</p>
  325. <h2 id="test-denvoi-de-courriers-entre-comptes-internes">Test d'envoi de courriers entre comptes internes.</h2>
  326. <ul>
  327. <li>
  328. <p>pi-&gt; root</p>
  329. <p>Les commandes suivantes permettent de :</p>
  330. <ul>
  331. <li>
  332. <p>envoyer un message à <strong>root</strong>(Essai 1)</p>
  333. <pre><code>pi@raspberrypi:~ $ mail root
  334. Cc:
  335. Subject: Essai1
  336. Essai 1
  337. .
  338. pi@raspberrypi:~ $
  339. </code></pre>
  340. </li>
  341. <li>
  342. <p>passer <strong>root</strong></p>
  343. <pre><code>pi@raspberrypi:~ $ sudo /bin/bash
  344. root@raspberrypi:/home/pi#
  345. </code></pre>
  346. </li>
  347. <li>
  348. <p>lancer <strong>mutt</strong></p>
  349. <pre><code>root@raspberrypi:/home/pi# mutt
  350. 1 gardé(s), 0 effacé(s).
  351. root@raspberrypi:/home/pi#
  352. </code></pre>
  353. <p><img alt="image de mutt" src="../Images/Capture%20d%E2%80%99%C3%A9cran%20de%202021-02-14%2019-11-39.png" /></p>
  354. </li>
  355. </ul>
  356. </li>
  357. <li>
  358. <p>root -&gt; pi</p>
  359. <pre><code>root@raspberrypi:/home/pi# mail pi
  360. Cc:
  361. Subject: Essai 2
  362. .
  363. root@raspberrypi:/home/pi# exit
  364. Vous avez du nouveau courrier dans /var/mail/pi
  365. pi@raspberrypi:~ $ mutt
  366. 3 gardé(s), 0 effacé(s).
  367. pi@raspberrypi:~ $
  368. </code></pre>
  369. <p>Nous avions 2 messages avant: le nouveau message est bien arrivé !</p>
  370. </li>
  371. </ul>
  372. <h2 id="configuration-de-postfix">Configuration de <strong>postfix</strong></h2>
  373. <p>Il nous faut configurer <strong>postfix</strong> pour permettre l'envoi de courriers à l'extérieur et en recevoir de l'extérieur.</p>
  374. <p>Pour cela, il nous faut modifier le fichier <strong>/etc/postfix/main.cf</strong></p>
  375. <p>Modifiez la ligne <strong>mydestination</strong> pour qu'elle ressemble à ce qui suit :</p>
  376. <blockquote>
  377. <p>mydestination = $myhostname, yojik.net, atom.yojik.net, localhost.yojik.net, localhost</p>
  378. </blockquote>
  379. <p>et relancez <strong>postfix</strong> avec la commande suivante :</p>
  380. <blockquote>
  381. <p>sudo service postfix restart</p>
  382. </blockquote>
  383. <h3 id="courriers-sortants">Courriers sortants</h3>
  384. <p>Envoi d'un message sur mon compte de messagerie gmail (oui, un envoi sur mon compte normal ne fonctionne pas dû à sa configuration):</p>
  385. <pre><code>pi@piras:~$ echo "Et voilà un petit message" | mail -s "test du courrier sortant" ericounet26200@gmail.com
  386. </code></pre>
  387. <p>Le message est bien reçu et dans les courriers indésirables, bien entendu (pas de dkim, spf, dnnssec, etc.)</p>
  388. <h3 id="courriers-entrants">Courriers entrants</h3>
  389. <p>Envoi d'un message à partir de mon adresse de courrier normale :</p>
  390. <p>Message bien reçu (après mise à jour de mon serveur DNS).</p>
  391. <p><img alt="Mutt" src="../Images/Capture%20d%E2%80%99%C3%A9cran%20de%202021-02-15%2004-59-28.png" /></p>
  392. <h2 id="amelioration-de-la-gestion-du-courrier">Amélioration de la gestion du courrier</h2>
  393. <p>Nous allons transférer les mails destinés à <strong>root</strong> vers l'utilisateur <strong>pi</strong>. Ainsi que d'autres adresses de courrier standards. Pour cela, nous allons modifier le fichier <strong>/etc/aliases</strong>, le compiler pour être digeste par <strong>postfix</strong> et relancer <strong>postfix</strong>.</p>
  394. <p>Ce fichier sert à rediriger toutes les adresses émail comme <strong>abuse</strong>, <strong>webmaster</strong>, <strong>root</strong> vers un utilisateur <strong>administrateur</strong> de la machine, root puis vers moi <strong>ericadmin</strong>.</p>
  395. <pre><code># /etc/aliases
  396. mailer-daemon: postmaster
  397. postmaster: root
  398. nobody: root
  399. hostmaster: root
  400. usenet: root
  401. news: root
  402. webmaster: root
  403. www: root
  404. ftp: root
  405. abuse: root
  406. noc: root
  407. security: root
  408. root: pi
  409. </code></pre>
  410. <p>Il faut lancer la commande <strong>newaliases</strong> pour générer le fichier.db utile à Postfix et on demande à Postfix de recharger ses fichiers.</p>
  411. <pre><code>pi@piras:~ $ sudo newaliases
  412. pi@piras:~ $
  413. </code></pre>
  414. <p>On relance <strong>postfix</strong> :</p>
  415. <pre><code>pi@piras:~ $ sudo systemctl restart postfix
  416. pi@piras:~ $
  417. </code></pre>
  418. <p>Et on teste (envoi d'un courrier à root@piras.yojik.net)</p>
  419. <p><img alt="Transfert" src="../Images/Capture%20d%E2%80%99%C3%A9cran%20de%202021-02-15%2005-07-49.png" /></p>
  420. <p>Et voilà, notre serveur de courrier est fonctionnel.</p>
  421. <h2 id="protection-par-fail2ban">Protection par Fail2ban</h2>
  422. <p>Nous devons ajouter la surveillance du mail par <strong>fail2ban</strong>.</p>
  423. <p>Editons le fichier /etc/fail2ban/jail.d/defaults-debian.conf pour y ajouter la surveillance de postfix (port smtp : 25.)</p>
  424. <p>Nous prenons l'exemple fourni dans <strong>/etc/fail2ban/jail.conf</strong> et ne gardons que le port 25.</p>
  425. <p>Voilà la partie modifiée à ajouter :</p>
  426. <pre><code>[postfix]
  427. mode = more
  428. port = smtp
  429. logpath = %(postfix_log)s
  430. backend = %(postfix_backend)s
  431. </code></pre>
  432. <p>Relançons le service pour que nos modifications soient prises en compte:</p>
  433. <pre><code>pi@piras:~ $ sudo systemctl reload fail2ban
  434. pi@piras:~ $
  435. </code></pre>
  436. </div>
  437. </div>
  438. <footer>
  439. <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
  440. <a href="../Exemple-d-utilisation-serveur-Web/" class="btn btn-neutral float-right" title="Exemple d'utilisation avec un serveur Web">Next <span class="icon icon-circle-arrow-right"></span></a>
  441. <a href="../Logwatch/" class="btn btn-neutral" title="Surveillance du serveur"><span class="icon icon-circle-arrow-left"></span> Previous</a>
  442. </div>
  443. <hr/>
  444. <div role="contentinfo">
  445. <!-- Copyright etc -->
  446. </div>
  447. Built with <a href="https://www.mkdocs.org/">MkDocs</a> using a <a href="https://github.com/snide/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
  448. </footer>
  449. </div>
  450. </div>
  451. </section>
  452. </div>
  453. <div class="rst-versions" role="note" aria-label="versions">
  454. <span class="rst-current-version" data-toggle="rst-current-version">
  455. <span><a href="../Logwatch/" style="color: #fcfcfc;">&laquo; Previous</a></span>
  456. <span style="margin-left: 15px"><a href="../Exemple-d-utilisation-serveur-Web/" style="color: #fcfcfc">Next &raquo;</a></span>
  457. </span>
  458. </div>
  459. <script>var base_url = '..';</script>
  460. <script src="../js/theme.js" defer></script>
  461. <script src="../search/main.js" defer></script>
  462. <script defer>
  463. window.onload = function () {
  464. SphinxRtdTheme.Navigation.enable(true);
  465. };
  466. </script>
  467. </body>
  468. </html>