Question
How can I verify that an X.509 certificate is signed by another certificate using PyOpenSSL or Twisted? I want a client to verify that the received server certificate is the one that signed its client certificate.
I've looked through the PyOpenSSL documentation and can't seem to find anything on how to verify a certificate separately from the establishing the SSL connection.
I found a reference to OpenSSL.crypto:X509.verify()
in twisted.internet._sslverify:PublicKey.verifyCertificate()
, but the twisted method is commented out (in Twisted 13.0) and the X509 method does not exist (in PyOpenSSL 0.13).
pyOpenSSL has no support for verifying a certificate describes a bug for not being able to manually verify a certificate chain, but I'm not entirely sure if that's what I'm trying to do.
Use Case
Certificates:
Generated self-signed CA certificate with openssl.
Generated server certificate signed by CA certificate.
Generated client certificate signed by server certificate.
Setup:
The server is using Twisted's CertificateOptions with its server cert. The CA certs are the CA and server certs to setup a chain where the server cert verifies the received client cert, and the CA cert verifies the server cert (all built-in functionality).
The client is also using CertificateOptions for the client cert. The CA certs only contains the CA cert.
This all works fine (both sides verify each other) but I want to perform an additional step:
- In the client set_verify() callback, verify that the client cert is signed by the server cert.