1
0
mirror of https://github.com/certbot/certbot.git synced 2026-01-26 07:41:33 +03:00

First pass at logs analysis

This commit is contained in:
Jacob Hoffman-Andrews
2014-06-18 17:50:41 -04:00
parent 67ee3b0488
commit 51980e212f
2 changed files with 50 additions and 2 deletions

View File

@@ -4,7 +4,7 @@ import sys
import json
from datetime import datetime
import string
import collections
def parse_timestamp(ts):
try:
@@ -48,7 +48,7 @@ class Config:
self.expires = parse_timestamp(val)
elif atr == "tls-policies":
self.tls_policies = {}
for domain,policies in self.check_tls_policy_domains(val):
for domain, policies in self.check_tls_policy_domains(val):
if type(policies) != dict:
raise TypeError, domain + "'s policies should be a dict: " + `policies`
self.tls_policies[domain] = {} # being here enforces TLS at all
@@ -60,10 +60,25 @@ class Config:
self.tls_policies[domain]["min-tls-version"] = str(value)
elif atr == "acceptable-mxs":
self.acceptable_mxs = val
self.mx_domain_to_address_domains = collections.defaultdict(set)
for address_domain, properties in self.acceptable_mxs.items():
mx_list = properties["accept-mx-domains"]
if len(mx_list) > 1:
print "Lists of multiple accept-mx-domains not yet supported, skipping ", address_domain
mx_domain = mx_list[0]
self.mx_domain_to_address_domains[mx_domain].add(address_domain)
pass
else:
sys.stderr.write("Unknown attribute: " + `atr` + "\n")
def get_address_domains(self, mx_hostname):
for mx_domain, address_domains in self.mx_domain_to_address_domains.items():
# TODO: write this better
if (mx_hostname.find(mx_domain) > 0 and
mx_hostname.find(mx_domain) == len(mx_hostname) - len(mx_domain)):
return address_domains
return None
def check_tls_policy_domains(self, val):
if type(val) != dict:
raise TypeError, "tls-policies should be a dict" + `val`

33
PostfixLogSummary.py Executable file
View File

@@ -0,0 +1,33 @@
#!/usr/bin/python2.7
import re
import sys
import collections
import ConfigParser
def get_counts(input, config):
counts = collections.defaultdict(lambda: collections.defaultdict(int))
r = re.compile("([A-Za-z]+) TLS connection established to ([^[]*)")
for line in sys.stdin:
result = r.search(line)
if result:
validation = result.group(1)
mx_hostname = result.group(2)
address_domains = config.get_address_domains(mx_hostname)
if address_domains:
for d in address_domains:
counts[d][validation] += 1
counts[d]["all"] += 1
return counts
def print_summary(counts):
for mx_hostname, validations in counts.items():
for validation, validation_count in validations.items():
if validation == "all":
continue
print mx_hostname, validation, validation_count / validations["all"]
if __name__ == "__main__":
config = ConfigParser.Config("starttls-everywhere.json")
counts = get_counts(sys.stdin, config)
print_summary(counts)