/* * 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.
*/
class SSLCertChain; class SSLCertificate; class SSLIdentity;
// This class contains PEM strings of an RTCCertificate's private key and // certificate and acts as a text representation of RTCCertificate. Certificates // can be serialized and deserialized to and from this format, which allows for // cloning and storing of certificates to disk. The PEM format is that of // `SSLIdentity::PrivateKeyToPEMString` and `SSLCertificate::ToPEMString`, e.g. // the string representations used by OpenSSL. class RTCCertificatePEM { public:
RTCCertificatePEM(absl::string_view private_key,
absl::string_view certificate)
: private_key_(private_key), certificate_(certificate) {}
// A thin abstraction layer between "lower level crypto stuff" like // SSLCertificate and WebRTC usage. Takes ownership of some lower level objects, // reference counting protects these from premature destruction. class RTC_EXPORT RTCCertificate final
: public RefCountedNonVirtual<RTCCertificate> { public: // Takes ownership of `identity`. static scoped_refptr<RTCCertificate> Create(
std::unique_ptr<SSLIdentity> identity);
// Returns the expiration time in ms relative to epoch, 1970-01-01T00:00:00Z.
uint64_t Expires() const; // Checks if the certificate has expired, where `now` is expressed in ms // relative to epoch, 1970-01-01T00:00:00Z. bool HasExpired(uint64_t now) const;
// TODO(hbos): If possible, remove once RTCCertificate and its // GetSSLCertificate() is used in all relevant places. Should not pass around // raw SSLIdentity* for the sake of accessing SSLIdentity::certificate(). // However, some places might need SSLIdentity* for its public/private key...
SSLIdentity* identity() const { return identity_.get(); }
// To/from PEM, a text representation of the RTCCertificate.
RTCCertificatePEM ToPEM() const; // Can return nullptr if the certificate is invalid. static scoped_refptr<RTCCertificate> FromPEM(const RTCCertificatePEM& pem); booloperator==(const RTCCertificate& certificate) const; booloperator!=(const RTCCertificate& certificate) const;
private: // The SSLIdentity is the owner of the SSLCertificate. To protect our // GetSSLCertificate() we take ownership of `identity_`. const std::unique_ptr<SSLIdentity> identity_;
};
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.