|  | @@ -301,24 +301,25 @@ def watch():
 | 
											
												
													
														|  |    pubsub.subscribe('F2B_CHANNEL')
 |  |    pubsub.subscribe('F2B_CHANNEL')
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    while not quit_now:
 |  |    while not quit_now:
 | 
											
												
													
														|  | -    try:
 |  | 
 | 
											
												
													
														|  |        for item in pubsub.listen():
 |  |        for item in pubsub.listen():
 | 
											
												
													
														|  | -        refreshF2bregex()
 |  | 
 | 
											
												
													
														|  | -        for rule_id, rule_regex in f2bregex.items():
 |  | 
 | 
											
												
													
														|  | -          if item['data'] and item['type'] == 'message':
 |  | 
 | 
											
												
													
														|  | -            try:
 |  | 
 | 
											
												
													
														|  | -              result = re.search(rule_regex, item['data'])
 |  | 
 | 
											
												
													
														|  | -            except re.error:
 |  | 
 | 
											
												
													
														|  | -              result = False
 |  | 
 | 
											
												
													
														|  | -            if result:
 |  | 
 | 
											
												
													
														|  | -              addr = result.group(1)
 |  | 
 | 
											
												
													
														|  | -              ip = ipaddress.ip_address(addr)
 |  | 
 | 
											
												
													
														|  | -              if ip.is_private or ip.is_loopback:
 |  | 
 | 
											
												
													
														|  | -                continue
 |  | 
 | 
											
												
													
														|  | -              logWarn('%s matched rule id %s (%s)' % (addr, rule_id, item['data']))
 |  | 
 | 
											
												
													
														|  | -              ban(addr)
 |  | 
 | 
											
												
													
														|  | -    except Exception as ex:
 |  | 
 | 
											
												
													
														|  | -      logWarn('Could not read logline from pubsub, skipping...')
 |  | 
 | 
											
												
													
														|  | 
 |  | +        try:
 | 
											
												
													
														|  | 
 |  | +          refreshF2bregex()
 | 
											
												
													
														|  | 
 |  | +          for rule_id, rule_regex in f2bregex.items():
 | 
											
												
													
														|  | 
 |  | +            if item['data'] and item['type'] == 'message':
 | 
											
												
													
														|  | 
 |  | +              try:
 | 
											
												
													
														|  | 
 |  | +                result = re.search(rule_regex, item['data'])
 | 
											
												
													
														|  | 
 |  | +              except re.error:
 | 
											
												
													
														|  | 
 |  | +                result = False
 | 
											
												
													
														|  | 
 |  | +              if result:
 | 
											
												
													
														|  | 
 |  | +                addr = result.group(1)
 | 
											
												
													
														|  | 
 |  | +                ip = ipaddress.ip_address(addr)
 | 
											
												
													
														|  | 
 |  | +                if ip.is_private or ip.is_loopback:
 | 
											
												
													
														|  | 
 |  | +                  continue
 | 
											
												
													
														|  | 
 |  | +                logWarn('%s matched rule id %s (%s)' % (addr, rule_id, item['data']))
 | 
											
												
													
														|  | 
 |  | +                ban(addr)
 | 
											
												
													
														|  | 
 |  | +        except Exception as ex:
 | 
											
												
													
														|  | 
 |  | +          logWarn('Could not read logline from pubsub, skipping...')
 | 
											
												
													
														|  | 
 |  | +          continue
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  def snat4(snat_target):
 |  |  def snat4(snat_target):
 | 
											
												
													
														|  |    global lock
 |  |    global lock
 |