1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CHROMEOS_DBUS_BLUETOOTH_MEDIA_ENDPOINT_SERVICE_PROVIDER_H_
6 #define CHROMEOS_DBUS_BLUETOOTH_MEDIA_ENDPOINT_SERVICE_PROVIDER_H_
10 #include "base/callback.h"
11 #include "chromeos/chromeos_export.h"
13 #include "dbus/message.h"
14 #include "dbus/object_path.h"
18 // BluetoothMediaEndpointServiceProvider is used to provide a D-Bus object that
19 // the Bluetooth daemon can commuicate with to serve as a media source/sink.
21 // Instantiate with a chosen D-Bus object path and a delegate object, and pass
22 // the D-Bus object path as |endpoint_path| argument to the
23 // chromeos::BluetoothMediaClient::RegisterEndoint() method.
25 // After initiating a connection between an audio source and an audio sink, the
26 // Bluetooth daemon will make calls to this endpoint object and they will be
27 // passed to user's Delegate object for handling. For SelectConfiguration method
28 // the response is returned using the SelectConfiguration callback.
29 class CHROMEOS_EXPORT BluetoothMediaEndpointServiceProvider
{
31 // Delegate is the interface for reacting to endpoint requests. User
32 // applications will implement this interface to handle either A2DP Sink or
36 virtual ~Delegate() {}
38 // SelectConfigurationCallback is used for the SelectConfiguration() method,
39 // it should be called with two arguements, the |configuration| which is
40 // agreed by the application and the |length| of |configuration|.
41 typedef base::Callback
<void(const std::vector
<uint8_t>&)>
42 SelectConfigurationCallback
;
44 // This method will be called after an Audio Source receives the agreed
45 // capabilities from the Audio Sink to set the configuration for the
46 // media transport object. |transport_path| is the path to the
47 // MediaTransport object, and |properties| are the properties for that
48 // MediaTransport object.
49 virtual void SetConfiguration(const dbus::ObjectPath
& transport_path
,
50 const dbus::MessageReader
& properties
) = 0;
52 // This method will be called when an Audio Source connects to an Audio Sink
53 // and asks it to decide the configuration to be used during the oncoming
54 // streaming. Audio Sources provide |capabilities| as a reference, where
55 // a user application can use these |capabilities| to figure out
56 // a well-matched configuration and return it to the Audio Source via
58 virtual void SelectConfiguration(
59 const std::vector
<uint8_t>& capabilities
,
60 const SelectConfigurationCallback
& callback
) = 0;
62 // This method will be called when an Audio Source disconnects from an Audio
63 // Sink. A user application is supposed to clear any of its resources which
64 // it keeps for that particular connection. |transport_path| is the Media
65 // Transport object which has been kept by an endpoint during the
67 virtual void ClearConfiguration(const dbus::ObjectPath
& transport_path
) = 0;
69 // This method will be called when the Bluetooth daemon unregisters the
70 // Media Endpoint. Media Endpoint objects can use this method to clean up
71 // tasks. There is no need to unregister the endpoint, since when this
72 // method gets called, that endpoint has been unregistered.
73 virtual void Release() = 0;
76 virtual ~BluetoothMediaEndpointServiceProvider();
78 // Creates the instance where |bus| is the D-Bus bus connection to export the
79 // object onto, |object_path| is the object path that it should have and
80 // |delegate| is the object to which all method calls will be passed and
81 // responses generated from.
82 static BluetoothMediaEndpointServiceProvider
* Create(
84 const dbus::ObjectPath
& object_path
,
88 BluetoothMediaEndpointServiceProvider();
91 DISALLOW_COPY_AND_ASSIGN(BluetoothMediaEndpointServiceProvider
);
94 } // namespace chromeos
96 #endif // CHROMEOS_DBUS_BLUETOOTH_MEDIA_ENDPOINT_SERVICE_PROVIDER_H_