On 21 Feb 2011, at 16:14 , Claudio Takahasi wrote: > Hi, > > > On Wed, Feb 16, 2011 at 6:13 PM, Elvis Pfützenreuter <epx@xxxxxxxxxxx> wrote: >> This patch proposes extensions to Attribute API, giving access to all >> characteristic descriptors (beyond 'Description' and 'Format'). >> --- >> doc/attribute-api.txt | 28 ++++++++++++++++++++++++++++ >> 1 files changed, 28 insertions(+), 0 deletions(-) >> >> diff --git a/doc/attribute-api.txt b/doc/attribute-api.txt >> index 23808e6..5ee189e 100644 >> --- a/doc/attribute-api.txt >> +++ b/doc/attribute-api.txt >> @@ -104,6 +104,14 @@ Methods dict GetProperties() >> >> Possible Errors: org.bluez.Error.InvalidArguments >> >> + void SetDescriptorValue(object descriptor, array{byte} value) >> + >> + Sets descriptor value, provided that it is writable. >> + >> + Possible Errors: org.bluez.Error.InvalidArguments >> + org.bluez.Error.NotAuthorized >> + >> + >> Properties string UUID [readonly] >> >> UUID128 of this characteristic. >> @@ -143,6 +151,26 @@ Properties string UUID [readonly] >> Friendly representation of the Characteristic Value >> based on the format attribute. >> >> + dict Descriptors [readonly] >> + >> + List of descriptors for this characteristic. >> + >> + This list contains only the descriptors not already >> + covered by other properties (v.g. Description, Format). >> + >> + Each descriptor is mapped to an unique object path, >> + which is the key for the dict. >> + >> + Each dict value is, in turn, a dict with at least >> + the following keys: >> + >> + { >> + "UUID": string (descriptor UUID - mandatory), >> + "Value": array of bytes (raw descriptor value - >> + optional, shows up when value can be >> + fetched) >> + } >> + >> >> Characteristic Watcher hierarchy >> =============================== >> -- >> 1.7.1 >> >> -- >> To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in >> the body of a message to majordomo@xxxxxxxxxxxxxxx >> More majordomo info at http://vger.kernel.org/majordomo-info.html >> > > In my opinion is not a good approach to allow applications(D-Bus > clients) to change a behavior/value of the same characteristic > descriptor. bluetoothd could manage automatically writing the client > characteristic configuration and server characteristic configuration > based on the registered watchers and supported client profiles. I'm not sure I follow, but let's break it down: 1) Note that this API is not just for client (and server) characteristic configuration descriptors. It is good for any kind of descriptor (like Valid Range, that client is supposed to be able to read, and set the related characteristic within its limits). 2) Updating automatically CCC/SCC descriptors based on Watchers sounds nice. We just need to add some kind of flag to agent registering in order to tell if we want notification or indication. 3) In terms of client profiles, the GATT API looks generic to me, not profile-specific. As there is a way to access characteristic values in a generic way, so there is a need to do the same for descriptors.-- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html