mirror of
https://github.com/openSUSE/osc.git
synced 2025-01-12 08:56:13 +01:00
- oscssl.verify_certificate: also print cert info if http_debug is set
If http_debug is set we redirect sys.stdout to an StringIO instance in order to do some header filtering (see conf module) so we have to use the "original" stdout for printing the certificate information.
This commit is contained in:
parent
20ac9ece78
commit
0ac1d32945
@ -529,12 +529,13 @@ def init_basicauth(config):
|
|||||||
def filterhdrs(meth, ishdr, *hdrs):
|
def filterhdrs(meth, ishdr, *hdrs):
|
||||||
# this is so ugly but httplib doesn't use
|
# this is so ugly but httplib doesn't use
|
||||||
# a logger object or such
|
# a logger object or such
|
||||||
def new_method(*args, **kwargs):
|
def new_method(self, *args, **kwargs):
|
||||||
stdout = sys.stdout
|
self._orig_stdout = sys.stdout
|
||||||
sys.stdout = StringIO()
|
sys.stdout = StringIO()
|
||||||
meth(*args, **kwargs)
|
meth(self, *args, **kwargs)
|
||||||
hdr = sys.stdout.getvalue()
|
hdr = sys.stdout.getvalue()
|
||||||
sys.stdout = stdout
|
sys.stdout = self._orig_stdout
|
||||||
|
del self._orig_stdout
|
||||||
for i in hdrs:
|
for i in hdrs:
|
||||||
if ishdr:
|
if ishdr:
|
||||||
hdr = re.sub(r'%s:[^\\r]*\\r\\n' % i, '', hdr)
|
hdr = re.sub(r'%s:[^\\r]*\\r\\n' % i, '', hdr)
|
||||||
|
@ -87,7 +87,7 @@ def verify_cb(ctx, ok, store):
|
|||||||
return 1
|
return 1
|
||||||
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print(e)
|
print(e, file=sys.stderr)
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
class FailCert:
|
class FailCert:
|
||||||
@ -116,15 +116,15 @@ class ValidationErrors:
|
|||||||
raise Exception("Certificate changed unexpectedly. This should not happen")
|
raise Exception("Certificate changed unexpectedly. This should not happen")
|
||||||
self.failures[depth].errs.append(err)
|
self.failures[depth].errs.append(err)
|
||||||
|
|
||||||
def show(self):
|
def show(self, out):
|
||||||
for depth in self.failures.keys():
|
for depth in self.failures.keys():
|
||||||
cert = self.failures[depth].cert
|
cert = self.failures[depth].cert
|
||||||
print("*** certificate verify failed at depth %d" % depth)
|
print("*** certificate verify failed at depth %d" % depth, file=out)
|
||||||
print("Subject: ", cert.get_subject())
|
print("Subject: ", cert.get_subject(), file=out)
|
||||||
print("Issuer: ", cert.get_issuer())
|
print("Issuer: ", cert.get_issuer(), file=out)
|
||||||
print("Valid: ", cert.get_not_before(), "-", cert.get_not_after())
|
print("Valid: ", cert.get_not_before(), "-", cert.get_not_after(), file=out)
|
||||||
print("Fingerprint(MD5): ", cert.get_fingerprint('md5'))
|
print("Fingerprint(MD5): ", cert.get_fingerprint('md5'), file=out)
|
||||||
print("Fingerprint(SHA1): ", cert.get_fingerprint('sha1'))
|
print("Fingerprint(SHA1): ", cert.get_fingerprint('sha1'), file=out)
|
||||||
|
|
||||||
for err in self.failures[depth].errs:
|
for err in self.failures[depth].errs:
|
||||||
reason = "Unknown"
|
reason = "Unknown"
|
||||||
@ -133,7 +133,7 @@ class ValidationErrors:
|
|||||||
reason = M2Crypto.Err.get_x509_verify_error(err)
|
reason = M2Crypto.Err.get_x509_verify_error(err)
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
print("Reason:", reason)
|
print("Reason:", reason, file=out)
|
||||||
|
|
||||||
# check if the encountered errors could be ignored
|
# check if the encountered errors could be ignored
|
||||||
def could_ignore(self):
|
def could_ignore(self):
|
||||||
@ -325,17 +325,21 @@ def verify_certificate(connection):
|
|||||||
print("offending certificate is at '%s'" % tc.file, file=sys.stderr)
|
print("offending certificate is at '%s'" % tc.file, file=sys.stderr)
|
||||||
raise SSLVerificationError("remote host identification has changed")
|
raise SSLVerificationError("remote host identification has changed")
|
||||||
|
|
||||||
verrs.show()
|
# if http_debug is set we redirect sys.stdout to an StringIO
|
||||||
|
# instance in order to do some header filtering (see conf module)
|
||||||
|
# so we have to use the "original" stdout for printing
|
||||||
|
out = getattr(connection, '_orig_stdout', sys.stdout)
|
||||||
|
verrs.show(out)
|
||||||
|
|
||||||
print()
|
print(file=out)
|
||||||
|
|
||||||
if not verrs.could_ignore():
|
if not verrs.could_ignore():
|
||||||
raise SSLVerificationError("Certificate validation error cannot be ignored")
|
raise SSLVerificationError("Certificate validation error cannot be ignored")
|
||||||
|
|
||||||
if not verrs.chain_ok:
|
if not verrs.chain_ok:
|
||||||
print("A certificate in the chain failed verification")
|
print("A certificate in the chain failed verification", file=out)
|
||||||
if not verrs.cert_ok:
|
if not verrs.cert_ok:
|
||||||
print("The server certificate failed verification")
|
print("The server certificate failed verification", file=out)
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
print("""
|
print("""
|
||||||
@ -344,9 +348,10 @@ Would you like to
|
|||||||
1 - continue anyways
|
1 - continue anyways
|
||||||
2 - trust the server certificate permanently
|
2 - trust the server certificate permanently
|
||||||
9 - review the server certificate
|
9 - review the server certificate
|
||||||
""")
|
""", file=out)
|
||||||
|
|
||||||
r = raw_input("Enter choice [0129]: ")
|
print("Enter choice [0129]: ", end='', file=out)
|
||||||
|
r = raw_input()
|
||||||
if not r or r == '0':
|
if not r or r == '0':
|
||||||
connection.close()
|
connection.close()
|
||||||
raise SSLVerificationError("Untrusted Certificate")
|
raise SSLVerificationError("Untrusted Certificate")
|
||||||
@ -357,6 +362,6 @@ Would you like to
|
|||||||
tc.trust_always()
|
tc.trust_always()
|
||||||
return
|
return
|
||||||
elif r == '9':
|
elif r == '9':
|
||||||
print(cert.as_text())
|
print(cert.as_text(), file=out)
|
||||||
|
|
||||||
# vim: sw=4 et
|
# vim: sw=4 et
|
||||||
|
Loading…
Reference in New Issue
Block a user