bionic (5) procmailex.5.gz

Provided by: manpages-es-extra_0.8a-19_all bug

NOMBRE

       procmailex - ejemplos de ficheros de recursos

SINOPSIS

       Ejemplos de $HOME/.procmailrc

DESCRIPCIÓN

       Para un descripción del formato del fichero de recursos véase procmailrc(5).

       La  técnica  de  puntuación  de  peso  se  describe  en  detalle en la página de manual de
       procmailsc(5).

       Esta página de manual muestra varios ejemplos de recetas. Por ejemplo ficheros de recursos
       completos  que  puede  comprobar en la sección NOTAS en procmail(1), o mirar a la parte de
       ejemplos   de   ficheros   de   recursos   de   la   distribución   fuente   de   procmail
       (procmail*/examples/?procmailrc).

EJEMPLOS

       Ordena  todo el correo procedente de la lista de correo scuba-dive en la carpeta de correo
       ficheroscuba (usa el fichero de bloqueo local scubafile.lock).

              :0:
              * ^TOscuba
              ficheroscuba

       Reenvía todo el correo de pedro sobre compiladores a guillermo (y mantiene una copia  aquí
       en petcompil).

              :0
              * ^From.*pedro
              * ^Subject:.*compiladores
              {
                 :0 c
                 ! guillermo@algunsitio.edu

                 :0
                 petcompil
              }

       Una solución equivalente que realiza lo mismo:

              :0 c
              * ^From.*pedro
              * ^Subject:.*compiladores
              ! guillermo@algunsitio.edu

                 :0 A
                 petcompil

       Una solución equivalente, pero ligeramente más lenta que realiza lo mismo:

              :0 c
              * ^From.*pedro
              * ^Subject:.*compiladores
              !guillermo@somewhere.edu

              :0
              * ^From.*pedro
              * ^Subject:.*compiladores
              petcompil

       Si vd. es completamente nuevo en procmail y quiere experimentar un poquito, con frecuencia
       ayuda tener una red segura de algún tipo. Inserte las dos siguientes recetas  sobre  todas
       las  otras  recetas para estar seguro de que todo el correo que llega siempre conserva los
       últimos 32 mensajes. Para que funcione como se prentende, tiene que  crear  un  directorio
       llamado `backup' en $MAILDIR antes de insertar estas dos recetas.

              :0 c
              backup

              :0 ic
              | cd backup && rm -f dummy `ls -t msg.* | sed -e 1,32d`

       Si  su  sistema  no  genera  o genera líneas `From' iniciales incorrectas en cada mensaje,
       puede corregir esto llamando a procmail con  la  opción  -f-  .  Para  corregir  el  mismo
       problema  por  medios  distintos,  podría haber insertado las dos siguientes recetas sobre
       todas las otras del fichero de recursos. Estas filtrarán la cabecera de cualquier  mensaje
       mediante  formail  que  elimina  cualquier  `From' inicial y lo regenera automáticamente a
       continuación.

              :0 fhw
              | formail -I "From " -a "From "

       Añade las cabeceras de todos los mensajes que no vienen del postmaster a su  colección  de
       cabeceras  privadas  (para  uso  estadístico  o depuración de correo); y usa el fichero de
       bloqueo `headc.lock'.  Para estar seguro de que el fichero de bloqueo no se elimina  hasta
       que  la  tubería  ha  finalizado,  tendrá  que  especificar la opción `w'; en otro caso el
       fichero de bloqueo sería eliminado tan pronto como la tubería ha aceptado el correo.

              :0 hwc:
              * !^FROM_MAILER
              | uncompress headc.Z; cat >>headc; compress headc

       O, si usara gzip, más eficiente que compress:

              :0 hwc:
              * !^FROM_MAILER
              | gzip >>headc.gz

       Reenvía todos los mensajes de menos de 1000 bytes a mi dirección personal (no se  necesita
       fichero de bloqueo en esta receta).

              :0
              * < 1000
              ! myname@home

       Divide  las  recopilaciones  de  la lista de correo surfing en mensajes individuales y los
       almacena en surfing, usando como fichero de bloqueo local surfing.lock.

              :0:
              * ^Subject:.*surfing.*Digest
              | formail +1 -ds >>surfing

       Almacena todo lo que llega del postmaster o mailer-daemon (como  correo  rebotado)  en  el
       fichero postm, usando como fichero de bloqueo local postm.lock.

              :0:
              * ^FROM_MAILER
              postm

       Una  simple  receta  de  respuesta  automática.  Se  toma la seguridad que ni el correo de
       cualquier demonio (como correo  rebotado  o  correo  de  una  lista),  ni  las  respuestas
       automáticas  procedentes  de usted mismo serán respondidas automáticamente.  Si no se toma
       esta precaución, podrían suceder desastres  (correo  en  anillo).  Para  que  esta  receta
       responda  a  todo  el correo entrante, desde luego, debería insertarla antes que cualquier
       otra receta en su fichero de recursos. Sin embargo es aconsejable ponerla  tras  cualquier
       receta  que  procese  los  correos  de  una  lista  de  correo a la que estemos suscritos;
       generalmente no es buena  idea  generar  autorespuestas  a  las  lista  de  correo(sí,  la
       expresión  regular  !^FROM_DAEMON  debería coger esos, pero si la lista de correo no sigue
       las convenciones aceptadas, esto podría no ser suficiente).

              :0 h c
              * !^FROM_DAEMON
              * !^X-Loop: your@own.mail.address
              | (formail -r -I"Precedence: junk" \
                  -A"X-Loop: su_propia@dirección.de.correo" ; \
                 echo "Mail recibido.") | $SENDMAIL -t

       Una receta de autorespuesta más complicada que lleva a cabo funciones equivalentes al bien
       conocido  programa  vacation(1)  Esta  receta  está basada en los mismos principios que la
       última (previniendo el correo en `anillo'). Además de eso, sin embargo, mantiene una  base
       de  datos  vacation  extrayendo  el  nombre  del  remitente  e  insertandolo en el fichero
       vacation.cache si el nombre es nuevo (el fichero  vacation.cache lo mantiene  formail  que
       estará  seguro  que siempre contiene los nombres más recientes, el tamaño del fichero está
       limitado a un máximo de aproximadamente 8192 bytes).  Si el nombre es nuevo, se envía  una
       respuesta automática.

       Como  puede  ver,  la siguiente receta tiene comentarios entre las condiciones.  Esto está
       permitido.  Sin embargo no ponga comentarios en la misma línea que una condición.

              SHELL=/bin/sh  # para otras shells, esto podría necesitar ajustes

              :0 Whc: vacation.lock
               # Realiza un chequeo rápido para ver si el correo va dirigido a nosotros
              * $^To:.*\<$\LOGNAME\>
               # No responde a demonios ni a listas de correo
              * !^FROM_DAEMON
               # Los bucles de correo son un desastre
              * !^X-Loop: your@own.mail.address
              | formail -rD 8192 vacation.cache

                :0 ehc         # si el nombre no está en el caché
                | (formail -rI"Precedence: junk" \
                     -A"X-Loop: your@own.mail.address" ; \
                   echo "He recibido tu correo,"; \
                   echo "pero no regresaré hasta el lunes."; \
                   echo "-- "; cat $HOME/.signature \
                  ) | $SENDMAIL -oi -t

       Almacena todos los mensajes  referentes  a  TeX  en  un  fichero  único  separado,  en  un
       directorio  llamado texmail (este directorio tiene  que existir); no hay necesidad de usar
       ficheros locales de bloqueo en este caso, por tanto no lo haremos.

              :0
              * (^TO|^Subject:.*)TeX[^t]
              texmail

       Lo mismo que arriba, salvo que  ahora  almacenamos  los  mensajes  en  ficheros  numerados
       (carpeta  de correo MH).

              :0
              * (^TO|^Subject:.*)TeX[^t]
              texmail/.

       O  podría  archivar el correo en varios carpetas directorios a la misma vez.  La siguiente
       receta entregará el correo a carpetas MH y una carpeta directorio.  Actualmente es sólo un
       fichero con dos enlaces duros extras.

              :0
              * (^TO|^Subject:.*)TeX[^t]
              texmail/. wordprocessing dtp/.

       Almacena  todos los mensajes sobre encuentros en una carpeta que está en un directorio que
       cambia  cada  mes.  V.  g.  si  fuera  Enero  de  1994,  la  carpeta  tendría  el   nombre
       `94-01/encuentros' y le fichero de bloqueo local sería `94-01/encuentros.lock'.

              :0:
              * meeting
              `date +%y-%m`/encuentros

       Lo   mismo   que   arriba,  pero  si  el  directorio  `94-01'  no  existiera,  se  crearía
       automáticamente

              CARPETAMESUAL=`date +%y-%m`

              :0 Wic
              * ? test ! -d $CARPETAMESUAL
              | mkdir $CARPETAMESUAL

              :0:
              * encuentro
              ${CARPETAMESUAL}/encuentro

       Lo mismo que arriba, pero con medios ligeramente diferentes:

              CARPETAMESUAL=`date +%y-%m`
              DUMMY=`test -d $CARPETAMESUAL || mkdir $CARPETAMESUAL`

              :0:
              * encuentros
              ${CARPETAMESUAL}/meeting

       Si está suscrito a varias listas de correo y la gente envía mesajes cruzados a  varias  de
       ellas,  normalmente  recibe  varios  correos  duplicados (uno de cada lista). La siguiente
       receta simple elimina mensajes duplicados. Le dice a formail que mantenga un fichero cache
       de  8Kb en el cual se almacenan los identificadores de mensaje de los correos más reciente
       que ha recibido. Como se garantiza que los identificadores de mensaje son únicos para cada
       mensaje,  son  ideales  para  descartar  los  mensajes  duplicados.  Simplemente  ponga la
       siguiente receta al comienzo de su fichero de recursos y ningún mensaje duplicado  logratá
       pasarla.

              :0 Wh: msgid.lock
              | formail -D 8192 msgid.cache

       Tenga  cuidado  si  tiene  problemas  de  entrega en las recetas debajo de esto y procmail
       intenta reencolar el correo, entonces en la próxima ejecución de la cola, este mensaje  se
       considerará  duplicado  y  seráeliminado.  Para  quienes  quieren seguridad pueden usar la
       siguiente receta en su lugar. Esta pone los duplicados en una carpeta separada en lugar de
       eliminarlos. Esto le obliga a vaciar periódicamente la carpeta, por supuesto.

              :0 Whc: msgid.lock
              | formail -D 8192 msgid.cache

              :0 a:
              duplicates

       Procmail  puede  entregar  a carpetas MH directamente, pero no actualiza las secuencias no
       vistas que el MH real gestiona. Si quiere que procmail actualice estas también ,  use  una
       receta  como  la siguiente que almacena todo lo que tenga la palabra spam en el cuerpo del
       mensaje en una carpeta MH llamada spamfold. Observe que el fichero de bloqueo  local,  que
       es  necesario  porque  los  progamas MH no bloquean el ficher de secuencias.  Las llamadas
       asíncronas de los progamas MH que cambian el fichero de  secuencias  pueden  corromper  el
       fichero  o  simplemente  perder  los  cambios.   Por  desgracia,  el fichero de bloqueo no
       resuelve el problema completamente ya que rcvstore se  podría  llamar  mientras  `show'  o
       `mark'  u  otro  programa  MH  está  en ejecución. El problema se epera corregir en alguna
       versión futura de MH, pero hasta entonces  tendrá  que  valorar  el  riesgo  de  perder  o
       corromper las secuencias contra lo beneficios de las secuencias no vistas.

              :0 :spamfold/$LOCKEXT
              * B ?? spam
              | rcvstore +spamfold

       Cuando  entregue  a  carpetas  emacs  (i.e.  carpetas  de correo gestionadas por cualquier
       paquete de correo de emacs, v.g.  RMAIL o  VM)  directamente,  debería  usar  ficheros  de
       bloqueo  compatibles con emacs. Los programas de correo de emacs son un poco descerebrados
       en ese respecto, se molestan mucho si alguien entrega a carpetas de correo  que  ellos  ya
       tienen  en  sus  bufferes  internos.  La  siguiente  receta  supone  que  $HOME es igual a
       /home/john.

              MAILDIR=Mail

              :0:/usr/local/lib/emacs/lock/!home!john!Mail!mailbox
              * ^Subject:.*loquesea
              mailbox

       De forma alternativa, puede hacer que procmail entrega en su propio conjunto de  carpetas,
       las  cuales  se pueden vaciar periódicamente yu copiarlas sobre sus porpios ficheros emacs
       usando  movemail.   Movemail  usa  ficheros  de  bloqueo  locales  buzón.lock  por  buzón.
       Actualmente este es el modo de operación preferido en conjunción con procmail.

       Para extraer ciertas cabeceras de un correo y pponerlas en variables de entorno puede usar
       cualquiera de las siguientes construcciones:

              SUBJECT=`formail -xSubject:`    # campo regular
              FROM=`formail -rt -xTo:`        # caso especial

              :0 h                            # método alternativo
              KEYWORDS=| formail -xKeywords:

       Si usa ficheros temporales en un fichero procmailrc, y quieres  estar  seguro  de  que  se
       eliminan antes de que procmail termine, podría usar algo como las líneas de:

              TEMPORARY=$HOME/tmp/pmail.$$
              TRAP="/bin/rm -f $TEMPORARY"

       TRAP  se  puede  usar  para modificar el código de salida de procmail.  I.e. si quiere que
       procmail devuelva un código de salida de  `1' en lugar de sus códigos de salida regulares,
       podría usar:

              EXITCODE=""
              TRAP="exit 1;"   # El punto y coma final es importante.
                               # ya que exit no es un programa standalone

       O, si el código de salida no necesita depender de la ejecución de programas de TRAP, puede
       usar un simple:

              EXITCODE=1

       La siguiente receta imprime cada correo de entrada que se parezca a un fichero postscript.

              :0 Bb
              * ^^%!
              | lpr

       La siguiente receta hace lo mismo, pero un poco más selectiva.  Sólo  imprime  el  fichero
       postscript  si  viene del servidor de impresión. La primera condición concuerda sólo si se
       encuentra en la cabecera. La segunda condición sólo concuerda al comienzo del cuerpo.

              :0 b
              * ^From[ :].*print-server
              * B ?? ^^%!
              | lpr

       Lo mismo  que arriba, pero por unos medios ligeramente diferentes:

              :0
              * ^From[ :].*print-server
              {
                :0 B b
                * ^^%!
                | lpr
              }

       Igualmente:

              :0 HB b
              * ^^(.+$)*From[ :].*print-server
              * ^^(.+$)*^%!
              | lpr

       Supongamos que tiene dos cuentas y usa  esas  dos  cuentas  regularmente,  pero  están  en
       lugares  distintos  (i.e.  sólo  podría leer el correo que llega a una de las cuentas). Le
       gustaría reenviar el correo que llega a la cuenta uno a la cuenta dos y al  contrario.  Lo
       primero  que  se  viene  a  la  mente  es  usar ficheros .forward en ambos sitios; esto no
       funcionará, desde luego, ya que estará creando un bucle de correo.  Este  bucle  se  puede
       evitar   insertando  la  siguiente  receta  frente  a  todas  las  otras  recetas  en  los
       ficheros$HOME/.procmailrc de ambos sitios. Si está seguro que añade el mismo campo X-Loop:
       en ambos sitios, el correo se puede reenviar de una cuenta a otra con garantías.

              :0 c
              * !^X-Loop: yourname@your.main.mail.address
              | formail -A "X-Loop: yourname@your.main.mail.address" | \
                 $SENDMAIL -oi yourname@the.other.account

       Si  alguien  le  envía  un  correo  con  la  palabra  `retrieve' en el campo `subject', lo
       siguiente devolverá automáticamente el contenido del fichero info_file al remitente.  Como
       en todas las recetas donde enviamos correo, tenemos que vigilar los bucles de correo.

              :0
              * !^From +YOUR_USERNAME
              * !^Subject:.*Re:
              * !^FROM_DAEMON
              * ^Subject:.*retrieve
              | (formail -r ; cat info_file) | $SENDMAIL -oi -t

       A  continuación  un ejemplo para un simple servidor de ficheros accesible por correo. Para
       aplicaciones con mayores exigencias, le  sugiero  que  le  eche  un  vistazo  a  SmartList
       (disponible  en  el  mismo  lugar que la distribución de  procmail).  Como se indica, este
       servidor de ficheros devuelve sólamente un fichero por  petición,  ignora  el  cuerpo  del
       mensaje  recibido,  la  línea  Subject:  tiene  que  parecerse  a  "Subject: envia fichero
       el_fichero_que_quiere" (los espacios en blanco son significativos), no  devuelve  ficheros
       que  empiezan  por  punto  ni  permite  recuperar  ficheros  que  estén fuera del árbol de
       directorios del servidor de ficheros (si decide usar este ejemplo, esté seguro  de  perder
       esta última restricción por descuido).

              :0
              * ^Subject: send file [0-9a-z]
              * !^X-Loop: yourname@your.main.mail.address
              * !^Subject:.*Re:
              * !^FROM_DAEMON
              * !^Subject: send file .*[/.]\.
              {
                MAILDIR=$HOME/fileserver # cambiar al directorio del servidor de ficheros

                :0 fhw                   # invierte las cabeceras y extrae el nombre
                * ^Subject: send file \/[^ ]*
                | formail -rA "X-Loop: yourname@your.main.mail.address"

                FILE="$MATCH"            # el fichero soliciatado

                :0 ah
                | cat - ./$FILE 2>&1 | $SENDMAIL -oi -t
              }

       El  siguiente ejemplo pre-convierte todos los correos que llegan en texto simple en cierto
       formato codificado MIME en otro formato de 8 bits más compacto que se puede usar y mostrar
       con  más  facilidad por la mayoría de los programas. El programa mimencode(1) es parte del
       paquete metamail de Nathaniel Borenstein.

              :0
              * ^Content-Type: *text/plain
              {
                :0 fbw
                * ^Content-Transfer-Encoding: *quoted-printable
                | mimencode -u -q

                   :0 Afhw
                   | formail -I "Content-Transfer-Encoding: 8bit"

                :0 fbw
                * ^Content-Transfer-Encoding: *base64
                | mimencode -u -b

                   :0 Afhw
                   | formail -I "Content-Transfer-Encoding: 8bit"
              }

       El siguiente es más bien exótico, pero  sólo  sirve  para  demostrar  una  característica.
       Suponga  que  tiene un fichero en su directorio HOME llamado ".urgent", y la única persona
       incluida en ese fichero es el remitente de un correo entrante, y le gustaría que el correo
       se  almacenara en $MAILDIR/urgent en lugar de cualesquiera de las otras carpetas de correo
       normales en las que lo habría puesto. Esto es lo que podría hacer (tenga  cuidado  con  la
       longitud del fichero de $HOME/.urgent que debería estar por debajo de $LINEBUF, incremente
       LINEBUF si es necesario):

              URGMATCH=`cat $HOME/.urgent`

              :0:
              * $^From.*${URGMATCH}
              urgent

       Una aplicación completamente diferente a procmail  aplicaría  condicionalmente  filtros  a
       ciertos  textos  o  mensajes  (salientes). Un ejemplo típico sería un filtreo a través del
       cual encauza todo su correo saliente, para estar seguro que se codificará con MIME sólo si
       se necesita.

              cat newtext | procmail ./mimeconvert | mail chris@where.ever

       El fichero de recursos mimeconvert podría contener algo como ( =0x80= y =0xff= se deberían
       sustituir por caracteres reales de 8 bits):

              DEFAULT=|     # tubería a la salida estándar
                            # de entrega de correo como es normal
              :0 Bfbw
              * [=0x80=-=0xff=]
              | mimencode -q

                :0 Afhw
                | formail -I 'MIME-Version: 1.0' \
                   -I 'Content-Type: text/plain; charset=ISO-8859-1' \
                   -I 'Content-Transfer-Encoding: quoted-printable'

VÉASE TAMBIÉN

       procmail(1), procmailrc(5), procmailsc(5), sh(1), csh(1), mail(1), mailx(1), binmail(1),
       uucp(1), aliases(5), sendmail(8), egrep(1), grep(1), biff(1), comsat(8), mimencode(1),
       lockfile(1), formail(1)

AUTOR

       Stephen R. van den Berg
              <srb@cuci.nl>