]> gitweb.pimeys.fr Git - config-20-100.git/blobdiff - .procmailrc
Merge branch 'master' into perso
[config-20-100.git] / .procmailrc
index a86340793f89c80abce341d8fdcc712b14d9cc8d..6916b27e72a505f9b2961824ffaa19d033d3732b 100644 (file)
 #  * Le troisième, custom.final.rules est appliqué tout à la fin, il peut par
 #    exemple servir à définir un dossier par défaut autre que .INBOX
 
+# Attention, certaines règles (pour l'instant commentées par #~#)
+# font appel à des scripts.
+# Pour qu'elles fonctionnent correctement, il faut que vous
+# possédiez les scripts correspondant et que vous adaptiez
+# la partie "Scripting" des variables de configuration.
+# (cf https://wiki.crans.org/VieCrans/FichiersConfiguration#scripting)
 
 
 ################################################################################
 #   |    |
 #   |    |-[+] Nagios (Comme Monit, mais en mieux/moins bien/différent)
 #   |    |     |
-#   |    |     |- <un dossier pour tousles switchs et un dossier par serveur>
+#   |    |     |- <un dossier pour tous les switchs, un pour toutes les bornes, puis un dossier par serveur>
 #   |    |
 #   |    |-[+B] Stats-upload (Qui a uplodé ?)
 #   |
 #################################################################
 ##                   Variables d'environnement                 ##
 #################################################################
+### Paths
 # Path du dossier où sont rangés les mails
 MAILDIR="${HOME}/Mail"
-# Shell à utiliser pour exécuter des commandes
-SHELL="/bin/bash"
 # Dossier contenant tout le garbage procmail-related
 # (le .procmailrc lui-même est dans le home)
 PROCMAILDIR="${HOME}/.procmail"
@@ -240,6 +245,16 @@ CONFIGDIR="${PROCMAILDIR}/rc"
 LOGFILE="${PROCMAILDIR}/logs/procmail.log"
 
 
+### Scripting
+# Shell à utiliser pour exécuter des commandes
+SHELL="/bin/bash"
+## Scripts
+# Dossier où sont rangés les scripts
+SCRIPTSFOLDER="${HOME}/scripts/crans_toolbox/"
+# Scripts pour décoder les headers MIME
+DECODEHEADERSCRIPT="${SCRIPTSFOLDER}decode_header.pl"
+
+
 #################################################################
 ##                      Noms de dossiers                       ##
 #################################################################
@@ -297,6 +312,7 @@ MONITORINGDIR="${CRANSDIR}.Monitoring"
 MONITDIR="${MONITORINGDIR}.Monit"
 NAGIOSDIR="${MONITORINGDIR}.Nagios"
 NAGIOSSWITCHSDIR="${NAGIOSDIR}.0-switchs"
+NAGIOSBORNESDIR="${NAGIOSDIR}.1-bornes"
 ARPWATCHDIR="${MONITORINGDIR}.Arpwatch"
 MUNINDIR="${MONITORINGDIR}.Munin"
 MUNINIMPRESSIONDIR="${MUNINDIR}.Imprimante"
