blob: 14a3590214cfcb59dc4251d0dc90290e4b0fb987 [file] [log] [blame]
// Copyright 2016 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_KEY_STORAGE_UTIL_LINUX_H_
#define COMPONENTS_OS_CRYPT_KEY_STORAGE_UTIL_LINUX_H_
#include <string>
#include "base/component_export.h"
#include "base/nix/xdg_util.h"
namespace base {
class FilePath;
}
namespace os_crypt {
// The supported Linux backends for storing passwords.
enum class SelectedLinuxBackend {
DEFER, // No selection
BASIC_TEXT,
GNOME_ANY, // GNOME_KEYRING or GNOME_LIBSECRET, whichever is available.
GNOME_KEYRING,
GNOME_LIBSECRET,
KWALLET,
KWALLET5,
};
// Decide which backend to target. |type| is checked first. If it does not
// match a supported backend and |use_backend| is true, |desktop_env| will be
// used to decide.
// TODO(crbug/571003): This is exposed as a utility only for password manager to
// use. It should be merged into key_storage_linux, once no longer needed in
// password manager.
SelectedLinuxBackend COMPONENT_EXPORT(OS_CRYPT)
SelectBackend(const std::string& type,
bool use_backend,
base::nix::DesktopEnvironment desktop_env);
// Set the setting that disables using OS-level encryption. If |use| is true,
// a backend will be used.
bool COMPONENT_EXPORT(OS_CRYPT)
WriteBackendUse(const base::FilePath& user_data_dir, bool use);
// Decide whether the backend should be used based on the setting.
bool COMPONENT_EXPORT(OS_CRYPT)
GetBackendUse(const base::FilePath& user_data_dir);
} // namespace os_crypt
#endif // COMPONENTS_OS_CRYPT_KEY_STORAGE_UTIL_LINUX_H_