From 3c9fc5f20faf677d017f32e5a08f8aafe8728d7a Mon Sep 17 00:00:00 2001 From: Steve Kemp Date: Wed, 18 Feb 2015 05:20:01 +0000 Subject: Added SSL-expiry checker. This is a stub for the moment, but it validates that we can have multiple handlers for a given test-type. This updates #9558. --- lib/custodian/protocoltest/ssl.rb | 88 +++++++++++++++++++++++++++++++++++++++ lib/custodian/protocoltests.rb | 1 + 2 files changed, 89 insertions(+) create mode 100644 lib/custodian/protocoltest/ssl.rb diff --git a/lib/custodian/protocoltest/ssl.rb b/lib/custodian/protocoltest/ssl.rb new file mode 100644 index 0000000..704edac --- /dev/null +++ b/lib/custodian/protocoltest/ssl.rb @@ -0,0 +1,88 @@ +require 'custodian/testfactory' + + +# +# The SSL-expiry test. +# +# This object is instantiated if the parser sees a line such as: +# +### +### https://foo.vm.bytemark.co.uk/ must run https with content 'page text' otherwise 'http fail'. +### +# +# +module Custodian + + module ProtocolTest + + class SSLCertificateTest < TestFactory + + + # + # Constructor + # + def initialize( line ) + + # + # Save the line + # + @line = line + + # + # Save the host + # + @host = line.split( /\s+/)[0] + + end + + + + + # + # Allow this test to be serialized. + # + def to_s + @line + end + + + + # + # Run the test - this means making a TCP-connection to the + # given host and validating that the SSL-certificate is not + # expired. + # + # Because testing the SSL certificate is relatively heavy-weight + # and because they don't change often we only test in office-hours. + # + # + def run_test + + hour = Time.now.hour + + # + # If outside 10AM-5PM we don't alert. + # + if ( hour < 10 || hour > 17 ) + return true + end + + # + # NOP - validate here. + # + return true + end + + + # + # If the test fails then report the error. + # + def error + @error + end + + register_test_type "https" + + end + end +end diff --git a/lib/custodian/protocoltests.rb b/lib/custodian/protocoltests.rb index 2aed748..29f2885 100644 --- a/lib/custodian/protocoltests.rb +++ b/lib/custodian/protocoltests.rb @@ -27,6 +27,7 @@ require 'custodian/protocoltest/redis' require 'custodian/protocoltest/rsync' require 'custodian/protocoltest/openproxy' require 'custodian/protocoltest/ssh' +require 'custodian/protocoltest/ssl' require 'custodian/protocoltest/smtp' require 'custodian/protocoltest/smtprelay' require 'custodian/protocoltest/telnet' -- cgit v1.2.1