Roll src/third_party/WebKit f36d5e0:68b67cd (svn 193299:193303)
[chromium-blink-merge.git] / components / ownership / owner_key_util_impl.cc
blob46b0b6a65ae353381b36f3ad4ed688e0c7c35da8
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "components/ownership/owner_key_util_impl.h"
7 #include <limits>
9 #include "base/files/file_util.h"
10 #include "base/logging.h"
11 #include "crypto/rsa_private_key.h"
13 namespace ownership {
15 OwnerKeyUtilImpl::OwnerKeyUtilImpl(const base::FilePath& public_key_file)
16 : public_key_file_(public_key_file) {
19 OwnerKeyUtilImpl::~OwnerKeyUtilImpl() {
22 bool OwnerKeyUtilImpl::ImportPublicKey(std::vector<uint8>* output) {
23 // Get the file size (must fit in a 32 bit int for NSS).
24 int64 file_size;
25 if (!base::GetFileSize(public_key_file_, &file_size)) {
26 #if defined(OS_CHROMEOS)
27 LOG(ERROR) << "Could not get size of " << public_key_file_.value();
28 #endif // defined(OS_CHROMEOS)
29 return false;
31 if (file_size > static_cast<int64>(std::numeric_limits<int>::max())) {
32 LOG(ERROR) << public_key_file_.value() << "is " << file_size
33 << "bytes!!! Too big!";
34 return false;
36 int32 safe_file_size = static_cast<int32>(file_size);
38 output->resize(safe_file_size);
40 if (safe_file_size == 0) {
41 LOG(WARNING) << "Public key file is empty. This seems wrong.";
42 return false;
45 // Get the key data off of disk
46 int data_read =
47 base::ReadFile(public_key_file_,
48 reinterpret_cast<char*>(vector_as_array(output)),
49 safe_file_size);
50 return data_read == safe_file_size;
53 #if defined(USE_NSS)
54 crypto::RSAPrivateKey* OwnerKeyUtilImpl::FindPrivateKeyInSlot(
55 const std::vector<uint8>& key,
56 PK11SlotInfo* slot) {
57 return crypto::RSAPrivateKey::FindFromPublicKeyInfoInSlot(key, slot);
59 #endif // defined(USE_NSS)
61 bool OwnerKeyUtilImpl::IsPublicKeyPresent() {
62 return base::PathExists(public_key_file_);
65 } // namespace ownership