// // Copyright (C) 2014 The Android Open Source Project // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // #ifndef UPDATE_ENGINE_UPDATE_MANAGER_REAL_DEVICE_POLICY_PROVIDER_H_ #define UPDATE_ENGINE_UPDATE_MANAGER_REAL_DEVICE_POLICY_PROVIDER_H_ #include #include #include #include #include #include // for FRIEND_TEST #include #if USE_DBUS #include #endif // USE_DBUS #include "update_engine/update_manager/device_policy_provider.h" #include "update_engine/update_manager/generic_variables.h" namespace chromeos_update_manager { // |DevicePolicyProvider| concrete implementation. class RealDevicePolicyProvider : public DevicePolicyProvider { public: #if USE_DBUS RealDevicePolicyProvider( std::unique_ptr session_manager_proxy, policy::PolicyProvider* policy_provider) : policy_provider_(policy_provider), session_manager_proxy_(std::move(session_manager_proxy)) {} #endif // USE_DBUS explicit RealDevicePolicyProvider(policy::PolicyProvider* policy_provider) : policy_provider_(policy_provider) {} ~RealDevicePolicyProvider(); // Initializes the provider and returns whether it succeeded. bool Init(); Variable* var_device_policy_is_loaded() override { return &var_device_policy_is_loaded_; } Variable* var_release_channel() override { return &var_release_channel_; } Variable* var_release_channel_delegated() override { return &var_release_channel_delegated_; } Variable* var_release_lts_tag() override { return &var_release_lts_tag_; } Variable* var_update_disabled() override { return &var_update_disabled_; } Variable* var_target_version_prefix() override { return &var_target_version_prefix_; } Variable* var_rollback_to_target_version() override { return &var_rollback_to_target_version_; } Variable* var_rollback_allowed_milestones() override { return &var_rollback_allowed_milestones_; } Variable* var_scatter_factor() override { return &var_scatter_factor_; } Variable>* var_allowed_connection_types_for_update() override { return &var_allowed_connection_types_for_update_; } Variable* var_has_owner() override { return &var_has_owner_; } Variable* var_http_downloads_enabled() override { return &var_http_downloads_enabled_; } Variable* var_au_p2p_enabled() override { return &var_au_p2p_enabled_; } Variable* var_allow_kiosk_app_control_chrome_version() override { return &var_allow_kiosk_app_control_chrome_version_; } Variable* var_auto_launched_kiosk_app_id() override { return &var_auto_launched_kiosk_app_id_; } Variable* var_disallowed_time_intervals() override { return &var_disallowed_time_intervals_; } Variable* var_channel_downgrade_behavior() override { return &var_channel_downgrade_behavior_; } Variable* var_device_minimum_version() override { return &var_device_minimum_version_; } Variable* var_quick_fix_build_token() override { return &var_quick_fix_build_token_; } private: FRIEND_TEST(UmRealDevicePolicyProviderTest, RefreshScheduledTest); FRIEND_TEST(UmRealDevicePolicyProviderTest, NonExistentDevicePolicyReloaded); FRIEND_TEST(UmRealDevicePolicyProviderTest, ValuesUpdated); FRIEND_TEST(UmRealDevicePolicyProviderTest, HasOwnerConverted); // A static handler for the |PropertyChangedCompleted| signal from the session // manager used as a callback. void OnPropertyChangedCompletedSignal(const std::string& success); // Called when the signal in |UpdateEngineLibcrosProxyResolvedInterface| is // connected. void OnSignalConnected(const std::string& interface_name, const std::string& signal_name, bool successful); // Schedules a call to periodically refresh the device policy. void RefreshDevicePolicyAndReschedule(); // Reloads the device policy and updates all the exposed variables. void RefreshDevicePolicy(); // Updates the async variable |var| based on the result value of the method // passed, which is a DevicePolicy getter method. template void UpdateVariable(AsyncCopyVariable* var, bool (policy::DevicePolicy::*getter)(T*) const); // Updates the async variable |var| based on the result value of the getter // method passed, which is a wrapper getter on this class. template void UpdateVariable(AsyncCopyVariable* var, bool (RealDevicePolicyProvider::*getter)(T*) const); // Wrapper for |DevicePolicy::GetRollbackToTargetVersion()| that converts the // result to |RollbackToTargetVersion|. bool ConvertRollbackToTargetVersion( RollbackToTargetVersion* rollback_to_target_version) const; // Wrapper for |DevicePolicy::GetScatterFactorInSeconds()| that converts the // result to a |base::TimeDelta|. It returns the same value as // |GetScatterFactorInSeconds()|. bool ConvertScatterFactor(base::TimeDelta* scatter_factor) const; // Wrapper for |DevicePolicy::GetAllowedConnectionTypesForUpdate()| that // converts the result to a set of |ConnectionType| elements instead of // strings. bool ConvertAllowedConnectionTypesForUpdate( std::set* allowed_types) const; // Wrapper for |DevicePolicy::GetUpdateTimeRestrictions()| that converts // the |DevicePolicy::WeeklyTimeInterval| structs to |WeeklyTimeInterval| // objects, which offer more functionality. bool ConvertDisallowedTimeIntervals( WeeklyTimeIntervalVector* disallowed_intervals_out) const; // Wrapper for |DevicePolicy::GetOwner()| that converts the result to a // boolean of whether the device has an owner. (Enterprise enrolled // devices do not have an owner). bool ConvertHasOwner(bool* has_owner) const; // Wrapper for |DevicePolicy::GetChannelDowngradeBehavior| that converts the // result to |ChannelDowngradeBehavior|. bool ConvertChannelDowngradeBehavior( ChannelDowngradeBehavior* channel_downgrade_behavior) const; // Used for fetching information about the device policy. policy::PolicyProvider* policy_provider_; // Used to schedule refreshes of the device policy. brillo::MessageLoop::TaskId scheduled_refresh_{ brillo::MessageLoop::kTaskIdNull}; #if USE_DBUS // The DBus (mockable) session manager proxy. std::unique_ptr session_manager_proxy_; #endif // USE_DBUS // Variable exposing whether the policy is loaded. AsyncCopyVariable var_device_policy_is_loaded_{"policy_is_loaded", false}; // Variables mapping the exposed methods from the |policy::DevicePolicy|. AsyncCopyVariable var_release_channel_{"release_channel"}; AsyncCopyVariable var_release_channel_delegated_{ "release_channel_delegated"}; AsyncCopyVariable var_release_lts_tag_{"release_lts_tag"}; AsyncCopyVariable var_update_disabled_{"update_disabled"}; AsyncCopyVariable var_target_version_prefix_{ "target_version_prefix"}; AsyncCopyVariable var_rollback_to_target_version_{ "rollback_to_target_version"}; AsyncCopyVariable var_rollback_allowed_milestones_{ "rollback_allowed_milestones"}; AsyncCopyVariable var_scatter_factor_{"scatter_factor"}; AsyncCopyVariable> var_allowed_connection_types_for_update_{ "allowed_connection_types_for_update"}; AsyncCopyVariable var_has_owner_{"owner"}; AsyncCopyVariable var_http_downloads_enabled_{"http_downloads_enabled"}; AsyncCopyVariable var_au_p2p_enabled_{"au_p2p_enabled"}; AsyncCopyVariable var_allow_kiosk_app_control_chrome_version_{ "allow_kiosk_app_control_chrome_version"}; AsyncCopyVariable var_disallowed_time_intervals_{ "update_time_restrictions"}; AsyncCopyVariable var_auto_launched_kiosk_app_id_{ "auto_launched_kiosk_app_id"}; AsyncCopyVariable var_channel_downgrade_behavior_{ "channel_downgrade_behavior"}; AsyncCopyVariable var_device_minimum_version_{ "device_minimum_version"}; AsyncCopyVariable var_quick_fix_build_token_{ "quick_fix_build_token"}; DISALLOW_COPY_AND_ASSIGN(RealDevicePolicyProvider); }; } // namespace chromeos_update_manager #endif // UPDATE_ENGINE_UPDATE_MANAGER_REAL_DEVICE_POLICY_PROVIDER_H_