OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/chromeos/arc/arc_enterprise_reporting_service.h" | 5 #include "chrome/browser/chromeos/arc/arc_enterprise_reporting_service.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
11 #include "chrome/browser/chromeos/arc/arc_auth_service.h" | 11 #include "chrome/browser/chromeos/arc/arc_auth_service.h" |
12 #include "components/arc/arc_service_manager.h" | 12 #include "components/arc/arc_service_manager.h" |
13 #include "components/arc/user_data/arc_user_data_service.h" | 13 #include "components/arc/user_data/arc_user_data_service.h" |
14 | 14 |
15 namespace arc { | 15 namespace arc { |
16 | 16 |
17 ArcEnterpriseReportingService::ArcEnterpriseReportingService( | 17 ArcEnterpriseReportingService::ArcEnterpriseReportingService( |
18 ArcBridgeService* bridge_service) | 18 ArcBridgeService* bridge_service) |
19 : ArcService(bridge_service), binding_(this), weak_ptr_factory_(this) { | 19 : ArcService(bridge_service), binding_(this), weak_ptr_factory_(this) { |
20 arc_bridge_service()->enterprise_reporting()->AddObserver(this); | 20 arc_bridge_service()->enterprise_reporting()->AddObserver(this); |
21 } | 21 } |
22 | 22 |
23 ArcEnterpriseReportingService::~ArcEnterpriseReportingService() { | 23 ArcEnterpriseReportingService::~ArcEnterpriseReportingService() { |
24 DCHECK(thread_checker_.CalledOnValidThread()); | 24 DCHECK(thread_checker_.CalledOnValidThread()); |
25 arc_bridge_service()->enterprise_reporting()->RemoveObserver(this); | 25 arc_bridge_service()->enterprise_reporting()->RemoveObserver(this); |
26 } | 26 } |
27 | 27 |
28 void ArcEnterpriseReportingService::OnInstanceReady() { | 28 void ArcEnterpriseReportingService::OnInstanceReady() { |
29 DCHECK(thread_checker_.CalledOnValidThread()); | 29 DCHECK(thread_checker_.CalledOnValidThread()); |
30 arc_bridge_service()->enterprise_reporting()->instance()->Init( | 30 auto* instance = |
31 binding_.CreateInterfacePtrAndBind()); | 31 arc_bridge_service()->enterprise_reporting()->GetInstanceForMethod( |
| 32 "Init"); |
| 33 if (!instance) |
| 34 return; |
| 35 instance->Init(binding_.CreateInterfacePtrAndBind()); |
32 } | 36 } |
33 | 37 |
34 void ArcEnterpriseReportingService::ReportManagementState( | 38 void ArcEnterpriseReportingService::ReportManagementState( |
35 mojom::ManagementState state) { | 39 mojom::ManagementState state) { |
36 DCHECK(thread_checker_.CalledOnValidThread()); | 40 DCHECK(thread_checker_.CalledOnValidThread()); |
37 VLOG(1) << "ReportManagementState state=" << state; | 41 VLOG(1) << "ReportManagementState state=" << state; |
38 | 42 |
39 if (state == mojom::ManagementState::MANAGED_DO_LOST) { | 43 if (state == mojom::ManagementState::MANAGED_DO_LOST) { |
40 DCHECK(arc::ArcServiceManager::Get()); | 44 DCHECK(arc::ArcServiceManager::Get()); |
41 ArcAuthService::Get()->RemoveArcData(); | 45 ArcAuthService::Get()->RemoveArcData(); |
42 ArcAuthService::Get()->StopAndEnableArc(); | 46 ArcAuthService::Get()->StopAndEnableArc(); |
43 } | 47 } |
44 } | 48 } |
45 | 49 |
46 } // namespace arc | 50 } // namespace arc |
OLD | NEW |