|
@ -25,25 +25,49 @@ import ssl |
|
|
|
|
|
|
|
|
from version import ELECTRUM_VERSION, PROTOCOL_VERSION |
|
|
from version import ELECTRUM_VERSION, PROTOCOL_VERSION |
|
|
from util import print_error, print_msg |
|
|
from util import print_error, print_msg |
|
|
|
|
|
from simple_config import SimpleConfig |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
DEFAULT_TIMEOUT = 5 |
|
|
DEFAULT_TIMEOUT = 5 |
|
|
proxy_modes = ['socks4', 'socks5', 'http'] |
|
|
proxy_modes = ['socks4', 'socks5', 'http'] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def is_expired(cert): |
|
|
def check_cert(host, cert): |
|
|
from OpenSSL import crypto as c |
|
|
from OpenSSL import crypto as c |
|
|
_cert = c.load_certificate(c.FILETYPE_PEM, cert) |
|
|
_cert = c.load_certificate(c.FILETYPE_PEM, cert) |
|
|
notAfter = _cert.get_notAfter() |
|
|
|
|
|
notBefore = _cert.get_notBefore() |
|
|
m = "host: %s\n"%host |
|
|
now = time.time() |
|
|
m += "has_expired: %s\n"% _cert.has_expired() |
|
|
if now > time.mktime( time.strptime(notAfter[:-1] + "GMT", "%Y%m%d%H%M%S%Z") ): |
|
|
m += "pubkey: %s bits\n" % _cert.get_pubkey().bits() |
|
|
print "deprecated cert", self.host, notAfter |
|
|
m += "serial number: %s\n"% _cert.get_serial_number() |
|
|
return True |
|
|
#m += "issuer: %s\n"% _cert.get_issuer() |
|
|
if now < time.mktime( time.strptime(notBefore[:-1] + "GMT", "%Y%m%d%H%M%S%Z") ): |
|
|
#m += "algo: %s\n"% _cert.get_signature_algorithm() |
|
|
print "notbefore", self.host, notBefore |
|
|
m += "version: %s\n"% _cert.get_version() |
|
|
return True |
|
|
print_msg(m) |
|
|
return False |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def check_certificates(): |
|
|
|
|
|
config = SimpleConfig() |
|
|
|
|
|
mydir = os.path.join(config.path, "certs") |
|
|
|
|
|
certs = os.listdir(mydir) |
|
|
|
|
|
for c in certs: |
|
|
|
|
|
print c |
|
|
|
|
|
p = os.path.join(mydir,c) |
|
|
|
|
|
with open(p) as f: |
|
|
|
|
|
cert = f.read() |
|
|
|
|
|
check_cert(c, cert) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def cert_verify_hostname(s): |
|
|
|
|
|
# hostname verification (disabled) |
|
|
|
|
|
from backports.ssl_match_hostname import match_hostname, CertificateError |
|
|
|
|
|
try: |
|
|
|
|
|
match_hostname(s.getpeercert(True), host) |
|
|
|
|
|
print_error("hostname matches", host) |
|
|
|
|
|
except CertificateError, ce: |
|
|
|
|
|
print_error("hostname did not match", host) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class Interface(threading.Thread): |
|
|
class Interface(threading.Thread): |
|
@ -52,7 +76,6 @@ class Interface(threading.Thread): |
|
|
def __init__(self, config=None): |
|
|
def __init__(self, config=None): |
|
|
|
|
|
|
|
|
if config is None: |
|
|
if config is None: |
|
|
from simple_config import SimpleConfig |
|
|
|
|
|
config = SimpleConfig() |
|
|
config = SimpleConfig() |
|
|
|
|
|
|
|
|
threading.Thread.__init__(self) |
|
|
threading.Thread.__init__(self) |
|
@ -288,10 +311,10 @@ class Interface(threading.Thread): |
|
|
dercert = s.getpeercert(True) |
|
|
dercert = s.getpeercert(True) |
|
|
s.close() |
|
|
s.close() |
|
|
cert = ssl.DER_cert_to_PEM_cert(dercert) |
|
|
cert = ssl.DER_cert_to_PEM_cert(dercert) |
|
|
|
|
|
|
|
|
temporary_path = cert_path + '.temp' |
|
|
temporary_path = cert_path + '.temp' |
|
|
with open(temporary_path,"w") as f: |
|
|
with open(temporary_path,"w") as f: |
|
|
f.write(cert) |
|
|
f.write(cert) |
|
|
|
|
|
|
|
|
else: |
|
|
else: |
|
|
is_new = False |
|
|
is_new = False |
|
|
|
|
|
|
|
@ -316,27 +339,18 @@ class Interface(threading.Thread): |
|
|
except ssl.SSLError, e: |
|
|
except ssl.SSLError, e: |
|
|
print_error("SSL error:", self.host, e) |
|
|
print_error("SSL error:", self.host, e) |
|
|
if is_new: |
|
|
if is_new: |
|
|
os.unlink(temporary_path) |
|
|
check_cert(self.host, cert) |
|
|
|
|
|
os.rename(temporary_path, cert_path + '.rej') |
|
|
return |
|
|
return |
|
|
except: |
|
|
except: |
|
|
print_error("wrap_socket failed", self.host) |
|
|
print_error("wrap_socket failed", self.host) |
|
|
traceback.print_exc(file=sys.stdout) |
|
|
traceback.print_exc(file=sys.stdout) |
|
|
if is_new: |
|
|
|
|
|
os.unlink(temporary_path) |
|
|
|
|
|
return |
|
|
return |
|
|
|
|
|
|
|
|
if is_new: |
|
|
if is_new: |
|
|
print_error("saving certificate for", self.host) |
|
|
print_error("saving certificate for", self.host) |
|
|
os.rename(temporary_path, cert_path) |
|
|
os.rename(temporary_path, cert_path) |
|
|
|
|
|
|
|
|
# hostname verification (disabled) |
|
|
|
|
|
#from backports.ssl_match_hostname import match_hostname, CertificateError |
|
|
|
|
|
#try: |
|
|
|
|
|
# match_hostname(s.getpeercert(), self.host) |
|
|
|
|
|
# print_error("hostname matches", self.host) |
|
|
|
|
|
#except CertificateError, ce: |
|
|
|
|
|
# print_error("hostname does not match", self.host, s.getpeercert()) |
|
|
|
|
|
# return |
|
|
|
|
|
|
|
|
|
|
|
s.settimeout(60) |
|
|
s.settimeout(60) |
|
|
self.s = s |
|
|
self.s = s |
|
@ -539,10 +553,4 @@ class Interface(threading.Thread): |
|
|
|
|
|
|
|
|
if __name__ == "__main__": |
|
|
if __name__ == "__main__": |
|
|
|
|
|
|
|
|
q = Queue.Queue() |
|
|
check_certificates() |
|
|
i = Interface({'server':'btc.it-zone.org:50002:s', 'path':'/extra/key/wallet', 'verbose':True}) |
|
|
|
|
|
i.start(q) |
|
|
|
|
|
time.sleep(1) |
|
|
|
|
|
exit() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|