// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "net/base/openssl_private_key_store.h" #include #include #include #include "base/logging.h" #include "base/memory/singleton.h" #include "crypto/auto_cbb.h" #include "crypto/openssl_util.h" #include "crypto/scoped_openssl_types.h" #include "net/android/network_library.h" namespace net { bool OpenSSLPrivateKeyStore::StoreKeyPair(const GURL& url, EVP_PKEY* pkey) { // Always clear openssl errors on exit. crypto::OpenSSLErrStackTracer err_trace(FROM_HERE); uint8_t* public_key; size_t public_len; crypto::AutoCBB cbb; if (!CBB_init(cbb.get(), 0) || !EVP_marshal_public_key(cbb.get(), pkey) || !CBB_finish(cbb.get(), &public_key, &public_len)) { return false; } crypto::ScopedOpenSSLBytes free_public_key(public_key); uint8_t* private_key; size_t private_len; cbb.Reset(); if (!CBB_init(cbb.get(), 0) || !EVP_marshal_private_key(cbb.get(), pkey) || !CBB_finish(cbb.get(), &private_key, &private_len)) { return false; } crypto::ScopedOpenSSLBytes free_private_key(private_key); if (!android::StoreKeyPair(public_key, public_len, private_key, private_len)) { LOG(ERROR) << "StoreKeyPair failed. public_len = " << public_len << " private_len = " << private_len; } return true; } } // namespace net