OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2004 The WebRTC Project Authors. All rights reserved. | 2 * Copyright 2004 The WebRTC Project Authors. All rights reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
11 #ifndef WEBRTC_BASE_OPENSSLIDENTITY_H_ | 11 #ifndef WEBRTC_BASE_OPENSSLIDENTITY_H_ |
12 #define WEBRTC_BASE_OPENSSLIDENTITY_H_ | 12 #define WEBRTC_BASE_OPENSSLIDENTITY_H_ |
13 | 13 |
14 #include <openssl/evp.h> | 14 #include <openssl/evp.h> |
15 #include <openssl/x509.h> | 15 #include <openssl/x509.h> |
16 | 16 |
| 17 #include <memory> |
17 #include <string> | 18 #include <string> |
18 | 19 |
19 #include "webrtc/base/common.h" | 20 #include "webrtc/base/common.h" |
20 #include "webrtc/base/scoped_ptr.h" | |
21 #include "webrtc/base/sslidentity.h" | 21 #include "webrtc/base/sslidentity.h" |
22 | 22 |
23 typedef struct ssl_ctx_st SSL_CTX; | 23 typedef struct ssl_ctx_st SSL_CTX; |
24 | 24 |
25 namespace rtc { | 25 namespace rtc { |
26 | 26 |
27 // OpenSSLKeyPair encapsulates an OpenSSL EVP_PKEY* keypair object, | 27 // OpenSSLKeyPair encapsulates an OpenSSL EVP_PKEY* keypair object, |
28 // which is reference counted inside the OpenSSL library. | 28 // which is reference counted inside the OpenSSL library. |
29 class OpenSSLKeyPair { | 29 class OpenSSLKeyPair { |
30 public: | 30 public: |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
78 size_t* length) const override; | 78 size_t* length) const override; |
79 | 79 |
80 // Compute the digest of a certificate as an X509 * | 80 // Compute the digest of a certificate as an X509 * |
81 static bool ComputeDigest(const X509* x509, | 81 static bool ComputeDigest(const X509* x509, |
82 const std::string& algorithm, | 82 const std::string& algorithm, |
83 unsigned char* digest, | 83 unsigned char* digest, |
84 size_t size, | 84 size_t size, |
85 size_t* length); | 85 size_t* length); |
86 | 86 |
87 bool GetSignatureDigestAlgorithm(std::string* algorithm) const override; | 87 bool GetSignatureDigestAlgorithm(std::string* algorithm) const override; |
88 rtc::scoped_ptr<SSLCertChain> GetChain() const override; | 88 std::unique_ptr<SSLCertChain> GetChain() const override; |
89 | 89 |
90 int64_t CertificateExpirationTime() const override; | 90 int64_t CertificateExpirationTime() const override; |
91 | 91 |
92 private: | 92 private: |
93 void AddReference() const; | 93 void AddReference() const; |
94 | 94 |
95 X509* x509_; | 95 X509* x509_; |
96 | 96 |
97 RTC_DISALLOW_COPY_AND_ASSIGN(OpenSSLCertificate); | 97 RTC_DISALLOW_COPY_AND_ASSIGN(OpenSSLCertificate); |
98 }; | 98 }; |
(...skipping 14 matching lines...) Expand all Loading... |
113 OpenSSLIdentity* GetReference() const override; | 113 OpenSSLIdentity* GetReference() const override; |
114 | 114 |
115 // Configure an SSL context object to use our key and certificate. | 115 // Configure an SSL context object to use our key and certificate. |
116 bool ConfigureIdentity(SSL_CTX* ctx); | 116 bool ConfigureIdentity(SSL_CTX* ctx); |
117 | 117 |
118 private: | 118 private: |
119 OpenSSLIdentity(OpenSSLKeyPair* key_pair, OpenSSLCertificate* certificate); | 119 OpenSSLIdentity(OpenSSLKeyPair* key_pair, OpenSSLCertificate* certificate); |
120 | 120 |
121 static OpenSSLIdentity* GenerateInternal(const SSLIdentityParams& params); | 121 static OpenSSLIdentity* GenerateInternal(const SSLIdentityParams& params); |
122 | 122 |
123 scoped_ptr<OpenSSLKeyPair> key_pair_; | 123 std::unique_ptr<OpenSSLKeyPair> key_pair_; |
124 scoped_ptr<OpenSSLCertificate> certificate_; | 124 std::unique_ptr<OpenSSLCertificate> certificate_; |
125 | 125 |
126 RTC_DISALLOW_COPY_AND_ASSIGN(OpenSSLIdentity); | 126 RTC_DISALLOW_COPY_AND_ASSIGN(OpenSSLIdentity); |
127 }; | 127 }; |
128 | 128 |
129 | 129 |
130 } // namespace rtc | 130 } // namespace rtc |
131 | 131 |
132 #endif // WEBRTC_BASE_OPENSSLIDENTITY_H_ | 132 #endif // WEBRTC_BASE_OPENSSLIDENTITY_H_ |
OLD | NEW |