<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Le blog à Nono &#187; postfix</title>
	<atom:link href="http://blogs.glou.org/arnaud/tag/postfix/feed/" rel="self" type="application/rss+xml" />
	<link>http://blogs.glou.org/arnaud</link>
	<description>C'est l'histoire d'un geek...</description>
	<lastBuildDate>Tue, 03 Aug 2010 16:01:04 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Alias mail et LDAP</title>
		<link>http://blogs.glou.org/arnaud/2010/03/26/alias-mail-et-ldap/</link>
		<comments>http://blogs.glou.org/arnaud/2010/03/26/alias-mail-et-ldap/#comments</comments>
		<pubDate>Fri, 26 Mar 2010 20:34:06 +0000</pubDate>
		<dc:creator>nono</dc:creator>
				<category><![CDATA[geekeries]]></category>
		<category><![CDATA[LDAP]]></category>
		<category><![CDATA[mail]]></category>
		<category><![CDATA[postfix]]></category>
		<category><![CDATA[python]]></category>

		<guid isPermaLink="false">http://blogs.glou.org/arnaud/?p=183</guid>
		<description><![CDATA[- Dis, Nono, comment on fait pour gérer des alias mail avec un annuaire LDAP ?
- Bouge pas mon gars, je te sers un café et je te montre.
Les fiches LDAP
Chez moi, une fiche LDAP peut comprendre jusqu&#8217;à 4 attributs différents liés au mail :

mail contient l&#8217;adresse « officielle » de l&#8217;utilisateur
mailLocalAddress contient ses alias locaux [...]]]></description>
			<content:encoded><![CDATA[<p><em>- Dis, Nono, comment on fait pour gérer des alias mail avec un annuaire LDAP ?</em><br />
<em>- Bouge pas mon gars, je te sers un café et je te montre.</em></p>
<h1>Les fiches LDAP</h1>
<p>Chez moi, une fiche LDAP peut comprendre jusqu&#8217;à 4 attributs différents liés au mail :</p>
<ul>
<li><em>mail</em> contient l&#8217;adresse « officielle » de l&#8217;utilisateur</li>
<li><em>mailLocalAddress</em> contient ses alias locaux ; ils seront réécrits et remplacés par la valeur de l&#8217;attribut <em>mail</em> en sortie de site</li>
<li><em>mailAcceptingAddress</em> contient des alias « en réception seule », typiquement pour les groupes de travail</li>
<li><em>mailRoutingAddress</em> contient la destination des messages envoyés aux <em>mailAcceptingAddress</em> et <em>mailLocalAddress</em> de la fiche</li>
</ul>
<p>En termes de schéma LDAP, nous avons ajouté ça au schéma de base d&#8217;OpenLDAP :</p>
<pre>attributetype ( 1.3.6.1.4.1.7568.1.1.10
    NAME 'mailAcceptingAddress'
    DESC 'RFC822 alternate email address of this recipient'
    EQUALITY caseIgnoreIA5Match
    SYNTAX 1.3.6.1.4.1.1466.115.121.1.26{256} )

objectclass ( 1.3.6.1.4.1.7568.1.2.2 NAME 'ircamLocalMailRecipient' AUXILIARY
    DESC ''
    MAY ( mailAcceptingAddress ) )

objectclass ( 1.3.6.1.4.1.7568.1.2.10 NAME 'ircamAlias' SUP top STRUCTURAL
    DESC ''
    MAY ( mailRoutingAddress ) )</pre>
<p>La classe d&#8217;objet <em>ircamAlias</em> ne sert que pour la gestion des alias indépendants des utilisateurs (listes de diffusion et redirections « vers l&#8217;extérieur » notamment). Nous allons la laisser de côté pour le moment.<br />
Concrètement, un utilisateur ressemble à ça :</p>
<pre>dn: uid=empion, ou=People, dc=example, dc=com
objectClass: account
objectClass: top
objectClass: inetLocalMailRecipient
objectClass: ircamLocalMailRecipient
objectClass: inetOrgPerson
objectClass: pilotPerson
objectClass: ircamAccount
objectClass: shadowAccount
objectClass: organizationalPerson
objectClass: person
objectClass: ircamPerson
uid: empion
mailRoutingAddress: empion@mailboxes.example.com
mailAcceptingAddress: tout-le-monde@example.com
mailAcceptingAddress: groupe-de-travail@example.com
mailLocalAddress: tartempion@example.com
mailLocalAddress: tarte.empion@example.com
mail: Tarte.Empion@example.com
sn: Empion
cn: Tarte Empion
uidNumber: 12345
gidNumber: 333</pre>
<h1>La configuration de Postfix</h1>
<p>Postfix, c&#8217;est bien. Si, si. Je sais que vous en êtes déjà convaincus, mais c&#8217;est encore une occasion de le dire. Pour utiliser ce qui précède, il suffit de ces quelques lignes de config dans <em>main.cf</em> :</p>
<pre>sender_canonical_classes = envelope_sender, header_sender
sender_canonical_maps = ldap:ldapcanon
ldapcanon_server_host = ldap.example.com
ldapcanon_server_port = 389
ldapcanon_search_base = dc=example,dc=com
ldapcanon_query_filter = (&#038;(mailLocalAddress=%s)(mail=*))
ldapcanon_result_attribute = mail

virtual_maps = ldap:ldapvirt
ldapvirt_server_host = ldap.example.com
ldapvirt_server_port = 389
ldapvirt_search_base = dc=example,dc=com
ldapvirt_query_filter = (|(mailLocalAddress=%s)(mailAcceptingAddress=%s))
ldapvirt_result_attribute = mailRoutingAddress</pre>
<p>C&#8217;est tout, rien de tordu à faire. Une fois ce bout de config en place, l&#8217;adresse source <em>tartempion@example.com</em> sera réécrite en <em>Tarte.Empion@example.com</em> (techniquement, <em>tarte.empion@example.com</em> sera réécrite aussi, mais ça ne fera ni chaud ni froid à la plupart des systèmes de courrier électronique actuels), et les messages envoyés à <em>tarte.empion@example.com</em>, <em>tartempion@example.com</em>, <em>tout-le-monde@example.com</em> et <em>groupe-de-travail@example.com</em> seront renvoyés à <em>empion@mailboxes.example.com</em> (et éventuellement à d&#8217;autres si ces mêmes alias sont aussi définis dans d&#8217;autres fiches). Elle est pas belle, la vie ?</p>
<h1>Les scripts</h1>
<p>OK, maintenant on sait à quoi les données peuvent ressembler, mais est-ce qu&#8217;il y a un outil plus simple que ldapvi pour les mettre dans l&#8217;annuaire ? Oui et non. J&#8217;ai bricolé récemment une petite série de scripts pour éditer l&#8217;attribut <em>mailAcceptingAddress</em> d&#8217;une fiche ; en pratique, c&#8217;est le seul qui varie plus ou moins souvent, les autres sont fixés à la création du compte. Les outils en question sont téléchargeables <a href="http://files.glou.org/blog/mail-ldap-tools-20100326.tar.gz">ici</a>. L&#8217;archive contient :</p>
<ul>
<li>le module <em>ircamldap.py</em> qui initialise quelques variables utiles (serveur LDAP, mot de passe admin&#8230;)</li>
<li>son fichier de configuration <em>ircamldap.cfg</em></li>
<li>les scripts <em>add-mail-alias</em>, <em>remove-mail-alias</em> et <em>get-mail-aliases</em> qui font l&#8217;essentiel du vrai boulot.</li>
</ul>
<p>Pour l&#8217;utilisation de ces derniers, j&#8217;ai essayé de faire assez simple pour mes deux neurones ; en pratique, ça donne ça :</p>
<pre><strong>% get-mail-aliases empion</strong>
tout-le-monde@example.com
groupe-de-travail@example.com
<strong>% add-mail-alias empion monnouvelaliasquilestbien@example.net</strong>
<strong>% get-mail-aliases empion</strong>
tout-le-monde@example.com
groupe-de-travail@example.com
monnouvelaliasquilestbien@example.net
<strong>% remove-mail-alias empion monnouvelaliasquilestbien@example.net tout-le-monde@example.com</strong>
<strong>% get-mail-aliases empion</strong>
groupe-de-travail@example.com
<strong>%</strong></pre>
<p>Pour le moment, ces outils marchent à peu près mais il ne faut pas leur en demander trop. Entre autres, leur gestion des erreurs est assez minimale, et ils ne positionnent pas forcément toujours leur code de retour comme il faudrait. Ce sera pour la prochaine version. <img src='http://blogs.glou.org/arnaud/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
<p>Bien entendu, je suis preneur de toute suggestion, amélioration, patch ou autre « mais t&#8217;es con, ça fait 10 ans que ça existe en mieux ».</p>
<p><em>- Il est bizarre, ton café.<br />
- Normal, c&#8217;est une bière. Tu es admin système ou pas ?</em></p>
]]></content:encoded>
			<wfw:commentRss>http://blogs.glou.org/arnaud/2010/03/26/alias-mail-et-ldap/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Choisir le bon /usr/sbin/sendmail avec puppet</title>
		<link>http://blogs.glou.org/arnaud/2009/09/02/choisir-le-bon-usrsbinsendmail-avec-puppet/</link>
		<comments>http://blogs.glou.org/arnaud/2009/09/02/choisir-le-bon-usrsbinsendmail-avec-puppet/#comments</comments>
		<pubDate>Wed, 02 Sep 2009 09:43:57 +0000</pubDate>
		<dc:creator>nono</dc:creator>
				<category><![CDATA[geekeries]]></category>
		<category><![CDATA[postfix]]></category>
		<category><![CDATA[puppet]]></category>
		<category><![CDATA[ssmtp]]></category>

		<guid isPermaLink="false">http://blogs.glou.org/arnaud/?p=141</guid>
		<description><![CDATA[Un peu de contexte
J&#8217;utilise linux-vserver sur une poignée de machines qui hébergent chacune quelques dizaines d&#8217;instances d&#8217;OS. Dans mon installation de base (CentOS), chaque isolateur fait tourner sendmail pour envoyer le mail local vers l&#8217;extérieur ; je parle essentiellement des rapports de logwatch et autres cronneries. Avec tous les problèmes habituels en cas de forte charge, [...]]]></description>
			<content:encoded><![CDATA[<h1>Un peu de contexte</h1>
<p>J&#8217;utilise linux-vserver sur une poignée de machines qui hébergent chacune quelques dizaines d&#8217;instances d&#8217;OS. Dans mon installation de base (CentOS), chaque isolateur fait tourner sendmail pour envoyer le mail local vers l&#8217;extérieur ; je parle essentiellement des rapports de logwatch et autres cronneries. Avec tous les problèmes habituels en cas de forte charge, ce qui arrive assez facilement dans ce genre de configuration.</p>
<p>Solution : installer un <em>/usr/sbin/sendmail</em> un peu plus léger, en l&#8217;occurrence <em>ssmtp</em>, sur toutes les machines sauf les vrais serveurs SMTP, qui eux font tourner Postfix.</p>
<h1>La configuration puppet</h1>
<p>Un petit extrait de ma config (nettement plus complète mais pas publiable en l&#8217;état) :</p>
<p><code>class mail{<br />
}<br />
<br />
class mail::smtp inherits mail {<br />
<br />
        package { "ssmtp": ensure => installed, }<br />
<br />
        file { "/etc/ssmtp/ssmtp.conf":<br />
                source => [<br />
                        "puppet:///files/mail/ssmtp.conf.$hostname",<br />
                        "puppet:///mail/ssmtp.conf",<br />
                ],<br />
                owner => root,<br />
                group => root,<br />
                mode => 0644,<br />
                require => Package["ssmtp"],<br />
        }<br />
<br />
        exec { "setup_mta":<br />
                command => "/usr/sbin/update-alternatives --set mta /usr/sbin/sendmail.ssmtp",<br />
                subscribe => Package["ssmtp"],<br />
                refreshonly => true,<br />
        }<br />
<br />
}<br />
<br />
class mail::postfix inherits mail::smtp {<br />
<br />
        package { ["postfix", "postfix-pflogsumm"]: ensure => installed }<br />
<br />
        service { "postfix":<br />
                enable => true,<br />
                ensure => running,<br />
                hasstatus => true,<br />
                subscribe => Package["postfix"],<br />
        }<br />
<br />
        Exec["setup_mta"] {<br />
                command => "/usr/sbin/update-alternatives --set mta /usr/sbin/sendmail.postfix",<br />
                subscribe => Package["postfix"],<br />
        }<br />
<br />
}</code></p>
<p>L&#8217;intérêt de la chose : toutes les machines sont dans la classe <em>mail::smtp</em>, et Postfix est installé uniquement là où il faut, et surtout une même machine peut cumuler les rôles « serveur SMTP » et « autre chose » et tout se passera comme il faut.</p>
<p>Pour le moment, ça installe <em>ssmtp</em> même sur les machines où il n&#8217;est pas nécessaire, on verra à corriger ça dans la prochaine version. <img src='http://blogs.glou.org/arnaud/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://blogs.glou.org/arnaud/2009/09/02/choisir-le-bon-usrsbinsendmail-avec-puppet/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
