1*d9f75844SAndroid Build Coastguard Worker /* 2*d9f75844SAndroid Build Coastguard Worker * Copyright 2020 The WebRTC Project Authors. All rights reserved. 3*d9f75844SAndroid Build Coastguard Worker * 4*d9f75844SAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license 5*d9f75844SAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source 6*d9f75844SAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found 7*d9f75844SAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may 8*d9f75844SAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree. 9*d9f75844SAndroid Build Coastguard Worker */ 10*d9f75844SAndroid Build Coastguard Worker 11*d9f75844SAndroid Build Coastguard Worker #ifndef RTC_BASE_OPENSSL_KEY_PAIR_H_ 12*d9f75844SAndroid Build Coastguard Worker #define RTC_BASE_OPENSSL_KEY_PAIR_H_ 13*d9f75844SAndroid Build Coastguard Worker 14*d9f75844SAndroid Build Coastguard Worker #include <openssl/ossl_typ.h> 15*d9f75844SAndroid Build Coastguard Worker 16*d9f75844SAndroid Build Coastguard Worker #include <memory> 17*d9f75844SAndroid Build Coastguard Worker #include <string> 18*d9f75844SAndroid Build Coastguard Worker 19*d9f75844SAndroid Build Coastguard Worker #include "absl/strings/string_view.h" 20*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/checks.h" 21*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/ssl_identity.h" 22*d9f75844SAndroid Build Coastguard Worker 23*d9f75844SAndroid Build Coastguard Worker namespace rtc { 24*d9f75844SAndroid Build Coastguard Worker 25*d9f75844SAndroid Build Coastguard Worker // OpenSSLKeyPair encapsulates an OpenSSL EVP_PKEY* keypair object, 26*d9f75844SAndroid Build Coastguard Worker // which is reference counted inside the OpenSSL library. 27*d9f75844SAndroid Build Coastguard Worker class OpenSSLKeyPair final { 28*d9f75844SAndroid Build Coastguard Worker public: 29*d9f75844SAndroid Build Coastguard Worker // Takes ownership of the key. OpenSSLKeyPair(EVP_PKEY * pkey)30*d9f75844SAndroid Build Coastguard Worker explicit OpenSSLKeyPair(EVP_PKEY* pkey) : pkey_(pkey) { 31*d9f75844SAndroid Build Coastguard Worker RTC_DCHECK(pkey_ != nullptr); 32*d9f75844SAndroid Build Coastguard Worker } 33*d9f75844SAndroid Build Coastguard Worker 34*d9f75844SAndroid Build Coastguard Worker static std::unique_ptr<OpenSSLKeyPair> Generate(const KeyParams& key_params); 35*d9f75844SAndroid Build Coastguard Worker // Constructs a key pair from the private key PEM string. This must not result 36*d9f75844SAndroid Build Coastguard Worker // in missing public key parameters. Returns null on error. 37*d9f75844SAndroid Build Coastguard Worker static std::unique_ptr<OpenSSLKeyPair> FromPrivateKeyPEMString( 38*d9f75844SAndroid Build Coastguard Worker absl::string_view pem_string); 39*d9f75844SAndroid Build Coastguard Worker 40*d9f75844SAndroid Build Coastguard Worker ~OpenSSLKeyPair(); 41*d9f75844SAndroid Build Coastguard Worker 42*d9f75844SAndroid Build Coastguard Worker OpenSSLKeyPair(const OpenSSLKeyPair&) = delete; 43*d9f75844SAndroid Build Coastguard Worker OpenSSLKeyPair& operator=(const OpenSSLKeyPair&) = delete; 44*d9f75844SAndroid Build Coastguard Worker 45*d9f75844SAndroid Build Coastguard Worker std::unique_ptr<OpenSSLKeyPair> Clone(); 46*d9f75844SAndroid Build Coastguard Worker pkey()47*d9f75844SAndroid Build Coastguard Worker EVP_PKEY* pkey() const { return pkey_; } 48*d9f75844SAndroid Build Coastguard Worker std::string PrivateKeyToPEMString() const; 49*d9f75844SAndroid Build Coastguard Worker std::string PublicKeyToPEMString() const; 50*d9f75844SAndroid Build Coastguard Worker bool operator==(const OpenSSLKeyPair& other) const; 51*d9f75844SAndroid Build Coastguard Worker bool operator!=(const OpenSSLKeyPair& other) const; 52*d9f75844SAndroid Build Coastguard Worker 53*d9f75844SAndroid Build Coastguard Worker private: 54*d9f75844SAndroid Build Coastguard Worker void AddReference(); 55*d9f75844SAndroid Build Coastguard Worker 56*d9f75844SAndroid Build Coastguard Worker EVP_PKEY* pkey_; 57*d9f75844SAndroid Build Coastguard Worker }; 58*d9f75844SAndroid Build Coastguard Worker 59*d9f75844SAndroid Build Coastguard Worker } // namespace rtc 60*d9f75844SAndroid Build Coastguard Worker 61*d9f75844SAndroid Build Coastguard Worker #endif // RTC_BASE_OPENSSL_KEY_PAIR_H_ 62