Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(260)

Unified Diff: components/ownership/owner_key_util.h

Issue 494093002: OwnerKeyUtil is moved to components/ownership. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fixes. Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « components/ownership/mock_owner_key_util.cc ('k') | components/ownership/owner_key_util.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/ownership/owner_key_util.h
diff --git a/components/ownership/owner_key_util.h b/components/ownership/owner_key_util.h
new file mode 100644
index 0000000000000000000000000000000000000000..24ae621ad0d5a47dde5577eeb40b0aaa5a12f9f5
--- /dev/null
+++ b/components/ownership/owner_key_util.h
@@ -0,0 +1,104 @@
+// Copyright 2014 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.
+
+#ifndef COMPONENTS_OWNERSHIP_OWNER_KEY_UTIL_H_
+#define COMPONENTS_OWNERSHIP_OWNER_KEY_UTIL_H_
+
+#include <string>
+#include <vector>
+
+#include "base/basictypes.h"
erikwright (departed) 2014/08/28 19:41:38 same comment.
ygorshenin1 2014/08/29 10:28:58 I need basictypes.h for the definition of uint8.
+#include "base/macros.h"
+#include "base/memory/ref_counted.h"
+#include "base/memory/scoped_ptr.h"
+#include "base/stl_util.h"
+#include "components/ownership/ownership_export.h"
+
+#if defined(USE_NSS)
+struct PK11SlotInfoStr;
+typedef struct PK11SlotInfoStr PK11SlotInfo;
+#endif // defined(USE_NSS)
+
+namespace crypto {
+class RSAPrivateKey;
+}
+
+namespace ownership {
+
+class OwnerKeyUtilTest;
+
+// This class is a ref-counted wrapper around plain public key.
erikwright (departed) 2014/08/28 19:41:38 _a_ plain public key.
ygorshenin1 2014/08/29 10:28:58 Done.
+class OWNERSHIP_EXPORT PublicKey
+ : public base::RefCountedThreadSafe<PublicKey> {
+ public:
+ PublicKey();
+
+ std::vector<uint8>& data() { return data_; }
+
+ bool is_loaded() const { return !data_.empty(); }
+
+ std::string as_string() {
+ return std::string(reinterpret_cast<const char*>(vector_as_array(&data_)),
+ data_.size());
+ }
+
+ private:
+ friend class base::RefCountedThreadSafe<PublicKey>;
+
+ virtual ~PublicKey();
+
+ std::vector<uint8> data_;
+
+ DISALLOW_COPY_AND_ASSIGN(PublicKey);
+};
+
+// This class is a ref-counted wrapper around crypto::RSAPrivateKey.
+class OWNERSHIP_EXPORT PrivateKey
+ : public base::RefCountedThreadSafe<PrivateKey> {
+ public:
+ explicit PrivateKey(crypto::RSAPrivateKey* key);
+
+ crypto::RSAPrivateKey* key() { return key_.get(); }
+
+ private:
+ friend class base::RefCountedThreadSafe<PrivateKey>;
+
+ virtual ~PrivateKey();
+
+ scoped_ptr<crypto::RSAPrivateKey> key_;
+
+ DISALLOW_COPY_AND_ASSIGN(PrivateKey);
+};
+
+// This class is a helper class that allows to import public/private
+// parts of the owner key.
+class OWNERSHIP_EXPORT OwnerKeyUtil
erikwright (departed) 2014/08/28 19:41:38 Do pure-virtual classes need EXPORT? Check for con
ygorshenin1 2014/08/29 10:28:58 Done.
+ : public base::RefCountedThreadSafe<OwnerKeyUtil> {
+ public:
+ // Attempts to read the public key from the file system. Upon success,
+ // returns true and populates |output|. False on failure.
+ virtual bool ImportPublicKey(std::vector<uint8>* output) = 0;
+
+#if defined(USE_NSS)
+ // Looks for the private key associated with |key| in the |slot|
+ // and returns it if it can be found. Returns NULL otherwise.
+ // Caller takes ownership.
+ virtual crypto::RSAPrivateKey* FindPrivateKeyInSlot(
+ const std::vector<uint8>& key,
+ PK11SlotInfo* slot) = 0;
+#endif // defined(USE_NSS)
+
+ // Checks whether the public key is present in the file system.
+ virtual bool IsPublicKeyPresent() = 0;
+
+ protected:
+ virtual ~OwnerKeyUtil() {}
+
+ private:
+ friend class base::RefCountedThreadSafe<OwnerKeyUtil>;
+};
+
+} // namespace ownership
+
+#endif // COMPONENTS_OWNERSHIP_OWNER_KEY_UTIL_H_
« no previous file with comments | « components/ownership/mock_owner_key_util.cc ('k') | components/ownership/owner_key_util.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698