during the SSL/TLS session establishment. It's a pretty short script, but it still has a configuration option. :)
The default setting is to log certificates of local hosts, to change that to log all certificates...
redef SSL_KnownCerts::logged_hosts = AllHosts;When this script really becomes cool is when you have DPD enabled (i'll write a post on how to do that soon). If DPD is enabled, you will actually be detecting SSL on all ports and then logging the X.509 certificate in the log just the same as SSL on the normal ports like 443/tcp and 995/tcp.
Here are some examples of the log lines seen in the ssl-known-certs.log file. (the wrapping is horrible, but you get the idea)
184.108.40.206 443 /C=US/ST=California/L=Mountain View/O=Google Inc/CN=mail.google.comThose fields are tab separated too, so they're nice and easy to parse. More tomorrow hopefully!
220.127.116.11 443 /C=US/ST=California/L=Mountain View/O=Google Inc/CN=*.mail.google.com
18.104.22.168 443 /C=US/ST=California/L=Mountain View/O=Google Inc/CN=*.google-analytics.com
22.214.171.124 443 /C=US/postalCode=43210/ST=OH/L=Columbus/streetAddress=250 West Woodruff Avenue/O=The Ohio State University/OU=Office of Information Technology/OU=Hosted by The Ohio State University/OU=Comodo PremiumSSL Wildcard/CN=*.osu.edu
Update: I forgot to give a link to the file. ssl-known-certs.bro