procmail дает "нет совпадения" по типу контента

Я пытаюсь, чтобы procmail декодировал вложение в кодировке base64. Для начала я следую простому рецепту, найденному здесь:

http://www.linuxquestions.org/questions/linux-software-2/procmailrc-decode-data-from-base64-encoded-emails-trying-to-decode-with-uudeview-933670/

Тем не менее, кажется, что procmail не может найти соответствие:

procmail: [7459] Mon Aug 10 10:54:43 2015
procmail: Assigning "LOGFILE=/home/myself/procmail.log"
procmail: Opening "/home/myself/procmail.log"
procmail: Assigning "LOGABSTRACT=yes"
procmail: Assigning "LINEBUF=65535"
procmail: No match on "^Content-Type: *text/plain"
procmail: Locking "/home/myself/scratch/prc.out.lock"
procmail: Assigning "LASTFOLDER=/home/myself/scratch/prc.out"
procmail: Opening "/home/myself/scratch/prc.out"
procmail: Acquiring kernel-lock
procmail: Unlocking "/home/myself/scratch/prc.out.lock"
Subject: FMSG:219
Folder: /home/myself/scratch/prc.out                     8312
[168]%

Мой ~/.procmailrc очень прост:

SHELL=/bin/sh
PATH=/bin:/usr/bin/:/sbin:/usr/sbin:$PATH
MAILDIR=$HOME/scratch   # this is a symlink to a scratch disk
DEFAULT=$HOME/scratch/prc.out
VERBOSE=yes
LOGFILE=/home/myself/procmail.log
LOGABSTRACT=yes
LINEBUF=65535

:0
* ^Content-Type: *text/plain
{
        :0 fbw
        * ^Content-Transfer-Encoding: *base64
        | $HOME/mmencode -u -b

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

и это начало почтового файла:

Return-Path: <unknown>
Delivered-To: unknown
From: <user1>
To: ole <user2>
Date: Mon, 20 Jul 2015 14:46:49 +0200
Subject: FMSG:219
Message-ID:  <6959f239-gf41-4339-a526-a0337a17a9ba@test.local>
Accept-Language: en-US
Content-Language: en-US
Content-Type: multipart/mixed;
boundary="_002_6959f239a4d111111111111111111111111111111oletestl_"
MIME-Version: 1.0

--_002_6959f239a4d111111111111111111111111111111oletestl_
Content-Type: text/plain; charset="us-ascii"
Content-Transfer-Encoding: quoted-printable


--_002_6959f239a4d111111111111111111111111111111oletestl_
Content-Type: application/x-ole-envelope; name="20150720"
Content-Description: ole envelope
Content-Disposition: attachment; filename="20150720"; size=5528;
creation-date="Mon, 20 Jul 2015 12:46:52 GMT";
modification-date="Mon, 20 Jul 2015 12:46:52 GMT"
Content-Transfer-Encoding: base64

SDRzSUFBQUFBQUFBQzYxWFdZK2pXTEordnBiOEgxTDEwZzhvaDgxZ3V6dXJSb2ZGZ0EzWWJHWVp6
UU83d1d4bU1kaS8vaDY3DQpNcnV5ZW5wNjVrbzNKU3NoNG9zNHNaOUFrUlQrOVJpM1hWWlh2Nzdn
THQzOUFsMTVsVm5vQmg4TS8vL0hIS3ZqblA0NzRQMkZtdjJ0NDlpSDYzb2h2NkhzamYvdC9IVUZS

...

--_002_6959f239a4d6959f239a4d111111111111111111111111111111oletestl_

Если я пытаюсь найти совпадение в "Content-Type: multipart/mixed", я получаю совпадение:

procmail: Match on "^Content-Type: multipart/mixed;"
procmail: No match on "^Content-Transfer-Encoding: *base64"

но тогда не о следующих...:(

Похоже с покушением на

procmail: нет совпадений для "^Content-Type: application/x-ole-envelope"

Что мне не хватает?

Спасибо

1 ответ

Решение

В заголовке сообщения на регулярном выражении нет совпадений. Если вы хотите найти совпадение в теле (включая, но не ограничиваясь, заголовки частей тела MIME), используйте B флаг; но правильная поддержка MIME будет намного сложнее, и это практически невозможно сделать только в Procmail.

Рецепт, который вы копируете, предназначен специально для нормализации отдельных частей. text/plain сообщения, а не мультипарты.

Ваш вопрос очень общий, поэтому я могу предложить альтернативные варианты только в общих чертах. Может быть, передать сообщение к чему-то вроде munpack возможно на основе некоторых критериев регулярных выражений, которые вполне можно выразить в Procmail; но для чего-то более сложного, может быть, труба к специализированному скрипту Python (или Perl, или Ruby, и т. д.).

Мой procmailrc работает

VERBOSE=on
LOGFILE=$HOME/.procmail.log/procmail.`date +%Y%m%d`.log
LOGABSTRACT=yes

:0Wc:mailparser.lock
| /usr/bin/python /home/qq/mailparser.py > mailparser.log

:0
* ^content-Type:
{
    # backup the complete mail first..
    # you can leave out this part if you don't want a backup of the complete mail
    :0c:
        $HOME/fetchmail/mail_backup

    :0fw
    | uudeview -i +a +o -p $HOME/fetchmail/attachments -

}

Когда я пытаюсь как

* ^Content-Type: *text/plain

Я не получаю совпадений.

Другие вопросы по тегам