| // 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 CHROMEOS_LOGIN_AUTH_KEY_H_ |
| #define CHROMEOS_LOGIN_AUTH_KEY_H_ |
| |
| #include <string> |
| |
| #include "base/component_export.h" |
| |
| namespace chromeos { |
| |
| // Key for user authentication. The class supports hashing of plain text |
| // passwords to generate keys as well as the use of pre-hashed keys. |
| // |
| // TODO(crbug.com/826417): Consider making this class movable. |
| class COMPONENT_EXPORT(CHROMEOS_LOGIN_AUTH) Key { |
| public: |
| enum KeyType { |
| // Plain text password. |
| // Used in early stages of auth process. |
| KEY_TYPE_PASSWORD_PLAIN = 0, |
| // SHA256 of salt + password, first half only, lower-case hex encoded. |
| // This hashing is used for user password. |
| KEY_TYPE_SALTED_SHA256_TOP_HALF = 1, |
| // PBKDF2 with 256 bit AES and 1234 iterations, base64 encoded. |
| // This hashing is used for user PINs. |
| KEY_TYPE_SALTED_PBKDF2_AES256_1234 = 2, |
| // SHA256 of salt + password, base64 encoded. |
| // This hashing is not used at the moment, it is introduced for |
| // credentials passing API. |
| KEY_TYPE_SALTED_SHA256 = 3, |
| |
| // Sentinel. Must be last. |
| KEY_TYPE_COUNT |
| }; |
| |
| Key(); |
| Key(const Key& other); |
| explicit Key(const std::string& plain_text_password); |
| Key(KeyType key_type, const std::string& salt, const std::string& secret); |
| ~Key(); |
| |
| bool operator==(const Key& other) const; |
| |
| KeyType GetKeyType() const; |
| const std::string& GetSecret() const; |
| const std::string& GetLabel() const; |
| |
| void SetLabel(const std::string& label); |
| |
| void ClearSecret(); |
| |
| void Transform(KeyType target_key_type, const std::string& salt); |
| |
| private: |
| KeyType key_type_; |
| std::string salt_; |
| std::string secret_; |
| std::string label_; |
| }; |
| |
| } // namespace chromeos |
| |
| // TODO(https://crbug.com/1164001): remove after the //chrome/browser/chromeos |
| // source migration is finished. |
| namespace ash { |
| using ::chromeos::Key; |
| } |
| |
| #endif // CHROMEOS_LOGIN_AUTH_KEY_H_ |