]> gitweb.pimeys.fr Git - config-20-100.git/blobdiff - .procmailrc
Décodage des headers avec un oneliner : adieu la dépendance à un script
[config-20-100.git] / .procmailrc
index ec56e76021a898459f04bc9e303656551cb4ee2a..280b61201873640580f492b2e88fb15a59b9fd14 100644 (file)
@@ -44,7 +44,6 @@
 #    exemple servir à définir un dossier par défaut autre que .INBOX
 
 
-
 ################################################################################
 #####                             Commentaires                             #####
 ################################################################################
 #   |    |
 #   |    |-[+] 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 +238,11 @@ CONFIGDIR="${PROCMAILDIR}/rc"
 LOGFILE="${PROCMAILDIR}/logs/procmail.log"
 
 
+### Scripting
+# Shell à utiliser pour exécuter des commandes
+SHELL="/bin/bash"
+
+
 #################################################################
 ##                      Noms de dossiers                       ##
 #################################################################
@@ -297,6 +300,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"
@@ -385,18 +389,33 @@ FEDEREZOVHDIR="${FEDEREZADMINDIR}.OVH"
 
 
 
+################################################################################
+#####                            Preprocessing                             #####
+################################################################################
+
+# On décode les champs sur lesquels ont pourrait avoir besoin de matcher
+# plus tard la version décodée. On stocke les versions décodées
+# dans des variables.
+# "formail -cXHeader" récupère le champ Header (-X) en enlevant les \n (-c)
+# si le champ fait plusieurs lignes
+:0
+* ^X-Mailer:
+XMAILER=| formail -cXX-Mailer: | perl -MEncode -pe '$_=encode("iso-8859-1",decode("MIME-Header",$_))'
+
+
+
 ################################################################################
 #####                                Règles                                #####
 ################################################################################
 
-#~# # Patch pour traiter les mails qui ont été
-#~# # reçus avant le 30/06/13, car certaines règles de tri du .procmailrc
-#~# # n'étaient pas encore valables à l'époque.
-#~# # très utile si on veut retrier tous ses mails
-#~# INCLUDERC="${CONFIGDIR}/retrocompatibility_patch.rules"
+# Patch pour traiter les mails qui ont été
+# reçus avant le 30/06/13, car certaines règles de tri du .procmailrc
+# n'étaient pas encore valables à l'époque.
+# très utile si on veut retrier tous ses mails
+INCLUDERC="${CONFIGDIR}/retrocompatibility_patch.rules"
 
-#~# # Fichier de règles prioritaires à personnaliser
-#~# INCLUDERC="${CONFIGDIR}/custom.high.rules"
+# Fichier de règles prioritaires à personnaliser
+INCLUDERC="${CONFIGDIR}/custom.high.rules"
 
 #################################################################
 ##                Gestion des mails d'Arpwatch                 ##
@@ -456,14 +475,19 @@ FEDEREZOVHDIR="${FEDEREZADMINDIR}.OVH"
 :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
@@ -482,9 +506,9 @@ FEDEREZOVHDIR="${FEDEREZADMINDIR}.OVH"
 * ^To:.*(roots?|postgres|www-data|list)@crans\.org
 * ^(X-Cron-Env|From: Anacron)
 {
-  #~# # Par défaut, on ne trie pas les mails de Cron, pensez à décommenter
-  #~# # le INCLUDERC (et à copier le fichier complémentaire) pour les trier
-  #~# INCLUDERC=${CONFIGDIR}/cron.rules
+  # Par défaut, on ne trie pas les mails de Cron, pensez à décommenter
+  # le INCLUDERC (et à copier le fichier complémentaire) pour les trier
+  INCLUDERC=${CONFIGDIR}/cron.rules
   
   :0
   ${CRONDIR}/
@@ -514,7 +538,7 @@ FEDEREZOVHDIR="${FEDEREZADMINDIR}.OVH"
 
 # 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 +708,7 @@ FEDEREZOVHDIR="${FEDEREZADMINDIR}.OVH"
 {
   # Statistiques d'upload
   :0
-  * ^X-Mailer: /usr/scripts/surveillance/statistiques.py
+  * ^X-Mailer: /usr/scripts/surveillance/statistiques2.py
   ${STATUPLOADDIR}/
   
   :0
@@ -722,13 +746,15 @@ ${CABLAGEDIR}/
   ${PRINTERWATCHDIR}/
 }
 
+
 # Sur la ML respbats@
+# On utilise la variable XMAILER peuplée dans la phase de Preprocessing
 :0
 * ^List-Id:.*respbats\.lists\.crans\.org
 {
   # Machines supprimées pour chambre invalide
   :0
-  * ^X-Mailer: /usr/scripts/gestion/chambres_vides.py
+  * XMAILER ?? /usr/scripts/gestion/menage/chambres_invalides.py
   ${DELETEDMACHINES}/
 }
 
@@ -763,8 +789,8 @@ ${CABLAGEDIR}/
 #################################################################
 ##              Inclusion des règles personnelles              ##
 #################################################################
-#~# # Fichier de règles à personnaliser
-#~# INCLUDERC="${CONFIGDIR}/custom.normal.rules"
+# Fichier de règles à personnaliser
+INCLUDERC="${CONFIGDIR}/custom.normal.rules"
 
 #################################################################
 ##                Gestion des mails de Mailman                 ##
@@ -866,7 +892,7 @@ ${CABLAGEDIR}/
     
     # MLs Med
     :0
-    * ? echo "${ML}" | grep med
+    * ? echo "${ML}" | grep -E "^med"
     ${MLMEDDIR}.${ML_}/
     
     # MLs SDA
@@ -961,9 +987,13 @@ ${CABLAGEDIR}/
   ##              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'`
@@ -971,5 +1001,5 @@ ${CABLAGEDIR}/
   ${MLDIR}.${DOMAIN_}.${ML_}/
 }
 
-#~# # Fichier de règles de faible priorité à personnaliser
-#~# INCLUDERC="${CONFIGDIR}/custom.final.rules"
+# Fichier de règles de faible priorité à personnaliser
+INCLUDERC="${CONFIGDIR}/custom.final.rules"