blob: 09d76e61cb0db153a18af26ef08a7a229e5b17c3 [file] [log] [blame]
// 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_