@@ -456,14 +472,19 @@ INCLUDERC="${CONFIGDIR}/custom.high.rules"
 :0
 * ^(From: nagios@crans\.org|User-Agent:.*nagios)
 {
-  # Tous les switchs vont dans le dossier ${NAGIOSSWITCH}
+  # Tous les switchs vont dans le dossier ${NAGIOSSWITCHSDIR}
   :0
-  * ^Subject:.*Alert: bat[^/]+-
+  * ^Subject:.*[A-Z]+ - (bat[a-z]-[0-9]+|backbone|minigiga)\.
   ${NAGIOSSWITCHSDIR}/
   
+  # Toutes les bornes vont dans le dossier ${NAGIOSBORNESDIR}
+  :0
+  * ^Subject:.* [A-Z]+ - [a-z0-9](-*[a-z0-9]+)*\.wifi\.crans\.org
+  ${NAGIOSBORNESDIR}/
+  
   # Chaque serveur a son dossier
   :0
-  * ^Subject:.*Alert: \/[^/\.]+
+  * ^Subject:.* [A-Z]+ - \/[a-z0-9](-*[a-z0-9]+)*
   ${NAGIOSDIR}.${MATCH}/
   
   # Si l'envie prenait à Nagios de raconter un peu plus sa vie
@@ -514,7 +535,7 @@ INCLUDERC="${CONFIGDIR}/custom.high.rules"
 
 # On matche tous les alias de root@crans.org
 :0
-* ^(To|Cc): .*(root|abuse|amavis|backup|bind|bin|clamav|daemon|ftpadm|ftpmaster|ftp-mirror|ftp|games|gnats|irc|list|logcheck|lp|mail|majordom|man|msql|munin|news|operator|postgres|proxy|sync|sys|usenet|uucp|webmaster|www-clubs|www-data|www-perso|postmaster|mailer-daemon)@(crans\.org|crans\.ens-cachan\.fr)
+* ^(To|Cc):.* (root|abuse|amavis|backup|bind|bin|clamav|daemon|ftpadm|ftpmaster|ftp-mirror|ftp|games|gnats|irc|list|logcheck|lp|mail|majordom|man|msql|munin|news|operator|postgres|proxy|sync|sys|usenet|uucp|webmaster|www-clubs|www-data|www-perso|postmaster|mailer-daemon)@(crans\.org|crans\.ens-cachan\.fr)
 {
   # Spam de logcheck
   :0
@@ -684,7 +705,7 @@ INCLUDERC="${CONFIGDIR}/custom.high.rules"
 {
   # Statistiques d'upload
   :0
-  * ^X-Mailer: /usr/scripts/surveillance/statistiques.py
+  * ^X-Mailer: /usr/scripts/surveillance/statistiques2.py
   ${STATUPLOADDIR}/
   
   :0
@@ -722,13 +743,21 @@ ${CABLAGEDIR}/
   ${PRINTERWATCHDIR}/
 }
 
+
 # Sur la ML respbats@
+# L'ancienne version de ce filtre ne fonctionne plus car les headers
+# de ces mails sont maintenant correctement encodé.
+# C'est bien pour le respect des RFC, mais c'est un peu pain in the ass
+# p our le trier avec procmail, donc on besoin d'un script
+# Ne pas décommenter si vous n'avez pas le script associé.
+# (cf https://wiki.crans.org/VieCrans/FichiersConfiguration#scripting)
 :0
 * ^List-Id:.*respbats\.lists\.crans\.org
+* ^X-Mailer:\/.*
 {
   # Machines supprimées pour chambre invalide
   :0
-  * ^X-Mailer: /usr/scripts/gestion/chambres_vides.py
+  * ? echo "${MATCH}" | ${DECODEHEADERSCRIPT} | grep /usr/scripts/gestion/chambres_vides.py
   ${DELETEDMACHINES}/
 }
 
@@ -961,9 +990,13 @@ INCLUDERC="${CONFIGDIR}/custom.normal.rules"
   ##              Gestion des autres mailing-listes              ##
   #################################################################
   # On récupère le nom de domaine et le nom de la ML
+  # Le nom de domaine, c'est le mot (sans .) qui précède le TLD
   DOMAIN=`echo "${ML}" | sed 's/.*\.\([^\.]\+\)\.[^\.]\+$/\1/'`
   # On ne sait jamais ce qu'on peut rencontrer…
   DOMAIN_=`echo "${DOMAIN}" | sed 's/ /_/g'`
+  # On vire le domain et le TLD
+  # On vire .list ou .lists si c'est la composante la plus à droite
+  # du subdomain
   # On prend garde à ne pas créer un sous-dossier
   # si jamais le List-Id contient un . ou un espace
   ML_=`echo "${ML}" | sed 's/\.[^\.]\+\.[^\.]\+$//;s/\.lists\?$//;s/\(\.\| \)/_/g'`