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

Side by Side Diff: chrome/common/extensions/api/networking_private/networking_private_crypto.h

Issue 2464663002: chrome: move networking_private_crypto from common to browser (Closed)
Patch Set: chrome/test Created 4 years, 1 month 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 unified diff | Download patch
OLDNEW
(Empty)
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.
4
5 #ifndef CHROME_COMMON_EXTENSIONS_API_NETWORKING_PRIVATE_NETWORKING_PRIVATE_CRYPT O_H_
6 #define CHROME_COMMON_EXTENSIONS_API_NETWORKING_PRIVATE_NETWORKING_PRIVATE_CRYPT O_H_
7
8 #include <stdint.h>
9
10 #include <string>
11 #include <vector>
12
13 #include "base/time/time.h"
14
15 namespace networking_private_crypto {
16
17 // Verify that the credentials described by |certificate| and |signed_data|
18 // are valid as follows:
19 // 1) The MAC address listed in the certificate matches |connected_mac|.
20 // 2) The certificate is a valid PEM encoded certificate signed by trusted CA.
21 // 3) |signature| is a valid signature for |data|, using the public key in
22 // |certificate|
23 bool VerifyCredentials(
24 const std::string& certificate,
25 const std::vector<std::string>& intermediate_certificates,
26 const std::string& signature,
27 const std::string& data,
28 const std::string& connected_mac);
29
30 // The same as VerifyCredentials() above, but uses time |time| rather than the
31 // current time for checking validity.
32 bool VerifyCredentialsAtTime(
33 const std::string& certificate,
34 const std::vector<std::string>& intermediate_certificates,
35 const std::string& signature,
36 const std::string& data,
37 const std::string& connected_mac,
38 const base::Time& time);
39
40 // Encrypt |data| with |public_key|. |public_key| is a DER-encoded
41 // RSAPublicKey. |data| is some string of bytes that is smaller than the
42 // maximum length permissible for PKCS#1 v1.5 with a key of |public_key| size.
43 //
44 // Returns true on success, storing the encrypted result in
45 // |encrypted_output|.
46 bool EncryptByteString(const std::vector<uint8_t>& public_key,
47 const std::string& data,
48 std::vector<uint8_t>* encrypted_output);
49
50 // Decrypt |encrypted_data| with |private_key_pem|. |private_key_pem| is the
51 // PKCS8 PEM-encoded private key. |encrypted_data| is data encrypted with
52 // EncryptByteString. Used in NetworkingPrivateCryptoTest::EncryptString test.
53 // Returns true on success, storing the decrypted result in
54 // |decrypted_output|.
55 bool DecryptByteString(const std::string& private_key_pem,
56 const std::vector<uint8_t>& encrypted_data,
57 std::string* decrypted_output);
58
59 } // namespace networking_private_crypto
60
61 #endif // CHROME_COMMON_EXTENSIONS_API_NETWORKING_PRIVATE_NETWORKING_PRIVATE_CR YPTO_H_
OLDNEW
« no previous file with comments | « chrome/common/BUILD.gn ('k') | chrome/common/extensions/api/networking_private/networking_private_crypto.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698