From 466e274c41487de7bcdb50d186b3ce251dced943 Mon Sep 17 00:00:00 2001 From: Matej Glejtek Date: Tue, 18 Jun 2024 21:52:59 +0200 Subject: [PATCH] docs: add info about setting up permissions DT-3180 --- README.md | 63 ++++++++++++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 58 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index 9ba119a..2d17220 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,7 @@ A flutter plugin for reading Wi-Fi and Bluetooth Remote ID advertisements using The platform-specific implementation reads raw message bytes from Wi-Fi and Bluetooth Remote ID advertisements. Then the raw payload with metadata is passed using event channels to the Dart side. Raw data are parsed to Remote ID messages using [Dart-opendroneid library](https://github.com/dronetag/dart-opendroneid). -[The pigeon library](https://pub.dev/packages/pigeon) is used to define the messaging protocol between the platform host and Flutter client. The messaging protocol is defined in [schema.dart](pigeon/schema.dart). +[The pigeon library](https://pub.dev/packages/pigeon) is used to define the messaging protocol between the platform host and the Flutter client. The messaging protocol is defined in [schema.dart](pigeon/schema.dart). The architecture of native code is inspired by [OpenDroneID Android receiver application](https://github.com/opendroneid/receiver-android). @@ -16,10 +16,7 @@ The architecture of native code is inspired by [OpenDroneID Android receiver app ## Getting Started -This project is a starting point for a Flutter -[plug-in package](https://flutter.dev/developing-packages/), -a specialized package that includes platform-specific implementation code for -Android and/or iOS. +This project is a Flutter [plug-in package](https://flutter.dev/developing-packages/), a specialized package that includes platform-specific implementation code for Android and/or iOS. For help getting started with Flutter, view [online documentation](https://flutter.dev/docs), which offers tutorials, @@ -34,6 +31,62 @@ samples, guidance on mobile development, and a full API reference. 1. Install the project using `flutter pub get` 2. Generate Pigeon classes by running shell script in `scripts/pigeon_generate.sh` +## Setting up permissions + +Enabling scanning the surroundings for Wi-Fi and Bluetooth Remote ID advertisements requires setting up permissions. App has to request required permissions, the plugin only checks that permissions are granted. If some permissions are missing, the plugin throws `PermissionsMissingException` when attempting to start the scan. Use for example the [permission handler package](https://pub.dev/packages/permission_handler) to request permissions. + + +### Android Setup +Android allows both Wi-Fi and Bluetooth scanning. Bluetooth scanning requires Bluetooth and Bluetooth Scan permission. Location permission is required for Bluetooth scanning since Android 12 (API level 31). +Check the [documentation on Bluetooth permissions](https://developer.android.com/develop/connectivity/bluetooth/bt-permissions). + +Wi-Fi scanning requires location permission up to version 12 (API level 31), since version 13, the Nearby Wifi Devices permission is required. +Check the [documentation on Wi-Fi permissions](https://developer.android.com/develop/connectivity/wifi/wifi-permissions). + +Permissions need to be added to `AndroidManifest.xml` file: + +``` + + + + + + +``` + +### iOS Setup + +iOS does not allow Wi-Fi scanning, only Bluetooth scanning is possible. Bluetooth permission is required. Apart from requesting permission, it also needs to be added to `Info.plist`. + +- add `NSBluetoothAlwaysUsageDescription key` to `Info.plist` with the `string` type. Use any description, for example the one in code snippet. It will be shown in dialog when requesting permission. +``` + + ... + NSBluetoothAlwaysUsageDescription + The application needs Bluetooth permission to acquire data from nearby aircraft. + ... +``` + +- permission handler requires setting macros in `Podfile`. Set `PERMISSION_BLUETOOTH` to 1. +``` +post_install do |installer| + installer.pods_project.targets.each do |target| + flutter_additional_ios_build_settings(target) + target.build_configurations.each do |config| + config.build_settings['GCC_PREPROCESSOR_DEFINITIONS'] ||= [ + '$(inherited)', + + ## dart: PermissionGroup.bluetooth + 'PERMISSION_BLUETOOTH=1', + ] + end + end +end +``` + --- © [Dronetag 2022](https://www.dronetag.cz)