summaryrefslogtreecommitdiff
path: root/test/aux-fixed/event-logger-acl
blob: 15321724efb62f7fa442ae513186c468a536850c (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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
ev_tcp:
    accept condition = ${if eq {$event_name}{tcp:connect}}
	   logwrite = . [$host_address]:$host_port
    accept condition = ${if eq {$event_name}{tcp:close}}
	   logwrite = . [$sending_ip_address] -> \
			[$host_address]:$host_port
    accept logwrite =	UNEXPECTED $event_name

ev_smtp:
    warn
	   logwrite = . [$sending_ip_address] -> \
			[$host_address]:$host_port
    accept condition = ${if eq {$event_name}{smtp:connect}}
	   logwrite = . banner <$event_data>
    accept condition = ${if eq {$event_name}{smtp:ehlo}}
	   logwrite = . ehlo-resp <$event_data>
    accept logwrite =	UNEXPECTED $event_name

ev_msg_fail:
    accept condition = ${if eq {$event_name}{msg:fail:delivery}}
	   logwrite = . \
	    refused by fdqn <$host> \
	    local_part <$local_part> \
	    domain <$domain> \
	    errstr <$event_data> \

    accept logwrite = . \
	    local_part <$local_part> \
	    domain <$domain> \
	    reason <$event_data>

ev_msg_log:
    accept logwrite = . \
	    $acl_arg1 \
	    ip <$host_address> \
	    port <$host_port> \
	    fqdn <$host> \
	    local_part <$local_part> \
	    domain <$domain> \
	    $acl_arg2 \
	    router <$router_name> \
	    transport <$transport_name>

ev_msg:
    accept condition = ${if eq {fail} {${listextract{2}{$event_name}}}}
	   acl = ev_msg_fail

    accept condition = ${if eq {$event_name}{msg:complete}}
	   logwrite = . finished: $message_exim_id

    accept condition = ${if eq {$domain}{expansionfail}}
	   logwrite = $this_expansion_will_fail

    accept condition = ${if eq {$event_name}{msg:delivery}}
	   acl = ev_msg_log delivery "confirmation <$event_data>"

    accept condition = ${if eq {$event_name}{msg:defer}}
	   acl = ev_msg_log "message deferral" \
			"errno <$event_defer_errno> errstr <$event_data>"

    accept condition = ${if eq {$event_name}{msg:host:defer}}
	   acl = ev_msg_log "host deferral" \
			"errno <$event_defer_errno> errstr <$event_data>"

    accept condition = ${if eq {$event_name}{msg:rcpt:defer}}
	   set acl_m_ev_lkup =	${eval:$event_defer_errno & 0xff}
	   set acl_m_ev_lkup =	${if = {$acl_m_ev_lkup}{65} {A} \
				{ ${if = {$acl_m_ev_lkup}{77} {MX} \
				  {$acl_m_ev_lkup}}}}
	   set acl_m_ev_code =  4${eval:$event_defer_errno >>8}
	   acl = ev_msg_log "rcpt deferral" \
			"err <$event_defer_errno>:<$acl_m_ev_lkup:$acl_m_ev_code> \
			errstr <$event_data>"

    accept condition = ${if eq {$event_name}{msg:rcpt:host:defer}}
    accept logwrite =	UNEXPECTED $event_name

logger:
    warn   logwrite = event $event_name
    accept condition = ${if eq {tcp} {${listextract{1}{$event_name}}}}
	   acl = ev_tcp
    accept condition = ${if eq {smtp} {${listextract{1}{$event_name}}}}
	   acl = ev_smtp
    accept condition = ${if eq {msg} {${listextract{1}{$event_name}}}}
	   acl = ev_msg
    accept logwrite =	UNEXPECTED $event_name