blob: 2de865114c487755a3eb73bede2baa4bd7a9e6b0 [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 COMPONENTS_OS_CRYPT_KEYCHAIN_PASSWORD_MAC_H_
#define COMPONENTS_OS_CRYPT_KEYCHAIN_PASSWORD_MAC_H_
#include <string>
#include "base/macros.h"
namespace crypto {
class AppleKeychain;
}
class KeychainPassword {
public:
explicit KeychainPassword(const crypto::AppleKeychain& keychain)
: keychain_(keychain) {
}
// Get the OSCrypt password for this system. If no password exists
// in the Keychain then one is generated, stored in the Mac keychain, and
// returned.
// If one exists then it is fetched from the Keychain and returned.
// If the user disallows access to the Keychain (or an error occurs) then an
// empty string is returned.
std::string GetPassword() const;
// The service and account names used in Chrome's Safe Storage keychain item.
static const char service_name[];
static const char account_name[];
private:
const crypto::AppleKeychain& keychain_;
DISALLOW_COPY_AND_ASSIGN(KeychainPassword);
};
#endif // COMPONENTS_OS_CRYPT_KEYCHAIN_PASSWORD_MAC_H_