Index: chrome/browser/chromeos/arc/arc_service_launcher.cc |
diff --git a/chrome/browser/chromeos/arc/arc_service_launcher.cc b/chrome/browser/chromeos/arc/arc_service_launcher.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..cc426fc8ee094dd6d8a9f3342740fb922c5fa73f |
--- /dev/null |
+++ b/chrome/browser/chromeos/arc/arc_service_launcher.cc |
@@ -0,0 +1,45 @@ |
+// 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. |
+ |
+#include "chrome/browser/chromeos/arc/arc_service_launcher.h" |
+ |
+#include "base/bind.h" |
+#include "chrome/browser/chromeos/arc/arc_auth_service.h" |
+#include "chrome/browser/chromeos/arc/arc_intent_helper_bridge.h" |
+#include "chromeos/dbus/dbus_thread_manager.h" |
+#include "chromeos/dbus/session_manager_client.h" |
+#include "components/arc/arc_bridge_service.h" |
+ |
+namespace arc { |
+ |
+ArcServiceLauncher::ArcServiceLauncher() : weak_factory_(this) {} |
+ |
+ArcServiceLauncher::~ArcServiceLauncher() {} |
+ |
+void ArcServiceLauncher::Initialize() { |
+ // Create ARC service manager. |
+ arc_service_manager_.reset(new ArcServiceManager()); |
+ arc_service_manager_->AddService(make_scoped_ptr( |
+ new ArcAuthService(arc_service_manager_->arc_bridge_service()))); |
+ arc_service_manager_->AddService(make_scoped_ptr( |
+ new ArcIntentHelperBridge(arc_service_manager_->arc_bridge_service()))); |
+ |
+ // Detect availiability. |
+ chromeos::SessionManagerClient* session_manager_client = |
+ chromeos::DBusThreadManager::Get()->GetSessionManagerClient(); |
+ session_manager_client->CheckArcAvailability(base::Bind( |
+ &ArcServiceLauncher::OnArcAvailable, weak_factory_.GetWeakPtr())); |
+} |
+ |
+void ArcServiceLauncher::Shutdown() { |
+ DCHECK(arc_service_manager_); |
+ arc_service_manager_->arc_bridge_service()->Shutdown(); |
+} |
+ |
+void ArcServiceLauncher::OnArcAvailable(bool arc_available) { |
+ arc_service_manager_->arc_bridge_service()->SetDetectedAvailability( |
+ arc_available); |
+} |
+ |
+} // namespace arc |