BLE GATT messaging protocol#748
Open
MathJud wants to merge 34 commits into
Open
Conversation
* chore(ble): init rust ble module * build(ble-rs): add prost and bytes * chore: recompile proto * feat(log): init logging * feat(log): set up ble logger * feat(rpc): init rpc channels * feat(rpc): set up channels * fix(proto): add local copy of qaul.sys.ble * feat: run tokio select loop * refactor(rpc): use async traits for easier testing * refactor(rpc): remove unused rpcerrors * refactor: run main loop in own module * build(bluer): import bluer features * feat(ble): add BLE UUIDs * style: remove unused imports * feat(ble): define BleManager trait * feat(ble): advertise services * feat(ble): add handles for main and msg chara * refactor(ble): rename trait to QaulBleManager * refactor(uuid): rename to main UUID * build(ble): add futures * feat(ble): add services * feat(ble_module): scan * feat(ble): filter devices by blocklist * feat(ble): add close method * refactor(ble): qaul ble trait to fit ble sys msgs * refactor(rpc): give publiuc access to proto mod * refactor(rpc loop): listen to sys msgs * feat(loop): forward sys msgs to ble impl * refactor(naming): improve naming * feat(ble): get device info * feat(start_ble): return when ble already started * feat(ble): advertise * feat(ble_utils): pretty print address * refactor(ble): remove redundant close method * feat(ble): break ble loop with mpsc * feat(ble): connect to device * feat(ble): set up notification and send device found * feat(ble): report chara writes * refactor(streams): WIP * fix(ble): breaking stop stream * refactor(ble): use merged streams * feat(ble): implement direct send * feat(ble): implement stop * style: lint * refactor(ble): remove unused handle types # Conflicts: # rust/libqaul/src/rpc/protobuf_generated/rust/qaul.net.messaging.rs # rust/libqaul/src/services/messaging/qaul.net.messaging.rs
SYS communication from BLE connectivity module shall be called directly via callback from outside. Libqaul calls the BLE module directly. There is no libqaul -> BLE_module channel needed anymore. fixed qaul_id compile warning Removed unused function from API
1. Linux is able to detect other devices 2. Other devices can detect Linux BLE advertisements 3. Linux device is able to recieve messages from other qaul devices
Signed-off-by: sukhman <sukhmansinghsaluja@gmail.com>
modified: ble_module/src/ble/ble_service.rs modified: ble_module/src/ble/utils.rs modified: ble_module/src/lib.rs modified: ble_module/src/rpc/msg_loop.rs modified: libqaul/src/connections/ble/mod.rs modified: libqaul/src/router/neighbours.rs
- New GATT messaging protocol Header - deprecated BLE small_id functions (16 Bytes) - moved BLE to q8id (8 Bytes) which is also used in routing - removed GSON library - libqaul: Fixed Messaging MAX_MESSAGE_LEN_BYTES to fit in 2 Bytes - BLE large message implementation - added connection manager to identify BLE device via qaul id
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
New BLE GATT messaging protocol
This protocol creates a two Byte header for all GATT messages.
The procotol can: