Benjamin Renard commited on 2016-01-20 17:54:57
Showing 1 changed files, with 98 additions and 0 deletions.
... | ... |
@@ -0,0 +1,98 @@ |
1 |
+#!/bin/bash |
|
2 |
+ |
|
3 |
+MAILID=$1 |
|
4 |
+[ -z "$MAILID" ] && echo "Usage : $0 [mailid]" && exit 1 |
|
5 |
+ |
|
6 |
+DEBUG=0 |
|
7 |
+[ "$2" == "-d" ] && DEBUG=1 |
|
8 |
+ |
|
9 |
+MAX_LOG=9 |
|
10 |
+ |
|
11 |
+HOSTNAME=$( hostname -f ) |
|
12 |
+ |
|
13 |
+function search_sender () { |
|
14 |
+ MAILID=$1 |
|
15 |
+ MAILLOG=$2 |
|
16 |
+ [ ! -f "$MAILLOG" ] && MAILLOG=$MAILLOG.gz |
|
17 |
+ [ -f "$MAILLOG" ] && zgrep $MAILID $MAILLOG|grep 'from='|sed 's/^.*\: from=<\([^>]*\)>.*$/\1/'|head -n 1 |
|
18 |
+} |
|
19 |
+ |
|
20 |
+function search_sender_from_mailid() { |
|
21 |
+ MAILID=$1 |
|
22 |
+ [ $DEBUG -eq 1 ] && echo "Search sender from Mail ID $MAILID ..." |
|
23 |
+ res=$( search_sender $MAILID /var/log/mail.log ) |
|
24 |
+ if [ -n "$res" ] |
|
25 |
+ then |
|
26 |
+ echo "$res" |
|
27 |
+ exit 0 |
|
28 |
+ else |
|
29 |
+ [ $DEBUG -eq 1 ] && echo "Not found from log file /var/log/mail.log. Try with archive (Max : $MAX_LOG)" |
|
30 |
+ for i in $( seq 1 $MAX_LOG ) |
|
31 |
+ do |
|
32 |
+ res=$( search_sender $MAILID /var/log/mail.log.$i ) |
|
33 |
+ if [ -n "$res" ] |
|
34 |
+ then |
|
35 |
+ [ $DEBUG -eq 1 ] && echo "Found from log file /var/log/mail.log.$i" |
|
36 |
+ echo "$res" |
|
37 |
+ exit 0 |
|
38 |
+ else |
|
39 |
+ [ $DEBUG -eq 1 ] && echo "Not found from log file /var/log/mail.log.$i" |
|
40 |
+ fi |
|
41 |
+ done |
|
42 |
+ [ $DEBUG -eq 1 ] && echo "Not found in archive (Max : $MAX_LOG)" |
|
43 |
+ fi |
|
44 |
+} |
|
45 |
+ |
|
46 |
+if [ $( mailq|egrep -c ^$MAILID ) -ne 0 ] |
|
47 |
+then |
|
48 |
+ [ $DEBUG -eq 1 ] && echo "Mail $MAILID still in mailq. Try to detect original mail ID ..." |
|
49 |
+ ORIGMAILID=$( postcat -q "$MAILID" |grep "by $HOSTNAME"|tail -n 1|sed 's/^.*by .* with.* id \([A-Z0-9]*\).*$/\1/' ) |
|
50 |
+ if [ -n "$ORIGMAILID" ] |
|
51 |
+ then |
|
52 |
+ if [ "$ORIGMAILID" != "$MAILID" ] |
|
53 |
+ then |
|
54 |
+ [ $DEBUG -eq 1 ] && echo "Original mail ID : $ORIGMAILID" |
|
55 |
+ search_sender_from_mailid "$ORIGMAILID" |
|
56 |
+ [ $DEBUG -eq 1 ] && echo "Sender not found from original mail ID" |
|
57 |
+ exit 1 |
|
58 |
+ else |
|
59 |
+ [ $DEBUG -eq 1 ] && echo "Mail ID and original mail ID are equals" |
|
60 |
+ fi |
|
61 |
+ else |
|
62 |
+ [ $DEBUG -eq 1 ] && echo "Fail to detect original mail ID. Continue with mail ID in parameter" |
|
63 |
+ fi |
|
64 |
+fi |
|
65 |
+ |
|
66 |
+search_sender_from_mailid "$MAILID" |
|
67 |
+[ -n "$ORIGMAILID" ] && echo "Sender not found" && exit 1 |
|
68 |
+ |
|
69 |
+[ $DEBUG -eq 1 ] && echo "Sender not found. Try to detect original mail ID with message ID in log" |
|
70 |
+ |
|
71 |
+MSGID=$( mailid_to_messageid "$MAILID" ) |
|
72 |
+ |
|
73 |
+if [ -z "$MSGID" ] |
|
74 |
+then |
|
75 |
+ [ $DEBUG -eq 1 ] && echo "Message ID not found from log." |
|
76 |
+ exit 1 |
|
77 |
+fi |
|
78 |
+ |
|
79 |
+[ $DEBUG -eq 1 ] && echo "Message ID found : $MSGID. Try to detect original mail ID with this message ID" |
|
80 |
+ |
|
81 |
+ORIGMAILID=$( messageid_to_original_mailid "$MSGID" ) |
|
82 |
+ |
|
83 |
+if [ -z "$ORIGMAILID" ] |
|
84 |
+then |
|
85 |
+ [ $DEBUG -eq 1 ] && echo "Original mail ID not found from message ID" |
|
86 |
+ exit 1 |
|
87 |
+fi |
|
88 |
+ |
|
89 |
+if [ "$ORIGMAILID" == "$MAILID" ] |
|
90 |
+then |
|
91 |
+ [ $DEBUG -eq 1 ] && echo "Original mail ID is same as mail ID in parameter" |
|
92 |
+ exit 1 |
|
93 |
+fi |
|
94 |
+ |
|
95 |
+search_sender_from_mailid "$ORIGMAILID" |
|
96 |
+[ $DEBUG -eq 1 ] && echo "Sender not found from original mail ID" |
|
97 |
+ |
|
98 |
+exit 1 |
|
0 | 99 |