// 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_GSM_SMS_CLIENT_H_
#define CHROMEOS_DBUS_GSM_SMS_CLIENT_H_
#include <string>
#include "base/basictypes.h"
#include "base/callback.h"
#include "chromeos/chromeos_export.h"
#include "chromeos/dbus/dbus_client.h"
namespace base {
class DictionaryValue;
class ListValue;
}
namespace dbus {
class ObjectPath;
}
namespace chromeos {
// GsmSMSClient is used to communicate with the
// org.freedesktop.ModemManager.Modem.Gsm.SMS service.
// All methods should be called from the origin thread (UI thread) which
// initializes the DBusThreadManager instance.
class CHROMEOS_EXPORT GsmSMSClient : public DBusClient {
public:
typedef base::Callback<void(uint32 index, bool complete)> SmsReceivedHandler;
typedef base::Callback<void()> DeleteCallback;
typedef base::Callback<void(const base::DictionaryValue& sms)> GetCallback;
typedef base::Callback<void(const base::ListValue& result)> ListCallback;
virtual ~GsmSMSClient();
// Factory function, creates a new instance and returns ownership.
// For normal usage, access the singleton via DBusThreadManager::Get().
static GsmSMSClient* Create();
// Sets SmsReceived signal handler.
virtual void SetSmsReceivedHandler(const std::string& service_name,
const dbus::ObjectPath& object_path,
const SmsReceivedHandler& handler) = 0;
// Resets SmsReceived signal handler.
virtual void ResetSmsReceivedHandler(const std::string& service_name,
const dbus::ObjectPath& object_path) = 0;
// Calls Delete method. |callback| is called after the method call succeeds.
virtual void Delete(const std::string& service_name,
const dbus::ObjectPath& object_path,
uint32 index,
const DeleteCallback& callback) = 0;
// Calls Get method. |callback| is called after the method call succeeds.
virtual void Get(const std::string& service_name,
const dbus::ObjectPath& object_path,
uint32 index,
const GetCallback& callback) = 0;
// Calls List method. |callback| is called after the method call succeeds.
virtual void List(const std::string& service_name,
const dbus::ObjectPath& object_path,
const ListCallback& callback) = 0;
// Requests a check for new messages. In shill this does nothing. The
// stub implementation uses it to generate a sequence of test messages.
virtual void RequestUpdate(const std::string& service_name,
const dbus::ObjectPath& object_path) = 0;
protected:
friend class GsmSMSClientTest;
// Create() should be used instead.
GsmSMSClient();
private:
DISALLOW_COPY_AND_ASSIGN(GsmSMSClient);
};
} // namespace chromeos
#endif // CHROMEOS_DBUS_GSM_SMS_CLIENT_H_