| // Copyright 2018 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 CHROME_BROWSER_CHROMEOS_POLICY_ARC_APP_INSTALL_EVENT_LOGGER_H_ |
| #define CHROME_BROWSER_CHROMEOS_POLICY_ARC_APP_INSTALL_EVENT_LOGGER_H_ |
| |
| #include <memory> |
| #include <set> |
| #include <string> |
| |
| #include "base/files/file_path.h" |
| #include "base/macros.h" |
| #include "base/memory/weak_ptr.h" |
| #include "chrome/browser/ash/arc/policy/arc_policy_bridge.h" |
| #include "chrome/browser/chromeos/policy/arc_app_install_event_log_collector.h" |
| #include "chrome/browser/chromeos/policy/install_event_logger_base.h" |
| #include "components/policy/core/common/policy_service.h" |
| #include "components/policy/proto/device_management_backend.pb.h" |
| |
| class Profile; |
| |
| namespace base { |
| class Value; |
| } |
| |
| namespace user_prefs { |
| class PrefRegistrySyncable; |
| } |
| |
| namespace policy { |
| |
| class PolicyMap; |
| struct PolicyNamespace; |
| |
| // Ensures that events relevant to app push-installs are logged. Three types of |
| // events are logged directly by this class: |
| // * When an app is added to the push-install list in policy, the start of its |
| // push-install process is logged. |
| // * When an app disappears from the non-compliance list returned by CloudDPC, |
| // the successful end of its push-install process is logged. |
| // * When an app is removed from the push-install list in policy, the end of its |
| // push-install process is logged. |
| // |
| // Additionally, an |ArcAppInstallEventLogCollector| is instantiated to collect |
| // detailed logs of the push-install process whenever there is at least one |
| // pending push-install request. |
| class ArcAppInstallEventLogger |
| : public InstallEventLoggerBase< |
| enterprise_management::AppInstallReportLogEvent, |
| enterprise_management::AppInstallReportLogEvent::EventType, |
| std::string>, |
| public ArcAppInstallEventLogCollector::Delegate, |
| public policy::PolicyService::Observer, |
| public arc::ArcPolicyBridge::Observer { |
| public: |
| // The delegate that events are forwarded to for inclusion in the log. |
| class Delegate { |
| public: |
| // Adds an identical log entry for every app in |packages|. |
| virtual void Add( |
| const std::set<std::string>& packages, |
| const enterprise_management::AppInstallReportLogEvent& event) = 0; |
| |
| using AndroidIdCallback = |
| base::OnceCallback<void(bool ok, int64_t android_id)>; |
| |
| virtual void GetAndroidId(AndroidIdCallback callback) const = 0; |
| |
| protected: |
| virtual ~Delegate() = default; |
| }; |
| |
| // Delegate must outlive |this|. |
| ArcAppInstallEventLogger(Delegate* delegate, Profile* profile); |
| ~ArcAppInstallEventLogger() override; |
| |
| ArcAppInstallEventLogger& operator=(const ArcAppInstallEventLogger&) = delete; |
| ArcAppInstallEventLogger(const ArcAppInstallEventLogger&) = delete; |
| |
| // Registers the prefs used to keep track of push-installs that have been |
| // requested and not yet completed. |
| static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry); |
| |
| // Clears all data related to app-install event log collection for |profile|. |
| // Must not be called while an |ArcAppInstallEventLogger| exists for |
| // |profile|. |
| static void Clear(Profile* profile); |
| |
| // ArcAppInstallEventLogCollector::Delegate: |
| void AddForAllPackages( |
| std::unique_ptr<enterprise_management::AppInstallReportLogEvent> event) |
| override; |
| void Add(const std::string& package, |
| bool gather_disk_space_info, |
| std::unique_ptr<enterprise_management::AppInstallReportLogEvent> |
| event) override; |
| |
| // policy::PolicyService::Observer: |
| void OnPolicyUpdated(const policy::PolicyNamespace& ns, |
| const policy::PolicyMap& previous, |
| const policy::PolicyMap& current) override; |
| |
| // arc::ArcPolicyBridge::Observer: |
| void OnPolicySent(const std::string& policy) override; |
| void OnComplianceReportReceived( |
| const base::Value* compliance_report) override; |
| |
| private: |
| // Loads a list of packages from a pref. |
| std::set<std::string> GetPackagesFromPref(const std::string& pref_name) const; |
| |
| // Stores a list of packages into a pref. |
| void SetPref(const std::string& pref_name, |
| const std::set<std::string>& packages); |
| |
| // Informs the existing |log_collector_| that the list of pending app |
| // push-install requests has changed or instantiates a new |log_collector_| if |
| // none exists yet. |
| void UpdateCollector(const std::set<std::string>& pending); |
| |
| // Destroys the |log_collector_|, if it exists. |
| void StopCollector(); |
| |
| // Extracts the list of app push-install requests from |policy|, logs the |
| // cancellation of any pending push-installs that are no longer in |policy| |
| // and updates the |log_collector_|. |
| void EvaluatePolicy(const policy::PolicyMap& policy, bool initial); |
| |
| // Override for InstallEventLoggerBase::AddForSetOfApps. |
| void AddForSetOfApps( |
| const std::set<std::string>& packages, |
| std::unique_ptr<enterprise_management::AppInstallReportLogEvent> event) |
| override; |
| |
| void OnGetAndroidId( |
| const std::set<std::string>& packages, |
| std::unique_ptr<enterprise_management::AppInstallReportLogEvent> event, |
| bool ok, |
| int64_t android_id); |
| |
| // The delegate that events are forwarded to for inclusion in the log. |
| Delegate* const delegate_; |
| |
| // Whether |this| has set itself up as observer of other classes and needs to |
| // remove itself as observer in the destructor. |
| bool observing_ = false; |
| |
| // The app push-install requests that were most recently sent to CloudDPC. |
| std::set<std::string> requested_in_arc_; |
| |
| // The |ArcAppInstallEventLogCollector| that collects detailed logs of the |
| // push-install process. Non-|nullptr| whenever there are one or more pending |
| // app push-install requests. |
| std::unique_ptr<ArcAppInstallEventLogCollector> log_collector_; |
| |
| // Weak factory used to reference |this| from background tasks. |
| base::WeakPtrFactory<ArcAppInstallEventLogger> weak_factory_{this}; |
| }; |
| |
| } // namespace policy |
| |
| #endif // CHROME_BROWSER_CHROMEOS_POLICY_ARC_APP_INSTALL_EVENT_LOGGER_H_ |