1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
|
// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_ASH_POLICY_ENROLLMENT_ENROLLMENT_STATE_FETCHER_H_
#define CHROME_BROWSER_ASH_POLICY_ENROLLMENT_ENROLLMENT_STATE_FETCHER_H_
#include <memory>
#include "base/functional/callback.h"
#include "base/memory/scoped_refptr.h"
#include "chrome/browser/ash/policy/enrollment/auto_enrollment_state.h"
#include "components/policy/core/common/cloud/device_management_service.h"
#include "components/prefs/pref_registry_simple.h"
#include "third_party/private_membership/src/private_membership_rlwe.pb.h"
#include "third_party/private_membership/src/private_membership_rlwe_client.h"
// Forward declarations
class PrefService;
namespace ash {
class DeviceSettingsService;
class OobeConfiguration;
}
namespace network {
class SharedURLLoaderFactory;
}
namespace private_membership::rlwe {
class PrivateMembershipRlweClient;
}
namespace policy {
class DeviceManagementService;
class ServerBackedStateKeysBroker;
// This class asynchronously determines the enrollment state by querying state
// availability via PSM and - if state is available - requesting the enrollment
// state from the DMServer.
//
// The operation is aborted with state kNoEnrollment:
// * when device ownership is taken or unknown,
// * when RLZ brand code or serial number are missing
// All these values are retrieved using StatisticsProvider, which can be faked
// using `FakeStatisticsProvider` in tests.
//
// Additionally, the operation can be aborted with state kConnectionError:
// * when system clock failed to synchronize, or
// * server-backed state keys could not be retrieved.
//
// The operation will be concluded by calling `report_result` with the retrieved
// enrollment state or error. Enrollment states can be:
// * kDisabled,
// * kEnrollment, or
// * kNoEnrollment.
// In case we retrieved state, i.e. there was no error, additional details are
// stored as a dictionary under key `prefs::kServerBackedDeviceState` in
// `local_state`, which can contain entries with the following keys and values:
// * kDeviceStateMode:
// * empty string (used when the state is kNoEnrollment),
// * kDeviceStateInitialModeEnrollmentEnforced,
// * kDeviceStateInitialModeEnrollmentZeroTouch,
// * kDeviceStateInitialModeTokenEnrollment,
// * kDeviceStateModeDisabled,
// * kDeviceStateRestoreModeReEnrollmentEnforced,
// * kDeviceStateRestoreModeReEnrollmentRequested, or
// * kDeviceStateRestoreModeReEnrollmentZeroTouch,
// * kDeviceStateManagementDomain:
// * domain name or email address of the device owner;
// * kDeviceStateDisabledMessage:
// * message shown to the user in case the device is disabled;
// * kDeviceStateLicenseType:
// * empty string,
// * kDeviceStateLicenseTypeEnterprise,
// * kDeviceStateLicenseTypeEducation, or
// * kDeviceStateLicenseTypeTerminal;
// * kDeviceStatePackagedLicense:
// * whether the device has a packaged license (true) or not (false);
// * kDeviceStateAssignedUpgradeType:
// * empty string,
// * kDeviceStateAssignedUpgradeTypeChromeEnterprise, or
// * kDeviceStateAssignedUpgradeTypeKiosk.
class EnrollmentStateFetcher {
public:
using RlweClient = private_membership::rlwe::PrivateMembershipRlweClient;
using RlweClientFactory = base::RepeatingCallback<std::unique_ptr<RlweClient>(
private_membership::rlwe::RlweUseCase,
const private_membership::rlwe::RlwePlaintextId&)>;
using Factory =
base::RepeatingCallback<std::unique_ptr<EnrollmentStateFetcher>(
base::OnceCallback<void(AutoEnrollmentState)> report_result,
PrefService* local_state,
RlweClientFactory rlwe_client_factory,
DeviceManagementService* device_management_service,
scoped_refptr<network::SharedURLLoaderFactory> url_loader_factory,
ServerBackedStateKeysBroker* state_key_broker,
ash::DeviceSettingsService* device_settings_service,
ash::OobeConfiguration* oobe_configuration)>;
// Creates an instance of EnrollmentStateFetcher.
//
// Does not take ownership of any passed raw pointers.
static std::unique_ptr<EnrollmentStateFetcher> Create(
base::OnceCallback<void(AutoEnrollmentState)> report_result,
PrefService* local_state,
RlweClientFactory rlwe_client_factory,
DeviceManagementService* device_management_service,
scoped_refptr<network::SharedURLLoaderFactory> url_loader_factory,
ServerBackedStateKeysBroker* state_key_broker,
ash::DeviceSettingsService* device_settings_service,
ash::OobeConfiguration* oobe_configuration);
static void RegisterPrefs(PrefRegistrySimple* registry);
virtual ~EnrollmentStateFetcher();
virtual void Start() = 0;
};
} // namespace policy
#endif // CHROME_BROWSER_ASH_POLICY_ENROLLMENT_ENROLLMENT_STATE_FETCHER_H_
|