| Paul Crowley | 1ef2558 | 2016-01-21 20:26:12 +0000 | [diff] [blame] | 1 | /* | 
|  | 2 | * Copyright (C) 2016 The Android Open Source Project | 
|  | 3 | * | 
|  | 4 | * Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | 5 | * you may not use this file except in compliance with the License. | 
|  | 6 | * You may obtain a copy of the License at | 
|  | 7 | * | 
|  | 8 | *      http://www.apache.org/licenses/LICENSE-2.0 | 
|  | 9 | * | 
|  | 10 | * Unless required by applicable law or agreed to in writing, software | 
|  | 11 | * distributed under the License is distributed on an "AS IS" BASIS, | 
|  | 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | 13 | * See the License for the specific language governing permissions and | 
|  | 14 | * limitations under the License. | 
|  | 15 | */ | 
|  | 16 |  | 
|  | 17 | #ifndef ANDROID_VOLD_KEYSTORAGE_H | 
|  | 18 | #define ANDROID_VOLD_KEYSTORAGE_H | 
|  | 19 |  | 
| Pavel Grafov | e2e2d30 | 2017-08-01 17:15:53 +0100 | [diff] [blame] | 20 | #include "KeyBuffer.h" | 
|  | 21 |  | 
| Paul Crowley | 1ef2558 | 2016-01-21 20:26:12 +0000 | [diff] [blame] | 22 | #include <string> | 
|  | 23 |  | 
|  | 24 | namespace android { | 
|  | 25 | namespace vold { | 
|  | 26 |  | 
| Paul Crowley | 0572080 | 2016-02-08 15:55:41 +0000 | [diff] [blame] | 27 | // Represents the information needed to decrypt a disk encryption key. | 
|  | 28 | // If "token" is nonempty, it is passed in as a required Gatekeeper auth token. | 
| Paul Crowley | 6ab2cab | 2017-01-04 22:32:40 -0800 | [diff] [blame] | 29 | // If "token" and "secret" are nonempty, "secret" is appended to the application-specific | 
| Paul Crowley | 0572080 | 2016-02-08 15:55:41 +0000 | [diff] [blame] | 30 | // binary needed to unlock. | 
| Paul Crowley | 6ab2cab | 2017-01-04 22:32:40 -0800 | [diff] [blame] | 31 | // If only "secret" is nonempty, it is used to decrypt in a non-Keymaster process. | 
| Paul Crowley | 0572080 | 2016-02-08 15:55:41 +0000 | [diff] [blame] | 32 | class KeyAuthentication { | 
| Paul Crowley | df528a7 | 2016-03-09 09:31:37 -0800 | [diff] [blame] | 33 | public: | 
|  | 34 | KeyAuthentication(std::string t, std::string s) : token{t}, secret{s} {}; | 
| Paul Crowley | 6ab2cab | 2017-01-04 22:32:40 -0800 | [diff] [blame] | 35 |  | 
|  | 36 | bool usesKeymaster() const { return !token.empty() || secret.empty(); }; | 
|  | 37 |  | 
| Paul Crowley | 0572080 | 2016-02-08 15:55:41 +0000 | [diff] [blame] | 38 | const std::string token; | 
|  | 39 | const std::string secret; | 
|  | 40 | }; | 
|  | 41 |  | 
|  | 42 | extern const KeyAuthentication kEmptyAuthentication; | 
|  | 43 |  | 
| Paul Crowley | f71ace3 | 2016-06-02 11:01:19 -0700 | [diff] [blame] | 44 | // Checks if path "path" exists. | 
|  | 45 | bool pathExists(const std::string& path); | 
|  | 46 |  | 
| Paul Crowley | 26a5388 | 2017-10-26 11:16:39 -0700 | [diff] [blame] | 47 | bool createSecdiscardable(const std::string& path, std::string* hash); | 
|  | 48 | bool readSecdiscardable(const std::string& path, std::string* hash); | 
|  | 49 |  | 
| Paul Crowley | 1ef2558 | 2016-01-21 20:26:12 +0000 | [diff] [blame] | 50 | // Create a directory at the named path, and store "key" in it, | 
|  | 51 | // in such a way that it can only be retrieved via Keymaster and | 
|  | 52 | // can be securely deleted. | 
|  | 53 | // It's safe to move/rename the directory after creation. | 
| Pavel Grafov | e2e2d30 | 2017-08-01 17:15:53 +0100 | [diff] [blame] | 54 | bool storeKey(const std::string& dir, const KeyAuthentication& auth, const KeyBuffer& key); | 
| Paul Crowley | 1ef2558 | 2016-01-21 20:26:12 +0000 | [diff] [blame] | 55 |  | 
| Paul Crowley | f71ace3 | 2016-06-02 11:01:19 -0700 | [diff] [blame] | 56 | // Create a directory at the named path, and store "key" in it as storeKey | 
|  | 57 | // This version creates the key in "tmp_path" then atomically renames "tmp_path" | 
|  | 58 | // to "key_path" thereby ensuring that the key is either stored entirely or | 
|  | 59 | // not at all. | 
|  | 60 | bool storeKeyAtomically(const std::string& key_path, const std::string& tmp_path, | 
| Pavel Grafov | e2e2d30 | 2017-08-01 17:15:53 +0100 | [diff] [blame] | 61 | const KeyAuthentication& auth, const KeyBuffer& key); | 
| Paul Crowley | f71ace3 | 2016-06-02 11:01:19 -0700 | [diff] [blame] | 62 |  | 
| Paul Crowley | 1ef2558 | 2016-01-21 20:26:12 +0000 | [diff] [blame] | 63 | // Retrieve the key from the named directory. | 
| Pavel Grafov | e2e2d30 | 2017-08-01 17:15:53 +0100 | [diff] [blame] | 64 | bool retrieveKey(const std::string& dir, const KeyAuthentication& auth, KeyBuffer* key); | 
| Paul Crowley | 1ef2558 | 2016-01-21 20:26:12 +0000 | [diff] [blame] | 65 |  | 
|  | 66 | // Securely destroy the key stored in the named directory and delete the directory. | 
| Paul Crowley | df528a7 | 2016-03-09 09:31:37 -0800 | [diff] [blame] | 67 | bool destroyKey(const std::string& dir); | 
| Paul Crowley | 1ef2558 | 2016-01-21 20:26:12 +0000 | [diff] [blame] | 68 |  | 
| Rubin Xu | 2436e27 | 2017-04-27 20:43:10 +0100 | [diff] [blame] | 69 | bool runSecdiscardSingle(const std::string& file); | 
| Paul Crowley | 1ef2558 | 2016-01-21 20:26:12 +0000 | [diff] [blame] | 70 | }  // namespace vold | 
|  | 71 | }  // namespace android | 
|  | 72 |  | 
|  | 73 | #endif |