-
Notifications
You must be signed in to change notification settings - Fork 711
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
BLE Library - Add service data support #282
Comments
Hi, Yes could be interesting to be able to read service data by an AdvertisedDevice, I think about examples like Mi flora who advertise sensors values on service data. |
Maybe im lack of knowledge and/or imagination, but how it suppose to looks like? It is implemented in Beacon already, but im guessing its not the same. |
Nop I don't think so : -) more a lack of explanation here is a screenshot of what i would like to be able to read with the library. Currently I didn't found a method on BLEAdvertisedDevice.h to do that, maybe i m misding something. |
I think it is implemented already. But it cant be done without connecting, its just implemented to do it out of box. But it is not added in library you are using. You can see this code: esp32-snippets/cpp_utils/BLEDevice.cpp Lines 197 to 205 in 3d39b22
|
Howdy @julesDesjardin , @1technophile Great questions and thanks for posting them. Lets see if we can't get this going for you. This is a technical discussion and I don't know how much or how little you know so please forgive me if it is too simple or too complicated ... let me know if I need to adjust. I am assuming that we are thinking of the ESP32 in its role as a BLE Central (Client) where it is passively scanning/listening for arriving advertisement from BLE Peripherals (Servers) that are broadcasting/advertising. When a BLE advert arrives at the ESP32, the advert contains up to 31 bytes of payload/advert data. On receipt of an advert, the ESP32 will parse its content and understand what arrived. Included in the advert is the Bluetooth Device Address (BDA) of the partner that sent the advert in the first place. The ESP32 can (should it choose and the partner allow) immediately send a message called a "Scan Request" which is basically "I just saw an advert from you, please send me one follow on message and tell me more" where a Scan Response message will be returned ... which is again just a second advertisement packet but containing more data. Adverts being sent by BLE are not just arrays of bytes. An advert is composed of identified fields where a field has some set of allowable and understood values. The complete list of possible advertisement fields can be found here: https://www.bluetooth.com/specifications/assigned-numbers/generic-access-profile This so far is theory ... In practice, the BLE C++ library found at this repository receives the incoming packet and decodes it to produce an object that is a logical representation of what was learned from the incoming advert. Since an advert may or may not contain certain fields ... it is 100% up to the advertiser as to what they include/exclude ... the resulting object will have some values filled in and others not set. The object type we create is BLEAdvertisedDevice. An instance of this object can be asked:
So far we have provided support for fields of type:
However, as you will see in the BLE spec list, there are many more. We simply haven't implemented all of those because we don't know which ones folks need or want. If there is a field a device is advertising and the BLEAdvertisedDevice doesn't yet decode that field, simply let us know and we will go ahead and code it in as quickly as possible. |
@chegewara Thanks for the code extract I will try that and let you know if it answer my needs. |
Hi, |
Ok, now i see it and its easy to implement. Work in progress. |
@nkolban thanks for this detailled explanation ! |
@nkolban @chegewara @julesDesjardin , I confirm that the modification made by @chegewara is working as expected and enables me to extract sensor values from a mi flora sensor (humidity, temperature, lux and fertilization). I have now to industrialize the proof of concept and integrate it into OpenMQTTGateway BLE gateway. Thanks a lot for the help! |
@1technophile ... About an hour ago I made some updates to the code made by @chegewara ... I haven't had a chance to chat with him about them yet ... however, they changed the exposed information from char* to std::string ... please be cautious as this is new code and the interfaces may change until we settle. |
BLE is like mine field, full of traps. But when you understand structure and data how they are send by peripherals we can provide tools to work with it. You guys gave us some tips, that screenshot was great, thanks for that and we were able to add functionality you are requesting to play with sensors. |
@nkolban no problem I will adapt according to your changes |
Careful ... they just changed again. Hopefully this will be the end. We studied and found that the service data advert has THREE variants. One that contains a 2 byte UUID, one a 4 byte UUID and one a 16 byte UUID. We were only handling the 2 byte UUID. We now handle all three. Secondly, we now see that every service data has the format:
where the uuid is 2, 4 or 16 bytes. We now parse all of them and give you the following methods:
I am currently assuming that any given advert will contain only ONE service data field ... if you find more than 1, we will need to accommodate. |
Thanks for the std::string, easier to handle, here is what I get with some string transformation:
Thanks again for this work. |
Awesome ... is this what you had hoped to see? :-) If you are satisfied with the resolution, close out the issue as desired. We can always re-open if needed or if there are new issues, don't hesitate to create new ones. |
Yes that's great |
@julesDesjardin if ok for you, could you close the issue, i don't have access to the close button |
Hi |
Sometimes these APIs expose data without a deeper understanding on the part of the authors. A BLE advertisement contains fields. There is a finite set of fields types defined. These are documented/described here. https://www.bluetooth.com/specifications/assigned-numbers/generic-access-profile The BLEAdvertisedDevice is a model that represents a received advertisement. It has knowledge of some of the fields types. The only reason that we haven't told the model about ALL field types is that we are lazy and we wait for someone to say "Hey, you don't decode XYZ field ..." and then we add it. One of the possible field types described in the BLE spec is type 0x0A - TX Power Level. Look at that in the spec document referenced previously. We found that was a commonly received advert payload so we added decoding of it. However ... and this is the punch line ... just because the spec says that data is available and because we have decoded that data and made it available to the programmer, unfortunately does not imply that we know what all these fields mean. What I suggest is go and study the spec in depth, study the meaning of the TX Power Level field in an advert and, when done, paste back here what you find. It will help all of us now and in the future. |
Is it possible to extract temperature values from an Eddystone TLM data? I have a beacon that advertises the temperature and battery level. I can see these data using android eddystone app and would like to see these data in esp32 in Arduino IDE too. In one of the snippets I saw that you wait until you receive an Adv data type 0x16 and then you look for 0x1809 uuid and then you decode the temperature. I tried to do the same thing in BLEAdvertisedDevice class, however the esp32 does not find 0x1809 uuid. Am I in the right path to get temperature readings? could anyone help please? |
You can check what raw data are used to advertise, i like to use nRF connect, and read from it what service UUID is used in advertising packet. If you have issue to read it you can paste here raw advertising packet or screenshot and we will try to help. Screenshot prefered like this one |
@shahabmusic This looks like it would make a great issue in its own right. Might I encourage you to move your post to its own issue so that we can track it separately? |
cool. thanks. I just opened a new question. |
Hi, |
We have recently updated library to follow changes in esp-idf. They just renamed bt.h to esp_bt.h. |
Thanks for the trick, it works ! |
Hi !
I would like to use the BLE library to manage advertising data, but right now it's only possible to add service UUIDs. Would it be possible to implement service data as well ? I also have the same question for the scanning part (for this part, a direct access to the advertising data via a getAdvertisingData method on the AdvertisedDevice class would also be enough, and easier to implement I think)
Thanks !
The text was updated successfully, but these errors were encountered: