CertificateInfoSoup.cpp [plain text]
#include "config.h"
#if USE(SOUP)
#include "CertificateInfo.h"
#include <ResourceError.h>
#include <ResourceResponse.h>
#include <libsoup/soup.h>
#include <wtf/glib/GRefPtr.h>
#include <wtf/glib/GUniquePtr.h>
namespace WebCore {
CertificateInfo::CertificateInfo()
: m_tlsErrors(static_cast<GTlsCertificateFlags>(0))
{
}
CertificateInfo::CertificateInfo(const ResourceResponse& response)
: m_certificate(response.soupMessageCertificate())
, m_tlsErrors(response.soupMessageTLSErrors())
{
}
CertificateInfo::CertificateInfo(const ResourceError& resourceError)
: m_certificate(resourceError.certificate())
, m_tlsErrors(static_cast<GTlsCertificateFlags>(resourceError.tlsErrors()))
{
}
CertificateInfo::CertificateInfo(GTlsCertificate* certificate, GTlsCertificateFlags tlsErrors)
: m_certificate(certificate)
, m_tlsErrors(tlsErrors)
{
}
CertificateInfo::~CertificateInfo() = default;
static GRefPtr<GTlsCertificate> createCertificate(GByteArray* bytes, GTlsCertificate* issuer)
{
gpointer cert = g_initable_new(g_tls_backend_get_certificate_type(g_tls_backend_get_default()),
nullptr, nullptr,
"certificate", bytes,
"issuer", issuer,
nullptr);
RELEASE_ASSERT(cert);
return adoptGRef(G_TLS_CERTIFICATE(cert));
}
CertificateInfo CertificateInfo::isolatedCopy() const
{
Vector<GRefPtr<GByteArray>> certificateBytes;
GTlsCertificate* cert = m_certificate.get();
if (!cert)
return CertificateInfo();
do {
GRefPtr<GByteArray> der;
g_object_get(cert, "certificate", &der.outPtr(), nullptr);
GRefPtr<GByteArray> copy = adoptGRef(g_byte_array_new());
g_byte_array_append(copy.get(), der->data, der->len);
certificateBytes.append(WTFMove(copy));
} while ((cert = g_tls_certificate_get_issuer(cert)));
auto finalCertificateIndex = certificateBytes.size() - 1;
GRefPtr<GTlsCertificate> copy = createCertificate(certificateBytes[finalCertificateIndex].get(), nullptr);
for (ssize_t i = finalCertificateIndex - 1; i >= 0; i--)
copy = createCertificate(certificateBytes[i].get(), copy.get());
return CertificateInfo(copy.get(), m_tlsErrors);
}
}
#endif