diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /third_party/libwebrtc/rtc_base/rtc_certificate.cc | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'third_party/libwebrtc/rtc_base/rtc_certificate.cc')
-rw-r--r-- | third_party/libwebrtc/rtc_base/rtc_certificate.cc | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/third_party/libwebrtc/rtc_base/rtc_certificate.cc b/third_party/libwebrtc/rtc_base/rtc_certificate.cc new file mode 100644 index 0000000000..e0b6b3258e --- /dev/null +++ b/third_party/libwebrtc/rtc_base/rtc_certificate.cc @@ -0,0 +1,77 @@ +/* + * Copyright 2015 The WebRTC Project Authors. All rights reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. An additional intellectual property rights grant can be found + * in the file PATENTS. All contributing project authors may + * be found in the AUTHORS file in the root of the source tree. + */ + +#include "rtc_base/rtc_certificate.h" + +#include <memory> + +#include "rtc_base/checks.h" +#include "rtc_base/ssl_certificate.h" +#include "rtc_base/ssl_identity.h" +#include "rtc_base/time_utils.h" + +namespace rtc { + +scoped_refptr<RTCCertificate> RTCCertificate::Create( + std::unique_ptr<SSLIdentity> identity) { + // Explicit new to access proteced constructor. + return rtc::scoped_refptr<RTCCertificate>( + new RTCCertificate(identity.release())); +} + +RTCCertificate::RTCCertificate(SSLIdentity* identity) : identity_(identity) { + RTC_DCHECK(identity_); +} + +RTCCertificate::~RTCCertificate() = default; + +uint64_t RTCCertificate::Expires() const { + int64_t expires = GetSSLCertificate().CertificateExpirationTime(); + if (expires != -1) + return static_cast<uint64_t>(expires) * kNumMillisecsPerSec; + // If the expiration time could not be retrieved return an expired timestamp. + return 0; // = 1970-01-01 +} + +bool RTCCertificate::HasExpired(uint64_t now) const { + return Expires() <= now; +} + +const SSLCertificate& RTCCertificate::GetSSLCertificate() const { + return identity_->certificate(); +} + +const SSLCertChain& RTCCertificate::GetSSLCertificateChain() const { + return identity_->cert_chain(); +} + +RTCCertificatePEM RTCCertificate::ToPEM() const { + return RTCCertificatePEM(identity_->PrivateKeyToPEMString(), + GetSSLCertificate().ToPEMString()); +} + +scoped_refptr<RTCCertificate> RTCCertificate::FromPEM( + const RTCCertificatePEM& pem) { + std::unique_ptr<SSLIdentity> identity( + SSLIdentity::CreateFromPEMStrings(pem.private_key(), pem.certificate())); + if (!identity) + return nullptr; + return RTCCertificate::Create(std::move(identity)); +} + +bool RTCCertificate::operator==(const RTCCertificate& certificate) const { + return *this->identity_ == *certificate.identity_; +} + +bool RTCCertificate::operator!=(const RTCCertificate& certificate) const { + return !(*this == certificate); +} + +} // namespace rtc |