aboutsummaryrefslogtreecommitdiffstats
path: root/bin/get_mail_stats
blob: 0fcf20d5391c16e233e14ed12e2118abd3c67f78 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#! /usr/bin/env bash

set -euo pipefail
IFS=$'\n\t'

time_frame=""
postfix_received=""
rbl_dropped=""
spampd_clean=""
spampd_spam=""
sieve_spam=""
postfix_sent=""

function set_range()
{
  case $1 in
    "month")
      time_frame=$(date --date="last month" -I)
      ;;
    "week")
      time_frame=$(date --date="last week" -I)
      ;;
    "day")
      time_frame=$(date -I)
      ;;
  esac
}

function get_stats()
{
  set +e
  postfix_received=$(journalctl -S "$time_frame" _EXE=/usr/lib/postfix/bin/smtpd|grep "proxy-accept"| wc -l)
  rbl_dropped=$(journalctl -S "$time_frame" -u postfix |grep "Service unavailable"| wc -l)
  spampd_clean=$(journalctl -S "$time_frame" -u spampd| grep "clean message"| wc -l)
  spampd_spam=$(journalctl -S "$time_frame" -u spampd| grep "identified spam"| wc -l)
  sieve_spam=$(journalctl -S "$time_frame" _EXE=/usr/lib/dovecot/dovecot-lda| grep "Spam"| wc -l)
  postfix_sent=$(journalctl -S "$time_frame" _EXE=/usr/lib/postfix/bin/smtp |grep "sent"| wc -l)
  set -e
}

function print_stats()
{
  echo "Mail statistics for $(hostname) since $time_frame"
  echo "Received total: $postfix_received"
  echo "RBL dropped: $rbl_dropped"
  echo "Spampd clean: $spampd_clean"
  echo "Spampd spam: $spampd_spam"
  echo "Sieve spam: $spampd_spam"
  echo "Sent: $postfix_sent"
}

case ${@} in
  "-w")
    set_range "week"
    ;;
  "-m")
    set_range "month"
    ;;
  "-d")
    set_range "day"
    ;;
  *)
    set_range "day"
    ;;
esac

get_stats
print_stats
exit 0