]> git.phdru.name Git - dotfiles.git/blob - .procmailrc
.procmailrc: Fix Klez rule to avoid false positives
[dotfiles.git] / .procmailrc
1 #
2 # User configuration file for procmail
3 #
4
5 #
6 # SET VARIABLES
7
8 # Internal Variables
9
10 SHELL=/bin/sh               #Shell used to run procmail.  Be sure this points to
11                             #your system's copy of sh.  DO NOT substitute a
12                             #different shell unless you really know Unix
13
14 LINEBUF=4096                #Needed to keep Procmail from choking on long
15                             #"recipes", or instructions on what to do with
16                             #particular kinds of email.
17
18 PATH=$HOME/bin:$HOME/mail/bin:/bin:/usr/bin:/usr/local/bin
19                             #Path for your programs -- this is probably best
20                             #left alone.
21
22 VERBOSE=off                 #Change this to "on" when you try a new recipe
23                             #so that Procmail will log literally every step
24                             #it takes.  DO NOT LEAVE IT ON, though, because
25                             #it creates huge logfiles.
26
27 # Default Program & file locations
28
29 MAILDIR=${HOME}/Mail        #you'd better make sure this directory exists
30
31 #ORGMAIL=/var/spool/mail/phd
32 #DEFAULT=${ORGMAIL}
33
34 LOGFILE=${MAILDIR}/procmail.log      #Logs message disposition.  Recommended -- otherwise
35                                      #errors are emailed to you. :/
36
37 SENDMAIL=/usr/sbin/sendmail    #useful for autoreply recipes.
38 FORMAIL=/usr/bin/formail       #useful for autoreply recipes.
39
40
41 MYEMAIL=${HOME}/mail/misc/.myemail   #Tells Procmail where your MYEMAIL
42                                      #file is located, a text file containing all the
43                                      #email addresses you use.
44
45 ADMINFOLDER=${MAILDIR}/admin         #for bounced mail, mail from root,
46                                      #postmaster, abuse, etc.
47
48 BLOCKFOLDER=${MAILDIR}/block         #for suspicious mail, but possibly not spam
49
50 BULKFOLDER=${MAILDIR}/bulk           #for bulk mail which appears legitimate, such
51                                      #as mail from mailing lists or mail sent using
52                                      #Bcc:
53
54 SPAMFOLDER=${MAILDIR}/spam           #change this to SPAMFOLDER=/dev/null
55                                      #to delete spam entirely.
56
57 VIRUSFOLDER=/dev/null                #Set this variable to /dev/null to delete
58                                      #all viruses. You don't want to take chances with a virus,
59                                      #and the false positive rate on the virus filters is near zero.
60
61 # BEGIN RECIPES
62
63
64 # Create a backup cache of 2000 most recent messages in case of mistakes
65 :0 c
66 backup
67
68   :0 ic
69   | cd backup && rm -f dummy `ls -t msg.* | sed -e 1,2000d`
70
71 # Regenerate "From" lines to make sure they are valid
72 :0 fhw
73 | ${FORMAIL} -I "From " -a "From "
74
75
76 # *CLOSED (only subscribers can write)* MAILING LISTS
77 # No need to filter them for spam
78
79 :0
80 * ^(From|To|Cc|Reply-To): .*((mlug@unixcenter\.ru)|@altlinux\.ru)
81 lists/mlug
82
83 :0
84 * ^List-Id: Moscow Linux User Group <mlug\.UnixCenter\.RU>
85 lists/mlug
86
87 :0
88 * ^(To|Cc|Reply-To|Resent-To|X-BeenThere): .*(-list@(python\.org|cwi\.nl))
89 lists/python
90
91 :0
92 * ^Sender: .*@python\.org
93 lists/python
94
95 :0
96 * ^List-Id: .*<python-.*\.python\.org>
97 lists/python
98
99 :0
100 * ^Newsgroups: .*comp\.lang\.python
101 lists/python
102
103 :0
104 * ^From: sitelist-bounces@lists\.sourceforge\.net
105 * ^To: .*-owner@lists\.sourceforge\.net
106 * ^Subject: Uncaught bounce notification
107 ${SPAMFOLDER}
108
109 :0
110 * ^From: .*-bounces@lists\.sourceforge\.net
111 * ^To: .*-owner@lists\.sourceforge\.net
112 * ^Subject: Auto-discard notification
113 ${SPAMFOLDER}
114
115 :0
116 * ^List-Id: .+<sqlobject-(discuss|cvs)\.lists\.sourceforge\.net>
117 lists/python
118
119 :0
120 * ^To: "(\[sqlobject:(bugs|patches)\] )|(Ticket [0-9]+)" <[0-9]+@(bugs|patches)\.sqlobject\.p\.re\.sf\.net>
121 * ^Reply-To: "?(\\?\[sqlobject:(bugs|patches)\\?\] )|(Ticket [0-9]+)"? <[0-9]+@(bugs|patches)\.sqlobject\.p\.re\.sf\.net>
122 * ^Subject: (\[SQL-CVS\] )?\[sqlobject:(bugs|patches)\] (Re: )?\#[0-9]+
123 lists/python
124
125 :0
126 * ^From: "SQLObject Git repository" <noreply@(fullhistory|sqlobject|scripts)\.sqlobject\.p\.re\.sf\.net>
127 * ^To: "SQLObject Git repository" <noreply@(fullhistory|sqlobject|scripts)\.sqlobject\.p\.re\.sf\.net>
128 * ^Reply-To: "SQLObject Git repository" <noreply@(fullhistory|sqlobject|scripts)\.sqlobject\.p\.re\.sf\.net>
129 * ^Subject: \[sqlobject:(fullhistory|sqlobject|scripts)\]
130 lists/python
131
132 :0
133 * ^From: .+<notifications@github\.com>
134 * ^To: sqlobject/sqlobject <sqlobject@noreply\.github\.com>
135 * ^List-ID: sqlobject/sqlobject <sqlobject\.sqlobject\.github\.com>
136 lists/python
137
138 :0
139 * ^List-Id: .*<cheetahtemplate-(announce|discuss)\.lists\.sourceforge\.net>
140 lists/python
141
142 :0
143 * ^Sender: ppa-qps-devel-admin@lists\.sourceforge\.net
144 lists/python
145
146 :0
147 * ^List-Id: PyGreSQL Development <pygresql\.vex\.net>
148 lists/python
149
150
151 # Now filters
152
153 # Klez
154 :0 B
155 * ^Content-Transfer-Encoding: base64
156 * name( ?)=.*\.(exe|bat|scr|pif)
157 | ${FORMAIL} -A"X-Note: Klez" -A"X-Folder: Virus" >${VIRUSFOLDER}
158
159 # Sobig.E
160 :0 HB
161 * ^Subject: Re: (Movie|Application)$
162 * ^Content-Transfer-Encoding: base64
163 * ^Content-Disposition: attachment;
164 * filename=.your_details\.zip
165 | ${FORMAIL} -A"X-Note: Sobig.E" -A"X-Folder: Virus" >${VIRUSFOLDER}
166
167 # Sobig.F
168 :0 H
169 * ^Subject: .*(Thank you!|Your application|That movie|Approved|Details|My details|Your details|Wicked screensaver)$
170 * ^X-MailScanner: Found to be clean$
171 | ${FORMAIL} -A"X-Note: Sobig.F" -A"X-Folder: Virus" >${VIRUSFOLDER}
172
173 # MyDoom/Novarg
174 :0 HB
175 * <50000
176 * ^Subject: (test|hi|hello|Mail Delivery System|Mail Transaction Failed|Server Report|Status|Error|)$
177 * ^Content-type: application/octet-stream;
178 * (file)?name="(document|readme|doc|text|file|data|test|message|body)\.(pif|scr|exe|cmd|bat|zip)
179 | ${FORMAIL} -A"X-Note: MyDoom" -A"X-Folder: Virus" >${VIRUSFOLDER}
180
181 # Netsky
182 :0
183 * > 20000
184 * < 60000
185 * ^Subject:[ ]*(hi|hello|read it immediately|\
186 something for you|warning|information|stolen|fake|unknown)
187 * B ?? ^(anything ok\?|what does it mean?|ok|\
188 i'm waiting|read the details\.|here is the document\.|\
189 read it immediately\!|my hero|\
190 here|is that true?|is that your name?|is that your account?|\
191 i wait for a reply\!|is that from you?|you are a bad writer|\
192 I have your password\!|something about you\!|\
193 kill the writer of this document\!|i hope it is not true\!|\
194 your name is wrong|i found this document about you|\
195 yes, really\?|that is bad|here it is|see you|\
196 greetings|stuff about you\?|something is going wrong!|\
197 information about you|about me|from the chatter|\
198 here, the serials|here, the introduction|here, the cheats|\
199 that's funny|do you\?|reply|take it easy|why\?|\
200 thats wrong|misc|you earn money|you feel the same|\
201 you try to steal|you are bad|something is going wrong|\
202 something is fool)$
203 * B ?? ^(Content-Disposition:[  ]*attachment;)?[        ]*(file)?name="?(document|msg|doc|talk|message|creditcard|\
204 details|attachment|me|stuff|posting|textfile|concert|\
205 information|note|bill|swimmingpool|product|\
206 topseller|ps|shower|aboutyou|nomoney| found|\
207 story|mails|website|friend|jokes|location|\
208 final|release|dinner|ranking|object|mail2|part2|\
209 disco|party|misc)\..*(zip|exe|scr|com|pif)"?$
210 | ${FORMAIL} -A"X-Note: Netsky" -A"X-Folder: Virus" >${VIRUSFOLDER}
211
212 # Bagle.J
213 :0
214 * ^Subject:(.*E-mail account disabling warning)|\
215    (.*E-mail account security warning)|\
216    (.*Email account utilization warning)|\
217    (.*Important notify about your e-mail account)|\
218    (.*Notify about using the e-mail account)|\
219    (.*Notify about your e-mail account utilization)|\
220    (.*Warning about your e-mail account)
221 * B ?? ^Content-Type: application/octet-stream;
222 * B ?? ^Content-Transfer-Encoding: base64
223 * B ?? ^Content-Disposition: attachment;
224 | ${FORMAIL} -A"X-Note: Bagle.J" -A"X-Folder: Virus" >${VIRUSFOLDER}
225
226
227 # From http://www.internetguru.com.au/igblog-102.html
228
229 # Redirect common virus attachments inc. zipped versions
230 :0 B
231 * name=.*(document|readme|doc|text|file|data|test|message|body)\.(vbs\"|wsf\"|vbe\"|wsh\"|hta\"|scr\"|pif\"|exe\"|shs\"|bat\"|bas\"|cmd\"|zip\")
232 {
233    :0
234    | ${FORMAIL} -A"X-Note: executable attachment virus" -A"X-Folder: Virus" >>${VIRUSFOLDER}
235 }
236
237 # Some more common virus attachments inc. zipped versions
238 :0 B
239 * name=.*(Attach|Information|Readme|Document|Info|TextDocument|Textfile|MoreInfo|Message)\.(pif\"|zip\")
240 {
241    :0
242    | ${FORMAIL} -A"X-Note: executable attachment virus" -A"X-Folder: Virus" >>${VIRUSFOLDER}
243 }
244
245 # Redirect windows executables (note - haven't included exe and com
246 :0 B
247 * name=.*\.(vbs\"|wsf\"|vbe\"|wsh\"|hta\"|scr\"|pif\"|shs\"|bat\"|bas\"|scr\"|dll\")
248 {
249    :0
250    | ${FORMAIL} -A"X-Note: executable attachment virus" -A"X-Folder: Virus" >>${VIRUSFOLDER}
251 }
252
253 # This one finds them annoying Custom Logo spams that seem to get past most filters
254 :0 B
255 * .*out\.php\?email\=(sales|info)\@
256 {
257    :0
258    | ${FORMAIL} -A"X-Note: Custom Logo spam" -A"X-Folder: Spam" >>${SPAMFOLDER}
259 }
260
261 # This catches about 99% of deliberate viagra mispellings ie v1@GRa, v1agr@ etc
262 :0 H
263 * ^Subject.*[Vv][1jl\|][aA\@][Gg][Rr][Aa\@]
264 {
265    :0
266    | ${FORMAIL} -A"X-Note: viagra spam" -A"X-Folder: Spam" >/dev/null
267 }
268
269
270 # Chineese/japaneese/korean spam
271
272 :0
273 * ^Content-Type: text/(plain|html); *charset=("?)(big5|gb2312|iso-2022-jp|ks_c_5601-1987|shift_jis)("?)
274 | ${FORMAIL} -A"X-Note: chineese/japaneese/korean charset" -A"X-Folder: Spam" >/dev/null
275
276 :0
277 * ^X-RBL-Warning: .*(china|korea) does not seem to care about spam
278 | ${FORMAIL} -A"X-Note: chineese/korean source" -A"X-Folder: Spam" >>${SPAMFOLDER}
279
280
281 # SpamAssassin (spamassassin.org)
282 :0fw
283 * < 10240000
284 | spamc -U /tmp/spamassassin.sock -s 10240000
285
286
287 # Mail with a score of 14 or higher is certainly spam
288 :0:
289 * ^X-Spam-Level: \*\*\*\*\*\*\*\*\*\*\*\*\*\*
290 | ${FORMAIL} -A"X-Note: certainly spam" -A"X-Folder: Spam" >/dev/null
291
292 :0:
293 * ^X-Spam-Status: Yes
294 * > 20000
295 | ${FORMAIL} -A"X-Note: oversized spam" -A"X-Folder: Spam" >/dev/null
296
297 :0 HB:
298 * ^X-Spam-Status: Yes
299 * http://www\.gstinc\.com/
300 | ${FORMAIL} -A"X-Note: gstinc spam" -A"X-Folder: Spam" >/dev/null
301
302 :0 HB:
303 * ^X-Spam-Status: Yes
304 * (www\.)?sonidom\.ru
305 | ${FORMAIL} -A"X-Note: sonidom spam" -A"X-Folder: Spam" >/dev/null
306
307 :0 HB:
308 * ^X-Spam-Status: Yes
309 * (www\.)?pos-tel\.ru
310 | ${FORMAIL} -A"X-Note: pos-tel spam" -A"X-Folder: Spam" >/dev/null
311
312 :0 HB:
313 * ^X-Spam-Status: Yes
314 * @besttraining\.ru
315 | ${FORMAIL} -A"X-Note: besttraining spam" -A"X-Folder: Spam" >/dev/null
316
317 :0:
318 * ^X-Spam-Status: Yes
319 ${SPAMFOLDER}
320
321
322 # MAILING LISTS
323
324 # Filter out mail from all mailing lists you are on. Just duplicate the recipe
325 # for each mailing list you are on, and put the correct address for the list in
326 # the condition statement. (The "* ^TO" part.) If you read mail on shell, you
327 # may find it easier to deliver this mail to separate folders, especially for
328 # busy lists. I do. :)
329
330
331 # Block all messages that are too big
332 :0
333 * > 1000000
334 | ${FORMAIL} -A"X-Note: the message is too big" -A"X-Folder: Block" >>${BLOCKFOLDER}
335
336
337 # unfiltered mail marked by exim (using RBL/ORBS/etc)
338
339 :0
340 * ^X-RBL-Warning:
341 * ^(To|Cc):.*phd
342 ${BLOCKFOLDER}
343
344 :0
345 * ^X-RBL-Warning:
346 ${SPAMFOLDER}
347
348
349 # Sort out mail that really is to you from mail Bcc'd to you, or mail
350 # which doesn't have any of your email addresses on the To: or Cc: line.
351 # For this to work properly, you must create a text file named .myemail
352 # in your home directory and enter all email addresses that belong to
353 # you in it, one per line, just as you do with your .nobounce file.
354 #
355 # This does =wonders= in keeping spam from appearing in your personal
356 # mail. :)
357 #
358 # Substitute your shell account email address, custom domain, and any other email
359 # address you may have for the entries below.
360 :0:
361 * ? test -f ${MYEMAIL} && \
362     (${FORMAIL} -zxTo: -zxCc: |\
363     fgrep -i -f ${MYEMAIL})
364 | ${FORMAIL} -A"X-Folder: Default" >>${DEFAULT}
365
366 # Deliver email which passed spam filtering, but which wasn't sent to
367 # a recognizable personal email address of yours, to your "bulk mail"
368 # folder, for reading on a less-urgent basis.
369 :0:
370 | ${FORMAIL} -A"X-Folder: Bulk" >>${BULKFOLDER}
371
372
373 # Vacation - modified version of procmail example from "man procmailex"
374
375 # Drop duplicates
376 #:0 Wh: msgid.lock
377 #| ${FORMAIL} -D 65536 msgid.cache
378 #
379 #:0 Whc: vacation.lock
380 #* !^From: .*phd
381 #* !^FROM_MAILER
382 #* !^FROM_DAEMON
383 #* !^X-Loop: phd@phdru.name
384 #* !^X-Loop: phd@iskra.aviel.ru
385 #* !^From: "AviTicket" <support@aviel\.ru>
386 #* !^From: .* <lj_notify@livejournal\.com>
387 #* !^From: .*report_card@sbrf.ru
388 #| ${FORMAIL} -rD 65536 vacation.cache
389 #
390 #:0 ehc  # if the name was not in the cache - reply
391 #| (egrep -v '^From phd|^Return-Path: phd' | \
392 #   ${FORMAIL} -r -A"Precedence: junk" \
393 #      -A"X-Loop: phd@phdru.name" -A"X-Loop: phd@iskra.aviel.ru" \
394 #      -A"Content-Type: text/plain; charset=koi8-r"; \
395 #   echo "Hello!"; echo "";\
396 #   echo "   I am on vacation. This is an auto-generated reply. Your message has been"; \
397 #   echo "delivered to my mailbox. Thanks a lot. I will read it after 0th of ."; \
398 #   echo ""; \
399 #   echo "Здравствуйте."; echo ""; \
400 #   echo "   Я уехал в отпуск. Это автоматический ответ. Ваше сообщение было доставлено."; \
401 #   echo "в мой почтовый ящик. Большое спасибо. Я прочту его, когда вернусь 0 ."; \
402 #   echo ""; cat $HOME/.signature) | $SENDMAIL -oi -t