// Copyright (c) 2012 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 CHROMEOS_DBUS_SHILL_SERVICE_CLIENT_H_ #define CHROMEOS_DBUS_SHILL_SERVICE_CLIENT_H_ #include <string> #include "base/basictypes.h" #include "base/callback.h" #include "chromeos/chromeos_export.h" #include "chromeos/dbus/dbus_client.h" #include "chromeos/dbus/shill_client_helper.h" namespace base { class Value; class DictionaryValue; } // namespace base namespace dbus { class ObjectPath; } // namespace dbus namespace chromeos { // ShillServiceClient is used to communicate with the Shill Service // service. // All methods should be called from the origin thread which initializes the // DBusThreadManager instance. class CHROMEOS_EXPORT ShillServiceClient : public DBusClient { public: typedef ShillClientHelper::PropertyChangedHandler PropertyChangedHandler; typedef ShillClientHelper::DictionaryValueCallback DictionaryValueCallback; typedef ShillClientHelper::ListValueCallback ListValueCallback; typedef ShillClientHelper::ErrorCallback ErrorCallback; // Interface for setting up services for testing. Accessed through // GetTestInterface(), only implemented in the stub implementation. class TestInterface { public: // Adds a Service to the Manager and Service stubs. virtual void AddService(const std::string& service_path, const std::string& name, const std::string& type, const std::string& state, bool visible) = 0; virtual void AddServiceWithIPConfig(const std::string& service_path, const std::string& guid, const std::string& name, const std::string& type, const std::string& state, const std::string& ipconfig_path, bool visible) = 0; // Sets the properties for a service but does not add it to the Manager // or Profile. Returns the properties for the service. virtual base::DictionaryValue* SetServiceProperties( const std::string& service_path, const std::string& guid, const std::string& name, const std::string& type, const std::string& state, bool visible) = 0; // Removes a Service to the Manager and Service stubs. virtual void RemoveService(const std::string& service_path) = 0; // Returns false if a Service matching |service_path| does not exist. virtual bool SetServiceProperty(const std::string& service_path, const std::string& property, const base::Value& value) = 0; // Returns properties for |service_path| or NULL if no Service matches. virtual const base::DictionaryValue* GetServiceProperties( const std::string& service_path) const = 0; // Clears all Services from the Manager and Service stubs. virtual void ClearServices() = 0; virtual void SetConnectBehavior(const std::string& service_path, const base::Closure& behavior) = 0; protected: virtual ~TestInterface() {} }; virtual ~ShillServiceClient(); // Factory function, creates a new instance which is owned by the caller. // For normal usage, access the singleton via DBusThreadManager::Get(). static ShillServiceClient* Create(); // Adds a property changed |observer| to the service at |service_path|. virtual void AddPropertyChangedObserver( const dbus::ObjectPath& service_path, ShillPropertyChangedObserver* observer) = 0; // Removes a property changed |observer| to the service at |service_path|. virtual void RemovePropertyChangedObserver( const dbus::ObjectPath& service_path, ShillPropertyChangedObserver* observer) = 0; // Calls GetProperties method. // |callback| is called after the method call succeeds. virtual void GetProperties(const dbus::ObjectPath& service_path, const DictionaryValueCallback& callback) = 0; // Calls SetProperty method. // |callback| is called after the method call succeeds. virtual void SetProperty(const dbus::ObjectPath& service_path, const std::string& name, const base::Value& value, const base::Closure& callback, const ErrorCallback& error_callback) = 0; // Calls SetProperties method. // |callback| is called after the method call succeeds. virtual void SetProperties(const dbus::ObjectPath& service_path, const base::DictionaryValue& properties, const base::Closure& callback, const ErrorCallback& error_callback) = 0; // Calls ClearProperty method. // |callback| is called after the method call succeeds. virtual void ClearProperty(const dbus::ObjectPath& service_path, const std::string& name, const base::Closure& callback, const ErrorCallback& error_callback) = 0; // Calls ClearProperties method. // |callback| is called after the method call succeeds. virtual void ClearProperties(const dbus::ObjectPath& service_path, const std::vector<std::string>& names, const ListValueCallback& callback, const ErrorCallback& error_callback) = 0; // Calls Connect method. // |callback| is called after the method call succeeds. virtual void Connect(const dbus::ObjectPath& service_path, const base::Closure& callback, const ErrorCallback& error_callback) = 0; // Calls Disconnect method. // |callback| is called after the method call succeeds. virtual void Disconnect(const dbus::ObjectPath& service_path, const base::Closure& callback, const ErrorCallback& error_callback) = 0; // Calls Remove method. // |callback| is called after the method call succeeds. virtual void Remove(const dbus::ObjectPath& service_path, const base::Closure& callback, const ErrorCallback& error_callback) = 0; // Calls ActivateCellularModem method. // |callback| is called after the method call succeeds. virtual void ActivateCellularModem( const dbus::ObjectPath& service_path, const std::string& carrier, const base::Closure& callback, const ErrorCallback& error_callback) = 0; // Calls the CompleteCellularActivation method. // |callback| is called after the method call succeeds. virtual void CompleteCellularActivation( const dbus::ObjectPath& service_path, const base::Closure& callback, const ErrorCallback& error_callback) = 0; // Calls the GetLoadableProfileEntries method. // |callback| is called after the method call succeeds. virtual void GetLoadableProfileEntries( const dbus::ObjectPath& service_path, const DictionaryValueCallback& callback) = 0; // Returns an interface for testing (stub only), or returns NULL. virtual TestInterface* GetTestInterface() = 0; protected: friend class ShillServiceClientTest; // Create() should be used instead. ShillServiceClient(); private: DISALLOW_COPY_AND_ASSIGN(ShillServiceClient); }; } // namespace chromeos #endif // CHROMEOS_DBUS_SHILL_SERVICE_CLIENT_H_