blob: 8809be098c91cbf725542e50cc0cdb12a82b3f5c [file] [log] [blame]
// Copyright 2014 The ChromiumOS Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef LIBBRILLO_BRILLO_DAEMONS_DBUS_DAEMON_H_
#define LIBBRILLO_BRILLO_DAEMONS_DBUS_DAEMON_H_
#include <memory>
#include <string>
#include <string_view>
#include <base/memory/ref_counted.h>
#include <brillo/brillo_export.h>
#include <brillo/daemons/daemon.h>
#include <brillo/dbus/dbus_connection.h>
#include <brillo/dbus/exported_object_manager.h>
#include <dbus/bus.h>
namespace brillo {
namespace dbus_utils {
class AsyncEventSequencer;
} // namespace dbus_utils
// DBusDaemon adds D-Bus support to Daemon.
// Derive your daemon from this class if you want D-Bus client services in your
// daemon (consuming other D-Bus objects). Currently uses a SYSTEM bus.
class BRILLO_EXPORT DBusDaemon : public Daemon {
public:
DBusDaemon();
DBusDaemon(const DBusDaemon&) = delete;
DBusDaemon& operator=(const DBusDaemon&) = delete;
~DBusDaemon() override = default;
protected:
// Calls the base OnInit() and then instantiates dbus::Bus and establishes
// a D-Bus connection.
int OnInit() override;
// A reference to the |dbus_connection_| bus object often used by derived
// classes.
scoped_refptr<::dbus::Bus> bus_;
private:
DBusConnection dbus_connection_;
};
// DBusServiceDaemon adds D-Bus service support to DBusDaemon.
// Derive your daemon from this class if your daemon exposes D-Bus objects.
// Provides an ExportedObjectManager to announce your object/interface creation
// and destruction.
class BRILLO_EXPORT DBusServiceDaemon : public DBusDaemon {
public:
// Constructs the daemon.
// |service_name| is the name of D-Bus service provided by the daemon.
// |object_manager_path_| is a well-known D-Bus object path for
// ExportedObjectManager object.
// If |object_manager_path_| is not specified, then ExportedObjectManager is
// not created and is not available as part of the D-Bus service.
explicit DBusServiceDaemon(const std::string& service_name);
DBusServiceDaemon(const std::string& service_name,
const ::dbus::ObjectPath& object_manager_path);
DBusServiceDaemon(const std::string& service_name,
std::string_view object_manager_path);
DBusServiceDaemon(const DBusServiceDaemon&) = delete;
DBusServiceDaemon& operator=(const DBusServiceDaemon&) = delete;
protected:
// OnInit() overload exporting D-Bus objects. Exports the contained
// ExportedObjectManager object and calls RegisterDBusObjectsAsync() to let
// you provide additional D-Bus objects.
int OnInit() override;
// Overload this method to export your custom D-Bus objects at startup.
// Objects exported in this way will finish exporting before we claim the
// daemon's service name on DBus.
virtual void RegisterDBusObjectsAsync(
dbus_utils::AsyncEventSequencer* sequencer);
std::string service_name_;
::dbus::ObjectPath object_manager_path_;
std::unique_ptr<dbus_utils::ExportedObjectManager> object_manager_;
private:
// A callback that will be called when all the D-Bus objects/interfaces are
// exported successfully and the daemon is ready to claim the D-Bus service
// ownership.
void TakeServiceOwnership(bool success);
};
} // namespace brillo
#endif // LIBBRILLO_BRILLO_DAEMONS_DBUS_DAEMON_H_