5332
Commentaire: Lien vers la version longue...
|
5991
Mise à jour
|
Texte supprimé. | Texte ajouté. |
Ligne 1: | Ligne 1: |
[[TableOfContents]] |
|
Ligne 2: | Ligne 4: |
Ou comment gérer les mails que l'on reçoit à l'aide des outils présents sur zamok. | Ou comment gérer les mails que l'on reçoit à l'aide des outils présents sur {{{ssh.crans.org}}}. |
Ligne 5: | Ligne 7: |
* Se connecter à zamok par ssh : WikiInformatique/ConnexionSsh * Utiliser un éditeur de texte en ligne de commande (nano, vi, pico, jed, etc. ) |
* Se connecter à {{{ssh.crans.org}}} : WikiInformatique/ConnexionSsh * Utiliser un éditeur de texte en ligne de commande (nano, jed, emacs, vi, etc. ) |
Ligne 9: | Ligne 11: |
Il s'agit de dire à un serveur de mail de transmettre automatiquement les emails reçus à une adresse vers une autre adresse. Il suffit pour cela d'éditer le fichier {{{.forward}}} dans votre home sur zamok. Exemple pas à pas : | Il s'agit de dire à un serveur de mail de transmettre automatiquement les emails reçus à une adresse vers une autre adresse. Il suffit pour cela d'éditer le fichier {{{.forward}}} dans votre home sur {{{ssh.crans.org}}}. Exemple pas à pas : |
Ligne 15: | Ligne 17: |
Dans ce cas, le serveur zamok du CR@NS transmet les mails destinés à ton adresse {{{login@crans.org}}} vers {{{mon_login@mon_adresse_préférée.org}}}. Pour annuler la redirection, il suffit de supprimer le fichier {{{.forward}}} (taper {{{rm .forward}}}) | Dans ce cas, le serveur du CR@NS transmet les mails destinés à ton adresse {{{login@crans.org}}} vers {{{mon_login@mon_adresse_préférée.org}}}. Pour annuler la redirection, il suffit de supprimer le fichier {{{.forward}}} (taper {{{rm .forward}}}) |
Ligne 19: | Ligne 21: |
/!\ Le mode de stoquage des mails de nos serveurs est le ''maildir'' pour spécifier ce type de stoquage il faut mettre un '/' à la fin des redirections. Exemple : {{{ # mail dans une mbox : :0 Mail/mbox #mail dans un maildir : :0 Mail/.maildir/ }}} |
|
Ligne 66: | Ligne 78: |
Mail/Spam | Mail/.Spam/ |
Ligne 78: | Ligne 91: |
Mail/Spam | Mail/.Spam/ |
Ligne 105: | Ligne 118: |
Une catégorie particulièrement intéressante de filtre est les filtres bayésiens, ces fameux filtres qui "apprennent". Pour cela, il faut une base de données de messages non-spam (ham) et de spam, pour bien faire la différence. Il est conseillé de faire travailler spamassassin sur vos propres messages afin que les informations apprises correspondent a ce que vous recevez. | Une catégorie particulièrement intéressante de filtres est celle des filtres bayésiens, ces fameux filtres qui "apprennent". Pour cela, il faut une base de données de messages non-spam (ham) et de spam, pour bien faire la différence. Il est conseillé de faire travailler spamassassin sur vos propres messages afin que les informations apprises correspondent à ce que vous recevez. SpamAssassin envoie automatiquement les mails les plus louches ainsi que les mails les plus corrects à l'apprentissage. Le problème, c'est que les mails qu'il reconnait mal induisent des erreurs dans la base (ie: il va apprendre comme spam un message qu'il a mal reconnu et qui était en fait du ham). Pour améliorer ses performances, il faut donc classer à la main les mails erronés dans des ''maildir'' puis les lui faire apprendre avec {{{sa-learn}}}. |
Ligne 109: | Ligne 126: |
sa-learn --spam /path/to/spam/folder sa-learn --ham /path/to/ham/folder |
sa-learn --spam ~/Mail/.spam_folder/new/* sa-learn --ham ~/Mail/.ham_folder/new/* |
Ligne 113: | Ligne 130: |
Si on fournit pas d'exemples aux filtres bayésiens, spam assassin envoit automatiquement les mails les plus louches et les mails les plus corrects à l'apprentissage. | Si les ''maildir'' contiennent beaucoup de messages, leur traitement peut être long, on peut ajouter l'option {{{--showdots}}} pour avoir un barre de progression. |
Ligne 115: | Ligne 132: |
Les filtres bayésiens ne s'activent que lorsque la base de données est suffisamment grande (plusieurs centaines de messages de chaque catégorie). On peut dire à spamassassin qu'il s'est trompé sur un message. Il suffit pour cela de réentrainer le logiciel avec le bon paramètre (ham ou spam). |
SpamAssassin sait quels mails il a déjà appris, on peut donc lui demander d'apprendre le même ''maildir'' toutes les semaines sans tronquer les statistiques. |
Les mails au CR@NS
Ou comment gérer les mails que l'on reçoit à l'aide des outils présents sur ssh.crans.org.
Prérequis:
Se connecter à ssh.crans.org : WikiInformatique/ConnexionSsh
- Utiliser un éditeur de texte en ligne de commande (nano, jed, emacs, vi, etc. )
Forwarder les mails vers une nouvelle adresse
Il s'agit de dire à un serveur de mail de transmettre automatiquement les emails reçus à une adresse vers une autre adresse. Il suffit pour cela d'éditer le fichier .forward dans votre home sur ssh.crans.org. Exemple pas à pas :
- Se connecter à zamok, vous obtenez un shell (i.e. une ligne de commande)
cat > .forward [Appuyer sur Entrée]
mon_login@mon_adresse_préférée.org [Appuyer sur Entrée]
[Ctrl-D]
logout [Appuyer sur Entrée] C'est pour se déconnecter.
Dans ce cas, le serveur du CR@NS transmet les mails destinés à ton adresse login@crans.org vers mon_login@mon_adresse_préférée.org. Pour annuler la redirection, il suffit de supprimer le fichier .forward (taper rm .forward)
Utiliser Procmail
Procmail sert à faire des trucs plus compliqués avec ses mails : filtrage, redirection, programmes externes, etc.
Le mode de stoquage des mails de nos serveurs est le maildir pour spécifier ce type de stoquage il faut mettre un '/' à la fin des redirections. Exemple :
# mail dans une mbox : :0 Mail/mbox #mail dans un maildir : :0 Mail/.maildir/
Le fichier utilisé est ~/.procmailrc. Sa syntaxe est la suivante:
:0 [flags] [ : [local_lock_file] ] * <conditions> <exactly one action line>
Les conditions utilisées sont (en général) des expressions régulières (man egrep) avec un ET sous entendu. Par défaut, procmail utilise les headers du mail, en ignorant les majuscules. Le flag c permet de faire des copies d'un mail.
Les actions possibles sont:
! forward vers les adresses mail suivantes
| envoie le mail vers un programme
{ sous bloc de règles. Ne pas oublier un caractère espace après le {
Par exemple:
:0: * ^Subject: .*travail ! adresse@profession.com
Utiliser SpamAssassin
La version longue de la manière de lutter contre le SPAM et l'utilisation de Spamassassin au CR@NS se trouve sur cette [http://www.crans.org/docs/Spamfilter.html page].
Préliminaires
Commencer par mettre en place un .forward vers procmail:
"| exec /usr/bin/procmail"
Ceci redirige tous les mails vers procmail qui va ensuite faire le tri. C'est procmail qui appelle Spam Assassin, et qui déplace (le cas échéant) les mails dans le bon répertoire.
Mails lus en IMAP
Si vous lisez vos mails en IMAP, la gestion des répertoires se fait sur le serveur, donc procmail peut déplacer le spam dans un dossier, ici Mail/Spam.
Contenu du .procmailrc
# On pipe vers SpamAssassin # f is for filter, h header and b body piped to spamassassin and W for check :0 Whbf * < 256000 | spamc # Si c'est du spam, ça part dans la mbox associée : :0 : * ^X-Spam-Status: Yes Mail/.Spam/ # Si le serveur distant est blacklisté, et si spamassassin n'a pas reconnu le mail comme spam, # on réécrit le sujet et on redirige tout vers le dossier Spam. # E is for preceding condition did not match (else if) :0 E * ^X-Reject: 554 { :0 Whf * ^Subject:\/.* | formail -i "Subject: *****SPAM***** $MATCH" :0 : Mail/.Spam/ }
Mails lus en POP
Là il faudra se contenter de tagger l'entête du message, ou son sujet, et donc d'utiliser un filtre de message dans votre logiciel de messagerie préféré (Mozilla Thunderbird).
# On pipe tout le mail de taille inférieure à 256Ko vers spamc, le client du daemon spamassassin : :0 Whbf * < 256000 | spamc # Si le serveur distant est blacklisté, et si spamassassin n'a pas reconnu le mail comme spam, # on réécrit le sujet pour tagguer le mail. :0 * ^X-Reject: 554 * !^X-Spam-Status: Yes { :0 Whf * ^Subject:\/.* | formail -i "Subject: *****SPAM***** $MATCH" }
Calculs des scores et Filtres Bayésiens
Spam assassin utilise différents filtres qui donnent un score à un mail. Si le score est suffisamment élevé, le mail est considéré comme du spam.
Une catégorie particulièrement intéressante de filtres est celle des filtres bayésiens, ces fameux filtres qui "apprennent". Pour cela, il faut une base de données de messages non-spam (ham) et de spam, pour bien faire la différence. Il est conseillé de faire travailler spamassassin sur vos propres messages afin que les informations apprises correspondent à ce que vous recevez.
SpamAssassin envoie automatiquement les mails les plus louches ainsi que les mails les plus corrects à l'apprentissage. Le problème, c'est que les mails qu'il reconnait mal induisent des erreurs dans la base (ie: il va apprendre comme spam un message qu'il a mal reconnu et qui était en fait du ham).
Pour améliorer ses performances, il faut donc classer à la main les mails erronés dans des maildir puis les lui faire apprendre avec sa-learn.
Commandes:
sa-learn --spam ~/Mail/.spam_folder/new/* sa-learn --ham ~/Mail/.ham_folder/new/*
Si les maildir contiennent beaucoup de messages, leur traitement peut être long, on peut ajouter l'option --showdots pour avoir un barre de progression.
SpamAssassin sait quels mails il a déjà appris, on peut donc lui demander d'apprendre le même maildir toutes les semaines sans tronquer les statistiques.
Configuration de spamassassin
Consulter le fichier .spamassassin/user_prefs
Liens utiles
[http://www.procmail.org/ procmail]
[http://www.spamassassin.org/ spamassassin]