index.html 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721
  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>SPF, DKIM, OPENDMARC - 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 = "SPF, DKIM, OPENDMARC";
  16. var mkdocs_page_input_path = "Tutoriels/tutostretch/Courrier-SPF-DKIM-OPENDMARC.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">Home</span></p>
  38. <ul>
  39. <li class="toctree-l1"><a class="reference internal" href="../../..">Page d'accueil</a>
  40. </li>
  41. </ul>
  42. <p class="caption"><span class="caption-text">Tutoriels</span></p>
  43. <ul>
  44. <li class="toctree-l1"><a class="reference internal" href="../../tutos/">Introduction</a>
  45. </li>
  46. <li class="toctree-l1"><a class="reference internal" href="#">Installation d'un serveur sécurisé, version Debian/Stretch (obsolète)</a>
  47. <ul>
  48. <li class="toctree-l2"><a class="reference internal" href="../tutostretch/">Présentation</a>
  49. </li>
  50. <li class="toctree-l2"><a class="reference internal" href="#">Installation</a>
  51. <ul>
  52. <li class="toctree-l3"><a class="reference internal" href="../Installation-de-base/">Installation du système de base</a>
  53. </li>
  54. <li class="toctree-l3"><a class="reference internal" href="../ovh/">Démarrage sur serveur OVH</a>
  55. </li>
  56. <li class="toctree-l3"><a class="reference internal" href="../Premi%C3%A8re-Etape-S%C3%A9curisation/">Première étapes de sécurisation du serveur</a>
  57. </li>
  58. <li class="toctree-l3"><a class="reference internal" href="../Configuration-R%C3%A9seau/">Configuration du réseau</a>
  59. </li>
  60. <li class="toctree-l3"><a class="reference internal" href="../Installation-Serveur-Temps/">Installation d'un serveur de temps</a>
  61. </li>
  62. <li class="toctree-l3"><a class="reference internal" href="../Installation-Parre-Feu/">Installation d'un pare-feu</a>
  63. </li>
  64. <li class="toctree-l3"><a class="reference internal" href="../Installation-Fail2ban/">Contrer les attaques de brute-force avec fail2ban</a>
  65. </li>
  66. <li class="toctree-l3"><a class="reference internal" href="../Installation-Serveur-Courrier-Basique/">Installation d'un serveur de courrier basique</a>
  67. </li>
  68. <li class="toctree-l3"><a class="reference internal" href="../Installation-Serveur-DNS/">Installation du serveur DNS</a>
  69. </li>
  70. <li class="toctree-l3"><a class="reference internal" href="../Installation-Serveur-Web/">Installation d'un serveur web</a>
  71. </li>
  72. <li class="toctree-l3"><a class="reference internal" href="../Installation-Dovecot-Authentification/">Installation de dovecot et de l'authentification</a>
  73. </li>
  74. <li class="toctree-l3"><a class="" href="../Installation-Certificats-Letsencrypt.md)">Installation des certificats letsencrypt</a>
  75. </li>
  76. <li class="toctree-l3"><a class="" href="../courrier-SPF-DKIM-OPENDMARC.md">Ajout des enregistrements **spf**, **DKIM**, **DMARC** au fichier de zone DNS</a>
  77. </li>
  78. <li class="toctree-l3"><a class="reference internal" href="../Courrier-Comptes-Virtuels/">Ajout des comptes émail virtuels</a>
  79. </li>
  80. <li class="toctree-l3"><a class="reference internal" href="../Surveillance-Serveur/">Installation de programmes de surveillance du serveur</a>
  81. </li>
  82. <li class="toctree-l3"><a class="reference internal" href="../Installation-Webmail/">Installation d'un webmail (rainloop)</a>
  83. </li>
  84. <li class="toctree-l3"><a class="" href="../Sécurisation-Serveur-Web">Sécurisation d'un serveur WEB</a>
  85. </li>
  86. </ul>
  87. </li>
  88. </ul>
  89. </li>
  90. <li class="toctree-l1"><a class="reference internal" href="#">Installation d'un serveur sécurisé, version Debian/Buster (en cours d'écriture)</a>
  91. <ul>
  92. <li class="toctree-l2"><a class="reference internal" href="../../tutobuster/1-tutobuster/">Présentation</a>
  93. </li>
  94. <li class="toctree-l2"><a class="reference internal" href="../../tutobuster/2-Installation-de-base/">Installation de base</a>
  95. </li>
  96. <li class="toctree-l2"><a class="reference internal" href="../../tutobuster/3-ovh/">Démarrage sur serveur OVH</a>
  97. </li>
  98. <li class="toctree-l2"><a class="reference internal" href="../../tutobuster/4-Plan/">Plan d'ensemble</a>
  99. </li>
  100. <li class="toctree-l2"><a class="reference internal" href="../../tutobuster/5-Premi%C3%A8re-Etape-S%C3%A9curisation/">Premières étapes de sécurisation du serveur</a>
  101. </li>
  102. </ul>
  103. </li>
  104. <li class="toctree-l1"><a class="reference internal" href="#">Installation d'un serveur sécurisé, version Debian/Buster sur RaspberryPI</a>
  105. <ul>
  106. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/R%C3%A9sum%C3%A9/">Résumé</a>
  107. </li>
  108. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/tutoraspi/">Présentation</a>
  109. </li>
  110. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/Installation-de-base/">Installation de base</a>
  111. </li>
  112. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/Premier-d%C3%A9marrage/">Premier démarrage</a>
  113. </li>
  114. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/Etat-des-lieux/">État des lieux</a>
  115. </li>
  116. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/S%C3%A9curisation-SSH/">Sécurisation SSH</a>
  117. </li>
  118. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/R%C3%A9seau/">Réseau (des IPs fixes)</a>
  119. </li>
  120. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/Knot/">Installation de Knot-resolver</a>
  121. </li>
  122. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/Firewall/">Installation d'un pare-feux</a>
  123. </li>
  124. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/Fail2ban/">Contrer les attaques de force brute</a>
  125. </li>
  126. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/Logwatch/">Surveillance du serveur</a>
  127. </li>
  128. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/Installation-courrier-basique/">Installation d'un serveur de courriers basique</a>
  129. </li>
  130. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/Exemple-d-utilisation-serveur-Web/">Exemple d'utilisation avec un serveur Web</a>
  131. </li>
  132. <li class="toctree-l2"><a class="reference internal" href="../../tutoraspi/Annexe/">Annexe</a>
  133. </li>
  134. </ul>
  135. </li>
  136. <li class="toctree-l1"><a class="reference internal" href="#">Domotique</a>
  137. <ul>
  138. <li class="toctree-l2"><a class="reference internal" href="../../Domotique/Introduction/">Introduction</a>
  139. </li>
  140. <li class="toctree-l2"><a class="reference internal" href="../../Domotique/Le-mat%C3%A9riel/">Le matériel</a>
  141. </li>
  142. </ul>
  143. </li>
  144. <li class="toctree-l1"><a class="reference internal" href="#">Tutoriel Anki</a>
  145. <ul>
  146. <li class="toctree-l2"><a class="reference internal" href="../../tutoanki/Introduction/">Introduction</a>
  147. </li>
  148. <li class="toctree-l2"><a class="reference internal" href="../../tutoanki/Installation/">Installation</a>
  149. </li>
  150. <li class="toctree-l2"><a class="reference internal" href="../../tutoanki/Les-fiches/">Les fiches</a>
  151. </li>
  152. <li class="toctree-l2"><a class="reference internal" href="../../tutoanki/Premi%C3%A8re-utilisation/">Premières utilisations et impressions</a>
  153. </li>
  154. <li class="toctree-l2"><a class="reference internal" href="../../tutoanki/Personnalisation/">Personnalisation</a>
  155. </li>
  156. <li class="toctree-l2"><a class="reference internal" href="../../tutoanki/Cartes/">Les cartes</a>
  157. </li>
  158. </ul>
  159. </li>
  160. </ul>
  161. </div>
  162. </div>
  163. </nav>
  164. <section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
  165. <nav class="wy-nav-top" role="navigation" aria-label="top navigation">
  166. <i data-toggle="wy-nav-top" class="fa fa-bars"></i>
  167. <a href="../../..">Les Tutoriels du Yojik</a>
  168. </nav>
  169. <div class="wy-nav-content">
  170. <div class="rst-content">
  171. <div role="navigation" aria-label="breadcrumbs navigation">
  172. <ul class="wy-breadcrumbs">
  173. <li><a href="../../..">Docs</a> &raquo;</li>
  174. <li>SPF, DKIM, OPENDMARC</li>
  175. <li class="wy-breadcrumbs-aside">
  176. </li>
  177. </ul>
  178. <hr/>
  179. </div>
  180. <div role="main">
  181. <div class="section">
  182. <h1 id="spf-dkim-opendmarc">SPF, DKIM, OPENDMARC</h1>
  183. <h2 id="spf">SPF</h2>
  184. <h3 id="ajout-des-enregistrements-spf-au-fichier-de-zone-dns">Ajout des enregistrements <strong>spf</strong> au fichier de zone DNS</h3>
  185. <p>Nous allons maintenant ajouter un enregistrement <strong>spf</strong> à notre configuration. SPF est un enregistrement qui déclare quelle machine est responsable et autorisée à envoyer des mails pour notre domaine. Cela permet d'éviter que nos mails soient considérés comme du <strong>spam</strong>.</p>
  186. <p>La syntaxe de la ligne à ajouter est assez simple. Il existe des générateurs de ligne SPF, comme:</p>
  187. <ul>
  188. <li><a href="https://www.spfwizard.net/">spfwizard</a></li>
  189. </ul>
  190. <p>ou</p>
  191. <ul>
  192. <li><a href="https://mxtoolbox.com/SPFRecordGenerator.aspx">mxtoolbox</a>.</li>
  193. </ul>
  194. <p>Le site <a href="http://www.openspf.org/">openspf</a> contient tout ce qu'il faut savoir à propos de SPF, syntaxe, paramètres etc ...</p>
  195. <p>Pour mon serveur, j'ai choisi une politique stricte de rejet des mails qui ne viennent pas d'une source autorisée.</p>
  196. <p>Voici la ligne à rajouter au fichier de zone. C'est le paramètre "-all" qui détermine la politique (de rejet ici). Nous aurions pu mettre <strong>~all</strong> pour une politique moins stricte. (notez le <strong>~</strong> à la place du <strong>-</strong>)</p>
  197. <pre><code>; spf
  198. yojik.net. IN TXT "v=spf1 a mx mx:adara.yojik.net a:adara.yojik.net -all"
  199. yojik.net. IN SPF "v=spf1 a mx mx:adara.yojik.net a:adara.yojik.net -all"
  200. </code></pre>
  201. <p>On recharge bind pour la prise en compte des modifications:</p>
  202. <pre><code>service bind9 restart
  203. </code></pre>
  204. <p>Il nous reste à configurer postfix pour prendre en compte cet enregistrement et effectuer les validations.</p>
  205. <h3 id="installation-des-logiciels-necessaires">Installation des logiciels nécessaires</h3>
  206. <pre><code>root@atom:/etc/bind# apt-get install postfix-policyd-spf-python
  207. Lecture des listes de paquets... Fait
  208. Construction de l'arbre des dépendances
  209. Lecture des informations d'état... Fait
  210. The following additional packages will be installed:
  211. python3-authres python3-dns python3-spf
  212. Paquets suggérés :
  213. python3-yaml
  214. Les NOUVEAUX paquets suivants seront installés :
  215. postfix-policyd-spf-python python3-authres python3-dns python3-spf
  216. 0 mis à jour, 4 nouvellement installés, 0 à enlever et 12 non mis à jour.
  217. Il est nécessaire de prendre 153 ko dans les archives.
  218. Après cette opération, 494 ko d'espace disque supplémentaires seront utilisés.
  219. Souhaitez-vous continuer ? [O/n] o
  220. Réception de:1 http://deb.debian.org/debian stretch/main amd64 python3-dns all 3.1.1-1 [27,5 kB]
  221. Réception de:2 http://deb.debian.org/debian stretch/main amd64 python3-authres all 0.900-1 [17,5 kB]
  222. Réception de:3 http://deb.debian.org/debian stretch/main amd64 python3-spf all 2.0.12t-3 [64,1 kB]
  223. Réception de:4 http://deb.debian.org/debian stretch/main amd64 postfix-policyd-spf-python all 2.0.1-1 [43,8 kB]
  224. 153 ko réceptionnés en 0s (1 533 ko/s)
  225. Sélection du paquet python3-dns précédemment désélectionné.
  226. (Lecture de la base de données... 40435 fichiers et répertoires déjà installés.)
  227. Préparation du dépaquetage de .../python3-dns_3.1.1-1_all.deb ...
  228. Dépaquetage de python3-dns (3.1.1-1) ...
  229. Sélection du paquet python3-authres précédemment désélectionné.
  230. Préparation du dépaquetage de .../python3-authres_0.900-1_all.deb ...
  231. Dépaquetage de python3-authres (0.900-1) ...
  232. Sélection du paquet python3-spf précédemment désélectionné.
  233. Préparation du dépaquetage de .../python3-spf_2.0.12t-3_all.deb ...
  234. Dépaquetage de python3-spf (2.0.12t-3) ...
  235. Sélection du paquet postfix-policyd-spf-python précédemment désélectionné.
  236. Préparation du dépaquetage de .../postfix-policyd-spf-python_2.0.1-1_all.deb ...
  237. Dépaquetage de postfix-policyd-spf-python (2.0.1-1) ...
  238. Paramétrage de python3-authres (0.900-1) ...
  239. Paramétrage de python3-dns (3.1.1-1) ...
  240. Traitement des actions différées (« triggers ») pour man-db (2.7.6.1-2) ...
  241. Paramétrage de python3-spf (2.0.12t-3) ...
  242. Paramétrage de postfix-policyd-spf-python (2.0.1-1) ...
  243. root@atom:/etc/bind#
  244. </code></pre>
  245. <h3 id="configuration-de-postfix-mastercf">Configuration de postfix: master.cf</h3>
  246. <p>Dans le fichier /etc/postfix/master.cf, il faut rajouter le service suivant:</p>
  247. <pre><code>policyd-spf unix - n n - 0 spawn
  248. user=policyd-spf argv=/usr/bin/policyd-spf
  249. </code></pre>
  250. <h3 id="configuration-de-postfix-maincf">Configuration de postfix: main.cf</h3>
  251. <p>Il nous faut ajouter la règle correspondante dans la lsite des restrictions de main.cf. Bien afire attention de positionner <strong>check_policy_service</strong> APRÈS <strong>reject_unauth_destination</strong>, sinon, votre serveur mail devient <strong>openrelay</strong>!</p>
  252. <pre><code>smtpd_recipient_restrictions =
  253. ...
  254. reject_unauth_destination
  255. check_policy_service unix:private/policyd-spf
  256. ...
  257. policyd-spf_time_limit = 3600
  258. </code></pre>
  259. <p>Relancez <strong>postfix</strong>:</p>
  260. <pre><code>service postfix restart
  261. </code></pre>
  262. <h3 id="test">Test</h3>
  263. <p>Je teste ma configuration sur les sites:</p>
  264. <ul>
  265. <li><a href="https://mxtoolbox.com/">Mxtoolbox</a></li>
  266. <li><a href="https://kitterman.com/spf/validate.html">Kitterman</a></li>
  267. <li><a href="https://www.mail-tester.com/spf-dkim-check">Mail-tester</a></li>
  268. </ul>
  269. <p>Les tests ne fonctionnent pas ... en fait, cela vient de la config IPV6 du serveur. La configuration automatique avec privext 2 donne plusieurs adresses IPV6 à la machine (avec le même préfixe, bien sûr). Mais l'adresse de la machine ne correspond plus à l'adresse de la machine déclarée dans bind. Et SPF ne peut plus fonctionner.</p>
  270. <p>La solution a été de configurer manuellement l'adresse IPV6 dans /etc/network/interfaces de la façon suivante:</p>
  271. <pre><code>iface enp2s0 inet6 static
  272. address 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93
  273. netmask 64
  274. gateway 2a01:e0a:54:c220:OOOO:0000:000:0001
  275. </code></pre>
  276. <p>On va aussi modifier la configuration de Postfix pour permettre l'envoi de messages de l'extérieur de la machine (uniquement les utilisateurs enregistrés, bien sûr).</p>
  277. <p>J'ai modifié /etc/postfix/main.cf de la façon suivante: j'ai ajouté ceci au fichier:</p>
  278. <pre><code>smtpd_recipient_restrictions =
  279. permit_sasl_authenticated,
  280. permit_mynetworks,
  281. reject_unauth_destination,
  282. check_policy_service unix:private/policyd-spf
  283. </code></pre>
  284. <p>et commenté les lignes correspondantes dans la section submission et smtps du fichier /etc/postfix/master.cf:</p>
  285. <pre><code># -o smtpd_sender_restrictions=$mua_sender_restrictions
  286. </code></pre>
  287. <p>J'ai simplement transféré les restrictions <strong>smtpd_sender_restrictions</strong> qui étaient dans main.cf dans master.cf.</p>
  288. <p>Après modifications, tout marche comme il faut, vérification SPF comprise.</p>
  289. <pre><code>root@atom:/home/ericadmin# tail -f /var/log/mail.log
  290. May 28 11:58:06 atom dovecot: imap-login: Login: user=&lt;ericadmin&gt;, method=PLAIN, rip=192.168.111.150, lip=192.168.111.240, mpid=1901, TLS, session=&lt;I0V6J0FtWODAqG+W&gt;
  291. May 28 11:58:26 atom postfix/smtpd[1902]: connect from adara.yojik.eu[91.121.72.10]
  292. May 28 11:58:26 atom policyd-spf[1907]: prepend Received-SPF: Pass (mailfrom) identity=mailfrom; client-ip=91.121.72.10; helo=adara.yojik.eu; envelope-from=eric@yojik.eu; receiver=&lt;UNKNOWN&gt;
  293. May 28 11:58:26 atom postfix/smtpd[1902]: C701DD004F2: client=adara.yojik.eu[91.121.72.10]
  294. May 28 11:58:26 atom postfix/cleanup[1908]: C701DD004F2: message-id=&lt;4c621385-3822-cb78-9c1d-7e9f43c3fc52@yojik.eu&gt;
  295. May 28 11:58:26 atom postfix/qmgr[867]: C701DD004F2: from=&lt;eric@yojik.eu&gt;, size=1414, nrcpt=1 (queue active)
  296. May 28 11:58:26 atom postfix/smtpd[1902]: disconnect from adara.yojik.eu[91.121.72.10] ehlo=2 starttls=1 mail=1 rcpt=1 data=1 quit=1 commands=7
  297. May 28 11:58:26 atom postfix/local[1909]: C701DD004F2: to=&lt;ericadmin@yojik.net&gt;, relay=local, delay=0.23, delays=0.21/0.01/0/0, dsn=2.0.0, status=sent (delivered to maildir)
  298. May 28 11:58:26 atom postfix/qmgr[867]: C701DD004F2: removed
  299. May 28 11:59:00 atom dovecot: imap-login: Login: user=&lt;ericadmin&gt;, method=PLAIN, rip=192.168.111.150, lip=192.168.111.240, mpid=1915, TLS, session=&lt;FoqwKkFtduDAqG+W&gt;
  300. </code></pre>
  301. <p>La ligne <strong>May 28 11:43:12 atom policyd-spf[1830]: prepend Received-SPF:Pass (mailfrom) identity=mailfrom;</strong> montre que notre contrôle SPF fonctionne comme il faut.</p>
  302. <h2 id="dkim">DKIM</h2>
  303. <p>DKIM (DomainKeys Identified Mail) est un système qui vous permet d'ajouter aux entêtes de vos émails une signature qui vous identifie et qui permet aux autres serveurs mails de la vérifier. L'entête peut être configuré pour garantir que le mail n'a pas été modifié après signature (on peut générer une clef qui signe tout ou partie du message, selon configuration)</p>
  304. <p>L'installation et la configuration de DKIM nécessite 3 étapes:</p>
  305. <h3 id="configuration-de-dkim">Configuration de DKIM</h3>
  306. <p>Nous commençons par l'installation de opendkim.</p>
  307. <pre><code>root@atom:/home/ericadmin# apt install opendkim
  308. Lecture des listes de paquets... Fait
  309. Construction de l'arbre des dépendances
  310. Lecture des informations d'état... Fait
  311. The following additional packages will be installed:
  312. dns-root-data liblua5.1-0 libmemcached11 libmemcachedutil2 libmilter1.0.1 libopendbx1 libopendbx1-sqlite3 libopendkim11 librbl1 libunbound2 libvbr2
  313. Paquets suggérés :
  314. ... etc ...
  315. </code></pre>
  316. <p>Une fois installé, nous allons configurer opendkim: cela se fait dans le fichier /etc/opendkim.conf</p>
  317. <p>Création des répertoires:</p>
  318. <pre><code>mkdir -p /etc/opendkim/keys/yojik.net/
  319. </code></pre>
  320. <p>Permissions:</p>
  321. <pre><code>chmod u=rw,go=r /etc/opendkim.conf
  322. chown -R opendkim:opendkim /etc/opendkim
  323. chmod go-rw /etc/opendkim/keys
  324. </code></pre>
  325. <p>Un fichier opendkim.conf entièrement commenté est disponible dans:</p>
  326. <pre><code>/usr/share/doc/opendkim/examples
  327. </code></pre>
  328. <p>Voici notre fichier de configuration; adaptez-le en fonction de votre domaine, bien sûr:</p>
  329. <pre><code># This is a basic configuration that can easily be adapted to suit a standard
  330. # installation. For more advanced options, see opendkim.conf(5) and/or
  331. # /usr/share/doc/opendkim/examples/opendkim.conf.sample.
  332. # Log to syslog
  333. Syslog yes
  334. # Required to use local socket with MTAs that access the socket as a non-
  335. # privileged user (e.g. Postfix)
  336. ## UMask 002
  337. # Sign for example.com with key in /etc/mail/dkim.key using
  338. # selector '2007' (e.g. 2007._domainkey.example.com)
  339. Domain yojik.net
  340. KeyFile /etc/opendkim/keys/yojik.net/yojik.private
  341. Selector yojik
  342. # Commonly-used options; the commented-out versions show the defaults.
  343. #Canonicalization simple
  344. #Mode sv
  345. #SubDomains no
  346. #ADSPAction continue
  347. # Always oversign From (sign using actual From and a null From to prevent
  348. # malicious signatures header fields (From and/or others) between the signer
  349. # and the verifier. From is oversigned by default in the Debian pacakge
  350. # because it is often the identity key used by reputation systems and thus
  351. # somewhat security sensitive.
  352. OversignHeaders From
  353. # List domains to use for RFC 6541 DKIM Authorized Third-Party Signatures
  354. # (ATPS) (experimental)
  355. #ATPSDomains example.com
  356. AutoRestart Yes
  357. AutoRestartRate 10/1h
  358. UMask 002
  359. Syslog yes
  360. SyslogSuccess Yes
  361. LogWhy Yes
  362. Canonicalization relaxed/simple
  363. ExternalIgnoreList refile:/etc/opendkim/TrustedHosts
  364. InternalHosts refile:/etc/opendkim/TrustedHosts
  365. KeyTable refile:/etc/opendkim/KeyTable
  366. SigningTable refile:/etc/opendkim/SigningTable
  367. Mode sv
  368. PidFile /var/run/opendkim/opendkim.pid
  369. SignatureAlgorithm rsa-sha256
  370. UserID opendkim:opendkim
  371. Socket inet:12301@localhost
  372. </code></pre>
  373. <p>Postix accédera à opendkim à travers le port 12301.</p>
  374. <p>Il nous reste 3 fichiers à configurer/créer, ainsi que générer les clefs privées et publiques.</p>
  375. <ul>
  376. <li>/etc/opendkim/SigningTable</li>
  377. </ul>
  378. <p>Ce fichier ne contient qu'une seule ligne:</p>
  379. <pre><code> `*@yojik.net yojik._domainkey.yojik.net`
  380. </code></pre>
  381. <ul>
  382. <li>/etc/opendkim/KeyTable</li>
  383. </ul>
  384. <p>Ce fichier ne contient qu'une seule ligne:</p>
  385. <pre><code> yojik._domainkey.yojik.net yojik.net:yojik:/etc/opendkim/keys/yojik.net/yojik.private
  386. </code></pre>
  387. <ul>
  388. <li>
  389. <p>/etc/opendkim/TrustedHosts</p>
  390. <pre><code>127.0.0.1
  391. ::1
  392. localhost
  393. yojik.net
  394. </code></pre>
  395. <p>Ne pas modifier les 3 premières lignes qui sont nécessaires à opendkim ...</p>
  396. </li>
  397. <li>
  398. <p>Création des clefs publiques et privées</p>
  399. <pre><code>cd /etc/opendkim/keys/yojik.net/
  400. opendkim-genkey -b 2048 -h rsa-sha256 -r -s yojik -d yojik.net -v
  401. </code></pre>
  402. <p>Une erreur apparaît: il nous faut installer opendkim-tools:</p>
  403. <pre><code>apt install opendkim-tools
  404. </code></pre>
  405. <p>2 fichiers sont crées: la clef publique et la clef privée. Nous allons renommer ces 2 clefs.</p>
  406. <pre><code>mv mv 201805.private yojik.private
  407. mv 201805.txt yojik.txt
  408. </code></pre>
  409. <p>Note du 9 décembre 2018: les fichiers sont crées avec les noms corrects; pas besoin de les renommer.</p>
  410. <p>On réapplique la modification des permissions:</p>
  411. <pre><code>root@atom:/etc/opendkim/keys# cd /etc
  412. root@atom:/etc# chown -R opendkim:opendkim /etc/opendkim
  413. root@atom:/etc# chmod -R go-rw /etc/opendkim/keys
  414. root@atom:/etc#
  415. </code></pre>
  416. <p>On relance opendkim pour voir s'il y a des erreurs:</p>
  417. <pre><code>systemctl restart opendkim
  418. </code></pre>
  419. <p>On lance:</p>
  420. <pre><code>netstat -tlnp
  421. </code></pre>
  422. <p>et on voit la ligne:</p>
  423. <pre><code>tcp 0 0 127.0.0.1:12301 0.0.0.0:* LISTEN 2395/opendkim
  424. </code></pre>
  425. <p>C'est bon .. le service est en place.</p>
  426. </li>
  427. </ul>
  428. <h3 id="ajout-de-dkim-a-postix">Ajout de DKIM à Postix</h3>
  429. <p>On va rajouter la gestion de DKIM à Postfix dans le fichier /etc/postfix/main.cf</p>
  430. <p>On ajoute les lignes suivantes:</p>
  431. <pre><code>milter_default_action = accept
  432. milter_protocol = 2
  433. smtpd_milters = inet:localhost:12301
  434. non_smtpd_milters = inet:localhost:12301
  435. </code></pre>
  436. <p>On relance Postfix par:</p>
  437. <pre><code>service postfix restart
  438. </code></pre>
  439. <h3 id="ajout-dun-enregistrement-dns">Ajout d'un enregistrement DNS</h3>
  440. <p>On ajoute la partie entre double-quotes du fichier /etc/opendkim/keys/yojik.net/yojik.txt à la ligne suivante:</p>
  441. <p>Attention à la syntaxe: ne pas oublier le "." derrière yojik.net!</p>
  442. <pre><code>yojik._domainkey.yojik.net.&lt;&gt;IN&lt;-&gt;TXT&lt;&gt;( "v=DKIM1; h=rsa-sha256; k=rsa; s=email; p=;")
  443. </code></pre>
  444. <p>Ajouter la clef derrière p= (supprimer les doubles quotes du début, milieu et fin de clef: ex:</p>
  445. <pre><code>"ljjoj" "dfjj")
  446. </code></pre>
  447. <h3 id="test-de-opendkim">Test de Opendkim</h3>
  448. <pre><code>opendkim-testkey -d yojik.net -s yojik
  449. </code></pre>
  450. <p>Si votre clef est de longueur 2048, il va falloir la découper ... et utiliser le format "multi-lignes" comme ce qui suit:</p>
  451. <h3 id="notes">Notes</h3>
  452. <ul>
  453. <li>Une chose à vérifier: le point "." à la fin du nom de domaine (première partie de la ligne). Les messages d'erreur style "erreur de syntaxe" n'aident pas beaucoup ...</li>
  454. </ul>
  455. <p>Cette fois-ci, tout est bon.</p>
  456. <ul>
  457. <li>J'ai adopté une technique pour coller ma clef dans l'enregistrement dns: je fais un:<pre><code>cat fichier_de_zone fichier_de_clef &gt; fichier_de_zone.new
  458. </code></pre>
  459. </li>
  460. </ul>
  461. <p>J'édite le fichier (les retours-chariot etc ...) et je remplace le fichier original (que je sauve d'abord) en incrémentant le numero de série dans le fichier.</p>
  462. <h3 id="nouveau-test">Nouveau Test</h3>
  463. <p>On envoie un message pour voir s'il est bien signé.</p>
  464. <p>Je redémarre le serveur et j'envoie un message.</p>
  465. <p>Voilà les résultats:</p>
  466. <pre><code>&gt; ARC-Authentication-Results: i=1; mx.google.com;
  467. &gt; dkim=pass header.i=@yojik.net header.s=yojik header.b=CE0b13ii;
  468. &gt; spf=pass (google.com: domain of ericadmin@yojik.net designates 82.64.48.5 as permitted sender) &gt; smtp.mailfrom=ericadmin@yojik.net
  469. &gt; Received-SPF: pass (google.com: domain of ericadmin@yojik.net designates 82.64.48.5 as permitted sender) &gt; client-ip=82.64.48.5;
  470. &gt; Authentication-Results: mx.google.com;
  471. &gt; dkim=pass header.i=@yojik.net header.s=yojik header.b=CE0b13ii;
  472. &gt; spf=pass (google.com: domain of ericadmin@yojik.net designates 82.64.48.5 as permitted sender) &gt; smtp.mailfrom=ericadmin@yojik.net
  473. &gt; Received: from [192.168.111.150] (unknown [192.168.111.150])
  474. &gt; by atom.yojik.net (Postfix) with ESMTPSA id AFB9ED004F3
  475. &gt; for &lt;ericounet26200@gmail.com&gt;; Thu, 31 May 2018 12:09:41 +0200 (CEST)
  476. &gt; DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=yojik.net; s=yojik;
  477. &gt; t=1527761381; bh=ay9Odp/rKTenfDlpDmHqBM+YFfCITM3u/keXU6iwx20=;
  478. &gt; h=To:From:Subject:Date:From;
  479. &gt; b=CE0b13iiZgEQgrd7EngBovulGeU6QnSU/cKzia42u9s9B+S/dxUsm1u7JRjBrTLLg
  480. &gt; /c/uW05pdE5QS+9y3dvZtji0hogr0H87nRpZE7QBZaFLpVWGpUTukRsJ47JskO+Cwi
  481. &gt; 4cRYjeyUOLTY8Gc8uQaiS79CDko8E107fsfoUGV8=
  482. </code></pre>
  483. <p>Tout est bon ....</p>
  484. <p><strong>IL est recommandé de changer les clefs DKIM tous les mois!</strong> ... Je pense qu'il va falloir créer des scripts pour toute la maintenance des clefs et de leur renouvellement.</p>
  485. <h2 id="adsp">ADSP</h2>
  486. <p>Author Domain Signing Practices (ADSP)Permalink (technique obsolète ...)</p>
  487. <p>Nous allons rajouter un enregistrement DNS qui va indiquer que tous les émails issus par yojik.net doivent être signés par DKIM. C'est une sécurité supplémentaire.</p>
  488. <p>La syntaxe est assez simple:</p>
  489. <pre><code> _adsp._domainkey.yojik.net. IN TXT "dkim=all"
  490. </code></pre>
  491. <ul>
  492. <li>Le paramètre dkim accepte d'autres valeurs moins strictes, mais j'ai choisi la plus stricte.</li>
  493. <li>Ne pas oublier d'incrémenter le numéro de série du fichier de zone après modification.</li>
  494. <li>
  495. <p>Rechargez bind.</p>
  496. <pre><code>service bind9 restart (ou reload)
  497. </code></pre>
  498. <p>Tout est OK.</p>
  499. </li>
  500. </ul>
  501. <p>Note: ADSP et Dmarc remplissent le même rôle. Après consultation d'experts, ADSP est "obsolète". Nous allons donc enlever ce service (commenter la ligne DNS) et configurer DMARC.</p>
  502. <h2 id="dmarc">DMARC</h2>
  503. <p>Dmarc (Domain Message Authentication, Reporting &amp; Conformance) précise les politiques d'envoi des messages issus du domaine concerné (grâce à DKIM et SPF), indique quelle politique utiliser si les conditions ne sont pas respectées (validations SPF ou DKIM , et peut éventuellement demander un rapport en cas d'échec de livraison du message.</p>
  504. <p>La mise en place de DMARC nécessite de configurer/installer opendmarc, de mettre en place l'enregistrement TXT dans le fichier de zone DNS et de configurer le <strong>hook</strong> dans Postfix.</p>
  505. <h3 id="installation-de-opendmarc">Installation de Opendmarc</h3>
  506. <pre><code>root@atom:/home/ericadmin# apt install opendmarc
  507. Lecture des listes de paquets... Fait
  508. Construction de l'arbre des dépendances
  509. Lecture des informations d'état... Fait
  510. The following additional packages will be installed:
  511. libdbd-mysql-perl libdbi-perl libencode-locale-perl libhttp-date-perl libhttp-message-perl libio-html-perl liblwp-mediatypes-perl libopendbx1-mysql libopendmarc2
  512. libspf2-2 libtimedate-perl liburi-perl publicsuffix
  513. etc ...
  514. Paramétrage de libdbd-mysql-perl (4.041-2) ...
  515. Paramétrage de opendmarc (1.3.2-2+deb9u1) ...
  516. Traitement des actions différées (« triggers ») pour libc-bin (2.24-11+deb9u3) ...
  517. Traitement des actions différées (« triggers ») pour systemd (232-25+deb9u3) ...
  518. </code></pre>
  519. <p>Voilà, opendmarc est installé. Passons à sa configuration.</p>
  520. <h3 id="configuration-de-opendmarc">Configuration de Opendmarc</h3>
  521. <p>2 fichiers sont à configurer.</p>
  522. <p>La configuration se fait dans /etc/opendmarc.conf et dans /etc/default/opendmarc:</p>
  523. <p>Comme d'habitude, faite une copie de sauvegarde du fichier d'origine avant modification.</p>
  524. <p><strong>Fichier /etc/opendmarc.conf</strong>:</p>
  525. <pre><code># This is a basic configuration that can easily be adapted to suit a standard
  526. # installation. For more advanced options, see opendkim.conf(5) and/or
  527. # /usr/share/doc/opendmarc/examples/opendmarc.conf.sample.
  528. ## AuthservID (string)
  529. ## &lt;--&gt;defaults to MTA name
  530. #
  531. # AuthservID name
  532. ## FailureReports { true | false }
  533. ## &lt;--&gt;default "false"
  534. ##
  535. # FailureReports false
  536. PidFile /var/run/opendmarc/opendmarc.pid
  537. ## RejectFailures { true | false }
  538. ## &lt;--&gt;default "false"
  539. ##
  540. RejectFailures false
  541. ## Socket socketspec
  542. ## &lt;--&gt;default (none)
  543. ##
  544. ## Specifies the socket that should be established by the filter to receive
  545. ## connections from sendmail(8) in order to provide service. socketspec is
  546. ## in one of two forms: local:path, which creates a UNIX domain socket at
  547. ## the specified path, or inet:port[@host] or inet6:port[@host] which creates
  548. ## a TCP socket on the specified port for the appropriate protocol family.
  549. ## If the host is not given as either a hostname or an IP address, the
  550. ## socket will be listening on all interfaces. This option is mandatory
  551. ## either in the configuration file or on the command line. If an IP
  552. ## address is used, it must be enclosed in square brackets.
  553. #
  554. # Socket local:/var/run/opendmarc/opendmarc.sock
  555. Socket inet:54444@localhost
  556. ## Syslog { true | false }
  557. ## &lt;--&gt;default "false"
  558. ##
  559. ## Log via calls to syslog(3) any interesting activity.
  560. #
  561. Syslog true
  562. ## SyslogFacility facility-name
  563. ## &lt;--&gt;default "mail"
  564. ##
  565. ## Log via calls to syslog(3) using the named facility. The facility names
  566. ## are the same as the ones allowed in syslog.conf(5).
  567. #
  568. # SyslogFacility mail
  569. ## TrustedAuthservIDs string
  570. ## &lt;--&gt;default HOSTNAME
  571. ##
  572. ## Specifies one or more "authserv-id" values to trust as relaying true
  573. ## upstream DKIM and SPF results. The default is to use the name of
  574. ## the MTA processing the message. To specify a list, separate each entry
  575. ## with a comma. The key word "HOSTNAME" will be replaced by the name of
  576. ## the host running the filter as reported by the gethostname(3) function.
  577. #
  578. # TrustedAuthservIDs HOSTNAME
  579. ## UMask mask
  580. ## &lt;--&gt;default (none)
  581. ##
  582. ## Requests a specific permissions mask to be used for file creation. This
  583. ## only really applies to creation of the socket when Socket specifies a
  584. ## UNIX domain socket, and to the HistoryFile and PidFile (if any); temporary
  585. ## files are normally created by the mkstemp(3) function that enforces a
  586. ## specific file mode on creation regardless of the process umask. See
  587. ## umask(2) for more information.
  588. #
  589. UMask 0002
  590. ## UserID user[:group]
  591. ## &lt;--&gt;default (none)
  592. ##
  593. ## Attempts to become the specified userid before starting operations.
  594. ## The process will be assigned all of the groups and primary group ID of
  595. ## the named userid unless an alternate group is specified.
  596. #
  597. UserID opendmarc
  598. ## Path to system copy of PSL (needed to determine organizational domain)
  599. #
  600. PublicSuffixList /usr/share/publicsuffix/
  601. IgnoreHosts /etc/opendmarc/ignore.hosts
  602. HistoryFile /var/run/opendmarc/opendmarc.dat
  603. #for testing:
  604. SoftwareHeader true
  605. </code></pre>
  606. <p>On crée le répertoire suivant: /etc/opendmarc et on crée un fichier qui va contenir la liste des machines auxquelles vous avez confiance.</p>
  607. <pre><code>root@atom:/etc# mkdir /etc/opendmarc
  608. </code></pre>
  609. <p>On crée le fichier <strong>/etc/opendmarc/ignore.hosts</strong> avec le contenu suivant (le fichier ignore.hosts a été déclaré dans le fichier /etc/opendmarc.conf):</p>
  610. <pre><code>localhost
  611. 192.168.111.0/24
  612. </code></pre>
  613. <p>Les mails envoyés par les machines listées dans ce fichier ne seront pas testés. Ici, le serveur de mail lui-même et les machines du réseau local familial.</p>
  614. <p>On ajoute la ligne suivante à /etc/default/opendmarc:</p>
  615. <pre><code>SOCKET=inet:54444@localhost
  616. </code></pre>
  617. <p>Notre daemon écoutera sur le port 54444. On relance opendmarc par la commande suivante:</p>
  618. <pre><code>service opendmarc restart
  619. </code></pre>
  620. <p>Mise en place du hook dans postfix:</p>
  621. <p>Nous modifierons les 2 lignes suivantes dans le fichier: /etc/postfix/main.cf:</p>
  622. <pre><code>smtpd_milters = inet:localhost:12301,inet:localhost:54444
  623. non_smtpd_milters = inet:localhost:12301,inet:localhost:54444
  624. </code></pre>
  625. <p>On recharge postfix (comme d'habitude ...)
  626. Configuration de l'enregistrement DNS dans le fichier de zone (ne pas oublier d'incrémenter le compteur!):</p>
  627. <pre><code>_dmarc.yojik.net. TXT ( "v=DMARC1; p=none; sp=reject; pct=10; adkim=r;aspf=r;fo=1;ri=86400;rua=mailto:ericadmin@yojik.net")
  628. </code></pre>
  629. <p>Test d'envoi de messages:</p>
  630. <pre><code>Authentication-Results: atom.yojik.net; dmarc=**pass**
  631. </code></pre>
  632. <p>Ça fonctionne :)</p>
  633. </div>
  634. </div>
  635. <footer>
  636. <hr/>
  637. <div role="contentinfo">
  638. <!-- Copyright etc -->
  639. </div>
  640. 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>.
  641. </footer>
  642. </div>
  643. </div>
  644. </section>
  645. </div>
  646. <div class="rst-versions" role="note" aria-label="versions">
  647. <span class="rst-current-version" data-toggle="rst-current-version">
  648. </span>
  649. </div>
  650. <script>var base_url = '../../..';</script>
  651. <script src="../../../js/theme.js" defer></script>
  652. <script src="../../../search/main.js" defer></script>
  653. <script defer>
  654. window.onload = function () {
  655. SphinxRtdTheme.Navigation.enable(true);
  656. };
  657. </script>
  658. </body>
  659. </html>