procmail дает "нет совпадения" по типу контента
Я пытаюсь, чтобы procmail декодировал вложение в кодировке base64. Для начала я следую простому рецепту, найденному здесь:
Тем не менее, кажется, что 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
Я не получаю совпадений.