author | Tero Marttila <terom@paivola.fi> |
Sun, 10 Feb 2013 16:52:51 +0200 | |
changeset 209 | cf883e2e1bff |
parent 99 | 8d60eb5604e4 |
child 216 | c0dbd44bd463 |
permissions | -rw-r--r-- |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
1 |
import logging; log = logging.getLogger('pvl.syslog.filter') |
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
2 |
|
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
3 |
import re # XXX |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
4 |
import os.path, fnmatch |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
5 |
|
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
6 |
class SyslogFilter (object) : |
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
7 |
""" |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
8 |
Match syslog messages fields against given patterns. |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
9 |
""" |
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
10 |
|
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
11 |
def __init__ (self, **filters) : |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
12 |
""" |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
13 |
Match using given { field: regex }. |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
14 |
""" |
45 | 15 |
|
61
cd33c2b53d69
pvl.syslog.filter: ignore None-filters
Tero Marttila <terom@fixme.fi>
parents:
57
diff
changeset
|
16 |
# drop None's |
65 | 17 |
self.filters = dict((attr, regex) for attr, regex in filters.iteritems() if regex is not None) |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
18 |
|
74
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
19 |
def match_glob (self, attr, glob, value=None) : |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
20 |
""" |
74
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
21 |
Match prog as glob. |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
22 |
""" |
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
23 |
|
74
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
24 |
if not value : |
68
bea41de5cc98
pvl.syslog.filter: reject empty progs
Tero Marttila <terom@fixme.fi>
parents:
65
diff
changeset
|
25 |
# require |
bea41de5cc98
pvl.syslog.filter: reject empty progs
Tero Marttila <terom@fixme.fi>
parents:
65
diff
changeset
|
26 |
return False |
bea41de5cc98
pvl.syslog.filter: reject empty progs
Tero Marttila <terom@fixme.fi>
parents:
65
diff
changeset
|
27 |
|
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
28 |
# normalize |
74
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
29 |
value = value.strip() |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
30 |
|
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
31 |
# match |
74
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
32 |
if fnmatch.fnmatch(value, glob) : |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
33 |
return { attr: value } |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
34 |
else : |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
35 |
return False |
74
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
36 |
|
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
37 |
match_facility = match_glob |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
38 |
|
74
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
39 |
def match_prog (self, attr, glob, prog=None) : |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
40 |
""" |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
41 |
Match prog as glob. |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
42 |
""" |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
43 |
|
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
44 |
if prog : |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
45 |
# normalize |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
46 |
prog = prog.strip().lower() |
209
cf883e2e1bff
pvl.syslog.SyslogFilter: only normalize prog path if an absolute path
Tero Marttila <terom@paivola.fi>
parents:
99
diff
changeset
|
47 |
|
cf883e2e1bff
pvl.syslog.SyslogFilter: only normalize prog path if an absolute path
Tero Marttila <terom@paivola.fi>
parents:
99
diff
changeset
|
48 |
if prog.startswith('/') : |
cf883e2e1bff
pvl.syslog.SyslogFilter: only normalize prog path if an absolute path
Tero Marttila <terom@paivola.fi>
parents:
99
diff
changeset
|
49 |
# leaves postfix/* intact, but fixes /usr/bin/cron |
cf883e2e1bff
pvl.syslog.SyslogFilter: only normalize prog path if an absolute path
Tero Marttila <terom@paivola.fi>
parents:
99
diff
changeset
|
50 |
_, prog = os.path.split(prog) |
74
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
51 |
|
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
52 |
# match |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
53 |
return self.match_glob(attr, glob, prog) |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
54 |
|
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
55 |
REGEX_TYPE = type(re.compile('')) |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
56 |
|
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
57 |
def match_regex (self, attr, regex, value=None) : |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
58 |
""" |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
59 |
Match given value against given pattern. |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
60 |
""" |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
61 |
|
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
62 |
if not value : |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
63 |
# XXX: optional = match empty string? |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
64 |
value = '' |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
65 |
else : |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
66 |
# normalize; XXX: unicode? |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
67 |
value = str(value).strip() |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
68 |
|
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
69 |
# match |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
70 |
match = regex.match(value) |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
71 |
|
54 | 72 |
if not match : |
56
ff184e09ceb9
pvl.syslog.filter: fix true/false/filenotfound snafu
Tero Marttila <terom@fixme.fi>
parents:
54
diff
changeset
|
73 |
return False |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
74 |
|
54 | 75 |
# as match-values |
99
8d60eb5604e4
pvl.syslog.filter: fix to override attr from regex
Tero Marttila <terom@paivola.fi>
parents:
74
diff
changeset
|
76 |
matches = { attr: match.group(0) } # whole match |
8d60eb5604e4
pvl.syslog.filter: fix to override attr from regex
Tero Marttila <terom@paivola.fi>
parents:
74
diff
changeset
|
77 |
matches.update(match.groupdict()) |
54 | 78 |
|
79 |
# TODO match.expand? |
|
80 |
||
81 |
return matches |
|
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
82 |
|
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
83 |
def filter (self, item) : |
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
84 |
""" |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
85 |
Match given item. Returns any matched values (including regexp capture groups) across all fields. |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
86 |
""" |
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
87 |
|
57
c88861dda326
pvl.syslog.filter: fix empty filters
Tero Marttila <terom@fixme.fi>
parents:
56
diff
changeset
|
88 |
match = None |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
89 |
matches = {} |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
90 |
|
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
91 |
for attr in self.filters : |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
92 |
# filter |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
93 |
filter = self.filters[attr] |
74
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
94 |
|
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
95 |
if not filter : |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
96 |
# ignore |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
97 |
continue |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
98 |
|
74
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
99 |
# lookup match-func |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
100 |
match = getattr(self, 'match_{attr}'.format(attr=attr), None) |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
101 |
|
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
102 |
if match : |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
103 |
pass |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
104 |
|
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
105 |
elif isinstance(filter, self.REGEX_TYPE) : |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
106 |
match = self.match_regex |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
107 |
|
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
108 |
else : |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
109 |
match = self.match_glob |
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
110 |
|
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
111 |
# apply match |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
112 |
if attr in item : |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
113 |
match = match(attr, filter, item[attr]) |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
114 |
else : |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
115 |
match = match(attr, filter) |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
116 |
|
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
117 |
log.debug("%s: %s", attr, match) |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
118 |
|
45 | 119 |
if match : |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
120 |
# match |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
121 |
matches.update(match) |
45 | 122 |
|
123 |
else : |
|
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
124 |
# reject |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
125 |
return |
45 | 126 |
|
74
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
127 |
# test last match |
45 | 128 |
if match is None : |
74
952ee07efd7a
pvl.syslog: implement --syslog-facility, implementing proper glob/regexp support in SyslogFilter
Tero Marttila <terom@paivola.fi>
parents:
68
diff
changeset
|
129 |
# empty filter -> all None |
45 | 130 |
return True |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
131 |
else : |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
132 |
return matches |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
133 |
|
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
134 |
def process (self, items) : |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
135 |
for item in items: |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
136 |
match = self.filter(item) |
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
137 |
|
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
138 |
if match : |
44
977442ccb72d
pvl.syslog: split out SyslogFilter
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
139 |
yield item |
52
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
140 |
|
f04df0db2acd
pvl.syslog: refactor SyslogFilter for extensive magics
Tero Marttila <terom@fixme.fi>
parents:
45
diff
changeset
|
141 |
__call__ = process |
61
cd33c2b53d69
pvl.syslog.filter: ignore None-filters
Tero Marttila <terom@fixme.fi>
parents:
57
diff
changeset
|
142 |
|
cd33c2b53d69
pvl.syslog.filter: ignore None-filters
Tero Marttila <terom@fixme.fi>
parents:
57
diff
changeset
|
143 |
def __nonzero__ (self) : |
cd33c2b53d69
pvl.syslog.filter: ignore None-filters
Tero Marttila <terom@fixme.fi>
parents:
57
diff
changeset
|
144 |
return bool(self.filters) |
cd33c2b53d69
pvl.syslog.filter: ignore None-filters
Tero Marttila <terom@fixme.fi>
parents:
57
diff
changeset
|
145 |
|
65 | 146 |
def __repr__ (self) : |
147 |
return repr(self.filters) |