blob: c10cdb08e18de5eca75e3c294fa88a8f8d31ad86 [file] [log] [blame]
// Copyright 2015 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 <stdint.h>
#include <map>
#include <memory>
#include <string>
#include <vector>
#include "base/callback.h"
#include "base/macros.h"
#include "dbus/bus.h"
#include "dbus/file_descriptor.h"
#include "dbus/object_path.h"
#include "device/bluetooth/bluetooth_export.h"
namespace bluez {
// BluetoothAdvertisementServiceProvider is used to provide a D-Bus object that
// the Bluetooth daemon can communicate with to advertise data.
class DEVICE_BLUETOOTH_EXPORT BluetoothLEAdvertisementServiceProvider {
using UUIDList = std::vector<std::string>;
using ManufacturerData = std::map<uint16_t, std::vector<uint8_t>>;
using ServiceData = std::map<std::string, std::vector<uint8_t>>;
// Type of advertisement.
enum AdvertisementType {
// Interface for reacting to advertisement changes.
class Delegate {
virtual ~Delegate() {}
// This method will be called when the advertisement is unregistered from
// the Bluetooth daemon, generally at shutdown or if the adapter goes away.
// It may be used to perform cleanup tasks. This corresponds to the
// org.bluez.LEAdvertisement1.Release method and is renamed to avoid a
// conflict with base::Refcounted<T>.
virtual void Released() = 0;
virtual ~BluetoothLEAdvertisementServiceProvider();
const dbus::ObjectPath& object_path() { return object_path_; }
// Creates the instance where |bus| is the D-Bus bus connection to export
// the object onto, |object_path| is the object path that it should have
// and |delegate| is the object to which all method calls will be passed
// and responses generated from.
static std::unique_ptr<BluetoothLEAdvertisementServiceProvider> Create(
dbus::Bus* bus,
const dbus::ObjectPath& object_path,
Delegate* delegate,
AdvertisementType type,
std::unique_ptr<UUIDList> service_uuids,
std::unique_ptr<ManufacturerData> manufacturer_data,
std::unique_ptr<UUIDList> solicit_uuids,
std::unique_ptr<ServiceData> service_data);
// D-Bus object path of object we are exporting, kept so we can unregister
// again in our destructor.
dbus::ObjectPath object_path_;
} // namespace bluez