Skip to content
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

AirGuard Version 2.3 #179

Merged
merged 192 commits into from
Jul 31, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
192 commits
Select commit Hold shift + click to select a range
1c95950
improve LocationProvider, can handle COARSE_LOCATION, works with any …
Sep 24, 2023
50fc255
small improvements to map rendering
Sep 27, 2023
5cca04d
make ObserveTracker functionality visible again
Sep 27, 2023
76b2c50
improve Observation Screen Design
Sep 27, 2023
79ad24e
ObserveTrackerWorker now calls ScanBluetoothWorker manually before ch…
Oct 2, 2023
ba43134
update gradle version
Oct 3, 2023
1f46a9d
improve Background Worker Scheduling, add Error Case for ObserveTracker
Oct 3, 2023
656baf9
add handling for inconsistent database entries in ObserveTracker, mak…
Oct 4, 2023
ffc1a2e
Tracker Observation can now be stopped, added visual indicator whethe…
Oct 5, 2023
f1baf67
add Article Fragment
Oct 11, 2023
9a6a264
fix crash in Play Sound Dialog
Oct 17, 2023
a3ff542
Merge branch 'ShowAllDevices' into ObserveTracker
Oct 17, 2023
96fa537
add navigation to article
Oct 17, 2023
2d1330b
Adding new API endpoint that deletes study data for a specific user
Sn0wfreezeDev Oct 23, 2023
a50fb54
Setting request to DELETE method
Sn0wfreezeDev Oct 23, 2023
a9fd70c
implement Data Deletion in UI
Oct 23, 2023
ec2150d
fix api initialization bug, better initialization of api token, add e…
imbissbudenaesthetik Oct 24, 2023
87b5b90
add first implementation of Online Article Download
Oct 26, 2023
66d89b4
Merge branch 'ShowAllDevices' into ObserveTracker
Oct 26, 2023
333154e
add additional information in JSON
Oct 26, 2023
a1127e8
Article Download now Coroutine, loading animation while downloading J…
Oct 27, 2023
359897b
Design improvement
Oct 27, 2023
d172e47
Article offline handling
Oct 28, 2023
a31cbc7
Merge branch 'ShowAllDevices' into ObserveTracker
imbissbudenaesthetik Oct 31, 2023
ed0dce1
support Online Articles in multiple languages
Nov 4, 2023
42a90dd
upgrade to gradle 8.1.3
Nov 11, 2023
5321602
fix security issues in the AndroidManifest
Nov 11, 2023
55f841b
update backup rules to confirm to android 12 standards
Nov 11, 2023
de32b38
optimize Article Offline Handling and add old cards again
Nov 11, 2023
3857e52
Merge remote-tracking branch 'origin/ObserveTracker' into ObserveTracker
imbissbudenaesthetik Nov 15, 2023
fa2c4ea
upgrade gradle and some libraries
Nov 19, 2023
78fcf61
speed up map rendering and add permission necessary for Android 14
Nov 19, 2023
ecaab97
Merge remote-tracking branch 'origin/ObserveTracker' into ObserveTracker
Nov 19, 2023
5aa2324
Rename SmartTags to be consistent with Samsungs current product lines
Nov 20, 2023
201b7e3
fix for common IllegalStateException in PlaySoundDialogFragment
Nov 20, 2023
bb3993b
add previewImage to the Article Function
Nov 22, 2023
7f06d31
Fix for Delete Study Data
Nov 24, 2023
534872a
Relevant Tracking Days can be set inividually for each Type of tracke…
Nov 25, 2023
973891c
upgrade gradle to 8.2.0
Dec 8, 2023
47657db
upgrade to Android 14 / SDK 34
Dec 8, 2023
24762e9
fix Crash when clicking on Scan Element
imbissbudenaesthetik Dec 11, 2023
7696ca0
optimize BluetoothReceiver for Android 13 or higher
imbissbudenaesthetik Dec 11, 2023
249a6d4
upgrade some plugins and dependencies
imbissbudenaesthetik Dec 11, 2023
a93b687
UI improvements: Manual Scan now more user friendly, more explanation…
Dec 18, 2023
24066ec
adjust articles for in production Server files
Dec 18, 2023
2d5fd57
Merge branch 'ObserveTracker' into TrackingOptimizations
Dec 18, 2023
c67bed3
number of Locations can be set individually for each tracker, in defa…
Dec 22, 2023
27f8e31
remove own location on map
Jan 2, 2024
ec5c2d0
NumberofLocations override can now be overwritten for every RiskLevel
Jan 2, 2024
da2042e
separate the connected / low Risk devices from the offline / high ris…
Jan 3, 2024
264696f
separated ScanView is now a NestedScrollView
Jan 3, 2024
0ebc53d
Manual Scan Behaviour now resembles the one from the iOS App
Jan 7, 2024
3a54b66
replace some of the deprecated Java Functions with backwards compatib…
imbissbudenaesthetik Jan 8, 2024
238247e
upgrade gradle to 8.2.1
imbissbudenaesthetik Jan 9, 2024
0ae5330
Scanning behaviour of Tile Tracker now closer to iOS Version
imbissbudenaesthetik Jan 9, 2024
66dbcfb
Device Detail Page now vertical, similar to iOS Design
imbissbudenaesthetik Jan 9, 2024
b723cff
add Website Link to Tracker Detail Page
imbissbudenaesthetik Jan 9, 2024
8652868
Update deprecated Code
Jan 9, 2024
19b1eb8
change relevant days to relevant hours
imbissbudenaesthetik Jan 15, 2024
c500fbf
Fixed an issue where the versionProvider was removed in the LocationP…
Sn0wfreezeDev Sep 21, 2023
2a089e2
Update 2.1 for F-Droid
Sn0wfreezeDev Oct 20, 2023
3b8f8d6
2.0 F-Droid Release version
Sn0wfreezeDev Jun 27, 2023
8e5f035
Fix Google Play badge in README.md
PeterDaveHello Sep 28, 2023
69199e5
Working on fixing SendStatisticsWorker
Sn0wfreezeDev Nov 12, 2023
f35fcdb
Changing proguard rules
Sn0wfreezeDev Nov 12, 2023
1cd320f
Reducing duplicate devices uploads
Sn0wfreezeDev Nov 14, 2023
a9e495e
F-Droid 2.1.1 Release
Sn0wfreezeDev Nov 14, 2023
eacf8bd
Updating F-Droid Metadata
Sn0wfreezeDev Nov 14, 2023
1dacfc1
Rebasing Main onto current branch
Sep 24, 2023
e086ed0
ObserveTrackerWorker now calls ScanBluetoothWorker manually before ch…
Oct 2, 2023
49b3192
Updating version in Manifest
Sn0wfreezeDev Jan 18, 2024
76c9390
some optimizations to the processing of manual scan items
Jan 21, 2024
f607a7e
some more optimizations to the processing of manual scan items, Devic…
Jan 22, 2024
6d09a21
A New notification for a device will only be sent if the device meets…
Jan 15, 2024
60ffc7a
upgrade Gradle and some dependecies
imbissbudenaesthetik Jan 25, 2024
fca9339
upgrade Kotlin Version to 1.9.22, more dependencies, migrate some fun…
imbissbudenaesthetik Jan 25, 2024
a2a64cd
reintroduce Scan Sorting again
Jan 31, 2024
74ad9c6
Detail Scan now shows correct Time since Tracker is in offline Mode
Jan 31, 2024
f5a9b09
add Legend to map
imbissbudenaesthetik Feb 7, 2024
b0a0d6b
upgrade some dependencies
imbissbudenaesthetik Feb 7, 2024
45031bf
upgrade some dependencies, modify dependency structure
Feb 7, 2024
7a21509
Merge branch 'TrackingOptimizations' into ScanRedesign
Feb 8, 2024
ea2b700
hide Website URL Button if Website URL could not be determined
imbissbudenaesthetik Feb 10, 2024
e58dd95
fix bug in sorting of manual scan, fix bug in article rendering in da…
imbissbudenaesthetik Feb 13, 2024
c1c23ac
adjust RiskLevel Numbers so they are consistent with the iOS Version
imbissbudenaesthetik Feb 14, 2024
0ab67ec
use separate Algorithm for Notifications and RiskLevel evaluation
imbissbudenaesthetik Feb 18, 2024
44b556e
optimize and Bugfix RiskLevelEvaluator
Feb 19, 2024
6d05b83
add feedback options other and not found. Add message success when su…
imbissbudenaesthetik Feb 22, 2024
b17376d
save sensitivity level for every notification, save connectionState f…
imbissbudenaesthetik Feb 22, 2024
f911ed8
devices that have not been seen in the last 30 days and beacons older…
imbissbudenaesthetik Feb 23, 2024
bb4e6d4
improve connectionState for chipolo devices
imbissbudenaesthetik Feb 23, 2024
a2598fa
safe all devices no matter in what connectionState. Hide safe tracker…
imbissbudenaesthetik Feb 23, 2024
1ee5ee4
log when and how many devices are getting deleted, small optimization…
imbissbudenaesthetik Feb 25, 2024
4a358ed
upgrade gradle to 8.3.0 and upgrade some dependencies
imbissbudenaesthetik Mar 5, 2024
335112a
remove Battery from Distance Scan
imbissbudenaesthetik Mar 5, 2024
ee89dd4
Show No trackers found since installation date, instead of last 14 days
Mar 6, 2024
7971408
Merge remote-tracking branch 'origin/TrackingOptimizations' into Trac…
Mar 6, 2024
a014d76
fix string showing wrong device type in feedback View
imbissbudenaesthetik Mar 6, 2024
beecb0b
Redesign Feedback, Fix Crashes in Feedback
Mar 6, 2024
adf6e03
make Feedback Button more visible, also improve some padding
imbissbudenaesthetik Mar 6, 2024
bcea3bf
add explanation text to device view that explains that some devices c…
imbissbudenaesthetik Mar 6, 2024
07c434e
add explanation for safe trackers in manual scan
imbissbudenaesthetik Mar 6, 2024
05fe801
Merge branch 'TrackingOptimizations' into development
imbissbudenaesthetik Mar 6, 2024
9f044b3
ignored trackers will be treated as safe trackers in manual scan
Mar 9, 2024
29d3952
Merge branch 'TrackingOptimizations' into development
imbissbudenaesthetik Mar 9, 2024
4807113
add Advanced Mode, that hides complicated to understand options and m…
imbissbudenaesthetik Mar 11, 2024
59f9d78
when deleting old devices and beacons, locations that are not used an…
imbissbudenaesthetik Mar 15, 2024
ae0532d
add Clustering to the map
imbissbudenaesthetik Mar 15, 2024
7b61934
highly optimize speed in loading map markers, update some dependencies
imbissbudenaesthetik Mar 17, 2024
7e67e4f
fix bug where numbers of locations being displayed were inconsistent
imbissbudenaesthetik Mar 17, 2024
e0ab32f
fix bug where map markers where not displayed correctly in TrackingFr…
imbissbudenaesthetik Mar 17, 2024
559d298
automatic adjustments to the code
imbissbudenaesthetik Mar 17, 2024
2f062e2
fix a bug where markers were not displayed correctly when accessed vi…
imbissbudenaesthetik Mar 17, 2024
98004f7
optimize retrieval of markers from the database
imbissbudenaesthetik Mar 17, 2024
884e509
Moving background scans to be scheduled by AlarmManager instead of ba…
Sn0wfreezeDev Mar 22, 2024
9df5356
Fixing map marker display issue:
Sn0wfreezeDev Mar 22, 2024
bb04ff3
first merge
imbissbudenaesthetik Mar 22, 2024
3bd1721
fix merge conflict
imbissbudenaesthetik Mar 22, 2024
d5f5a29
add indices to Beacon and BaseDevice
imbissbudenaesthetik Mar 22, 2024
1ef909f
Checking permission for setExact Alarm
Sn0wfreezeDev Mar 22, 2024
a1570e2
Fixing merge issues with git
Sn0wfreezeDev Mar 23, 2024
fae75e9
upgrade gradle to 8.3.1, upgrade dependencies
imbissbudenaesthetik Mar 23, 2024
ed860fa
replace some Strings with Plurals
Mar 23, 2024
7032a09
fix crash when double tapping scan result
imbissbudenaesthetik Mar 23, 2024
15a0150
add caching to deviceType retrieval and fix bug in old Beacon deletion
imbissbudenaesthetik Mar 23, 2024
0e6cf73
manual scan keeps pause state while viewing scan items. Limit notifyD…
imbissbudenaesthetik Mar 24, 2024
cbf9655
device name can be edited from device detail view by clicking on the …
imbissbudenaesthetik Mar 30, 2024
3112824
limit device name to 255 characters and one line, device name cannot …
imbissbudenaesthetik Mar 30, 2024
14ee5a1
revert savedConnections only to for Tracking Detection relevant
imbissbudenaesthetik Apr 8, 2024
52ed100
make corners of minimap rounded
imbissbudenaesthetik Apr 9, 2024
34444c0
add (currently not visible) simpler design for device view
imbissbudenaesthetik Apr 9, 2024
be5a604
altitude of each location now gets saved
imbissbudenaesthetik Apr 13, 2024
d9bdf5d
update existing locations if more recent and more accurate data is av…
imbissbudenaesthetik Apr 13, 2024
515f9a3
upgrade gradle and some dependecies
imbissbudenaesthetik Apr 15, 2024
0aa3318
upgrade Kotlin Version
imbissbudenaesthetik Apr 15, 2024
8300ced
do not save devices above an altitude of 9000 meters. This should avo…
imbissbudenaesthetik Apr 16, 2024
dfa1975
don't create location object above 3000 meters, this is different to …
imbissbudenaesthetik Apr 26, 2024
cefded6
upgrade gradle to 8.4.0
imbissbudenaesthetik May 2, 2024
9fff0da
fix bug where devices where not correctly put into safe and unsafe tr…
imbissbudenaesthetik May 2, 2024
d5d0fba
make some string more understandable
imbissbudenaesthetik May 2, 2024
7b4b574
make padding of map more consistent
imbissbudenaesthetik May 2, 2024
ee0717e
massive speed up of manual scan, cleanup code
imbissbudenaesthetik May 13, 2024
281215a
replace ScanResult in manual scan with Wrapper Object. Massive Speed …
imbissbudenaesthetik May 14, 2024
63200b4
Setting minimum detection events to 3 on medium security mode.
Sn0wfreezeDev May 15, 2024
7da26e0
Updating gradle and manifest
Sn0wfreezeDev May 15, 2024
88f5e3b
Updating gradle and manifest
Sn0wfreezeDev May 15, 2024
536da88
Testing app without FOREGROUND_SERVICE
Sn0wfreezeDev May 16, 2024
aa3f5ed
Rssi indicator image in manual scan updates if rssi value changes, up…
imbissbudenaesthetik May 16, 2024
f15ee71
optimize Repository Loading in manual scan
imbissbudenaesthetik May 16, 2024
063274c
further use of ScanResultWrapper in Backend. Put back Exact Alarm Per…
imbissbudenaesthetik May 19, 2024
c0656bd
fix TypeToken Error on some devices by updating proguard rules
imbissbudenaesthetik May 19, 2024
2ce1de6
add message in manual scan that Location Permission has to turned on
imbissbudenaesthetik May 19, 2024
e0f87ec
handle case if wakeLock cannot be held
imbissbudenaesthetik May 19, 2024
f0652b8
upgrade gradle to 8.4.1.
imbissbudenaesthetik May 22, 2024
802c86c
avoid unnecessary duplicate calls of getDeviceType
imbissbudenaesthetik May 22, 2024
c220f94
low risk "secure tracker" explanation in manual scan is hidden if the…
imbissbudenaesthetik May 22, 2024
7c442e4
Show Website URL also for Low Risk Devices
imbissbudenaesthetik May 22, 2024
de97650
Fix DeviceType Detection and Display of Explanation for it for unknow…
imbissbudenaesthetik May 22, 2024
4893218
fix bug in ScanDistance
imbissbudenaesthetik May 30, 2024
c2af3d7
fix bug in fetching deviceType from safe trackers
imbissbudenaesthetik May 30, 2024
8ed52d4
fix compilation bug
imbissbudenaesthetik May 30, 2024
fffd7f0
base Implementation of Google Tracker
imbissbudenaesthetik Jun 6, 2024
cb10d13
implement Google Tracker Page on AllDevicesFragment
imbissbudenaesthetik Jun 7, 2024
03cc5f0
implement Sound Service (not tested yet)
imbissbudenaesthetik Jun 7, 2024
c297ae3
Adopting changes to set alarms more reliably
Sn0wfreezeDev Jun 10, 2024
a4e5c83
Removing second launch icon
Sn0wfreezeDev Jun 10, 2024
8f79ecc
Adding Scheduling alarms with new permission for Android 13 and Andro…
Sn0wfreezeDev Jun 10, 2024
d974f6c
F-Droid 2.2
Sn0wfreezeDev Jun 11, 2024
0022220
Merge branch 'main' into development
Sn0wfreezeDev Jun 11, 2024
a073c3f
upgrade gradle, kotlin version and some dependencies
imbissbudenaesthetik Jun 12, 2024
c8a508c
Merge branch 'development' into GoogleNetwork
imbissbudenaesthetik Jun 12, 2024
df329d5
fix bug in kotlin version upgrade
imbissbudenaesthetik Jun 12, 2024
a6012d9
Reporting Chipolo as Overmature Offline when in tracking mode.
Sn0wfreezeDev Jun 13, 2024
7f9a9ef
Sorting ScanFragment by detection date instead of RSSI making it less…
Sn0wfreezeDev Jun 13, 2024
0afa613
Delete old trackers at the end in case this fails we can do not hinde…
Sn0wfreezeDev Jun 13, 2024
a111651
Merge branch 'refs/heads/development' into GoogleNetwork
imbissbudenaesthetik Jun 16, 2024
bf4c809
upgrade gradle to 8.5.0
imbissbudenaesthetik Jun 16, 2024
39ea3f4
upgrade gradle, kotlin version and some dependecies
imbissbudenaesthetik Jun 21, 2024
ecb5c81
add additional check to BackgroundBluetoothScanner
imbissbudenaesthetik Jun 21, 2024
be510e2
Merge branch 'refs/heads/development' into GoogleNetwork
imbissbudenaesthetik Jun 21, 2024
b156a23
adjust Strings, Chipolo isn now via default in UNKNOWN ConnectionState
imbissbudenaesthetik Jun 21, 2024
4fe6d5e
flip device type filter in the settings
imbissbudenaesthetik Jul 5, 2024
ab54583
generate unique notification id for every notification
imbissbudenaesthetik Jul 8, 2024
3cf9e36
fix some bugs from quality inside reports
imbissbudenaesthetik Jul 11, 2024
869b28f
update gradle and some dependencies
imbissbudenaesthetik Jul 15, 2024
f6e7970
Migrate from kapt to ksp
imbissbudenaesthetik Jul 15, 2024
513c806
Migrate to Kotlin 2.0.0
imbissbudenaesthetik Jul 15, 2024
da8defe
fix bug in Devices Filter Migration
imbissbudenaesthetik Jul 15, 2024
e73048d
add basic PebbleBee detection
imbissbudenaesthetik Jul 16, 2024
e2df728
add sound playing to Pebblebee
imbissbudenaesthetik Jul 17, 2024
5a87437
F-Droid 2.3
Sn0wfreezeDev Jul 31, 2024
309ed4b
Merge branch 'main' into development
Sn0wfreezeDev Jul 31, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion api.properties
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
API_KEY="AGdk9qPF.Bl9yatnjjoy9WEEjXYGVewE7ZyJET9Yy"
API_KEY="aGUuBakn.mm4dTiqKAfN6akqkzggODoJjmMkGAoWL"
API_BASE_ADDRESS="https://tpe.seemoo.tu-darmstadt.de/api/"
71 changes: 32 additions & 39 deletions app/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,11 @@ plugins {
id 'kotlin-android'
id 'androidx.navigation.safeargs.kotlin'
id 'kotlin-kapt'
id 'com.google.devtools.ksp'
id 'dagger.hilt.android.plugin'
id 'com.mikepenz.aboutlibraries.plugin'
id 'org.jetbrains.kotlin.android'
id 'org.jetbrains.compose'
id 'org.jetbrains.kotlin.plugin.compose' version "$kotlin_version"
}

def apiPropertiesFile = rootProject.file("api.properties")
Expand All @@ -26,19 +28,13 @@ android {
applicationId "de.seemoo.at_tracking_detection"
minSdkVersion 28
targetSdk = 34
versionCode 44
versionName "2.2"
versionCode 45
versionName "2.3"

buildConfigField "String", "API_KEY", apiProperties["API_KEY"]
buildConfigField "String", "API_BASE_ADDRESS", apiProperties["API_BASE_ADDRESS"]

testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"

kapt {
arguments {
arg("room.schemaLocation", "$projectDir/schemas")
}
}
}

buildTypes {
Expand All @@ -65,11 +61,6 @@ android {
jvmTarget = JavaVersion.VERSION_17.toString()
}

composeOptions {
kotlinCompilerExtensionVersion "1.5.11"
}


sourceSets {
// Adds exported schema location as test app assets.
androidTest.assets.srcDirs += files("$projectDir/schemas".toString())
Expand All @@ -95,31 +86,31 @@ dependencies {
implementation 'com.github.bastienpaulfr:Treessence:1.0.0'
implementation "androidx.work:work-runtime-ktx:$work_version"
implementation 'androidx.core:core-ktx:1.13.1'
implementation 'androidx.appcompat:appcompat:1.6.1'
implementation 'androidx.appcompat:appcompat:1.7.0'
implementation 'com.google.android.material:material:1.12.0'
implementation 'androidx.constraintlayout:constraintlayout:2.1.4'
implementation 'androidx.vectordrawable:vectordrawable:1.2.0'
implementation 'androidx.navigation:navigation-fragment-ktx:2.7.7'
implementation 'androidx.navigation:navigation-ui-ktx:2.7.7'
implementation 'androidx.lifecycle:lifecycle-livedata-ktx:2.8.0'
implementation 'androidx.lifecycle:lifecycle-viewmodel-ktx:2.8.0'
implementation 'androidx.lifecycle:lifecycle-livedata-ktx:2.8.3'
implementation 'androidx.lifecycle:lifecycle-viewmodel-ktx:2.8.3'
implementation 'androidx.lifecycle:lifecycle-extensions:2.2.0'
implementation 'androidx.preference:preference-ktx:1.2.1'
implementation 'androidx.cardview:cardview:1.0.0'
implementation 'androidx.recyclerview:recyclerview:1.3.2'

implementation 'com.squareup.retrofit2:retrofit:2.9.0'
implementation 'com.squareup.retrofit2:converter-gson:2.9.0'
implementation 'com.squareup.okhttp3:okhttp:5.0.0-alpha.12'
implementation 'com.squareup.okhttp3:okhttp:5.0.0-alpha.14'
implementation 'com.google.code.gson:gson:2.10.1'
implementation 'androidx.legacy:legacy-support-v4:1.0.0'
implementation "androidx.work:work-testing:$work_version"
implementation 'androidx.core:core-ktx:1.13.1'
debugImplementation 'com.squareup.okhttp3:logging-interceptor:5.0.0-alpha.12'
debugImplementation 'com.squareup.okhttp3:logging-interceptor:5.0.0-alpha.14'

implementation "com.google.dagger:hilt-android:$hilt_version"
implementation 'androidx.hilt:hilt-work:1.2.0'
implementation 'androidx.hilt:hilt-navigation-fragment:1.2.0'
implementation "com.google.dagger:hilt-android:$hilt_compiler_version"
implementation "androidx.hilt:hilt-work:$hilt_version"
implementation "androidx.hilt:hilt-navigation-fragment:$hilt_version"

implementation 'com.github.AppIntro:AppIntro:6.1.0'

Expand All @@ -134,23 +125,22 @@ dependencies {

implementation 'com.github.bumptech.glide:glide:4.16.0'


kapt "com.google.dagger:hilt-compiler:$hilt_version"
kapt 'androidx.hilt:hilt-compiler:1.2.0'
ksp "com.google.dagger:hilt-compiler:$hilt_compiler_version"
ksp "androidx.hilt:hilt-compiler:$hilt_version"

implementation "androidx.room:room-runtime:$room_version"
implementation "androidx.room:room-ktx:$room_version"
kapt "androidx.room:room-compiler:$room_version"
ksp "androidx.room:room-compiler:$room_version"

androidTestImplementation 'androidx.test.ext:junit:1.1.5'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.5.1'
androidTestImplementation 'androidx.test.ext:junit:1.2.1'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.6.1'
androidTestImplementation "androidx.room:room-testing:$room_version"
androidTestImplementation 'org.jetbrains.kotlinx:kotlinx-coroutines-test:1.8.0'
androidTestImplementation 'androidx.test:core:1.5.0'
androidTestImplementation 'androidx.test:core-ktx:1.5.0'
androidTestImplementation 'androidx.test.ext:junit-ktx:1.1.5'
androidTestImplementation 'androidx.test:runner:1.5.2'
androidTestImplementation 'androidx.test.espresso:espresso-contrib:3.5.1'
androidTestImplementation 'org.jetbrains.kotlinx:kotlinx-coroutines-test:1.8.1'
androidTestImplementation 'androidx.test:core:1.6.1'
androidTestImplementation 'androidx.test:core-ktx:1.6.1'
androidTestImplementation 'androidx.test.ext:junit-ktx:1.2.1'
androidTestImplementation 'androidx.test:runner:1.6.1'
androidTestImplementation 'androidx.test.espresso:espresso-contrib:3.6.1'

coreLibraryDesugaring 'com.android.tools:desugar_jdk_libs:2.0.4'

Expand All @@ -161,16 +151,19 @@ dependencies {
// Integration with activities
implementation 'androidx.activity:activity-compose:1.9.0'
// Compose Material Design
implementation 'androidx.compose.material:material:1.6.7'
implementation 'androidx.compose.material:material:1.6.8'
// Animations
implementation 'androidx.compose.animation:animation:1.6.7'
implementation 'androidx.compose.animation:animation:1.6.8'
// Tooling support (Previews, etc.)
implementation 'androidx.compose.ui:ui-tooling:1.6.7'
implementation 'androidx.compose.ui:ui-tooling:1.6.8'
// Integration with ViewModels
implementation 'androidx.lifecycle:lifecycle-viewmodel-compose:2.8.0'
implementation 'androidx.lifecycle:lifecycle-viewmodel-compose:2.8.3'
// UI Tests
androidTestImplementation 'androidx.compose.ui:ui-test-junit4:1.6.7'
androidTestImplementation 'androidx.compose.ui:ui-test-junit4:1.6.8'
// When using a MDC theme
implementation "com.google.android.material:compose-theme-adapter:1.2.1"
}

ksp {
arg("room.schemaLocation", "$projectDir/schemas")
}
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ class DevicesTabUITest {

//Disabling all devices
onView(withText("AirTag")).perform(click())
onView(withText("FindMy Device")).perform(click())
onView(withText("AppleFindMy Device")).perform(click())
onView(withText("AirPods")).perform(click())
onView(withText("Apple Device")).perform(click())
onView(withText("Galaxy SmartTag")).perform(click())
Expand All @@ -101,7 +101,7 @@ class DevicesTabUITest {

//Enabling all devices
onView(withText("AirTag")).perform(click())
onView(withText("FindMy Device")).perform(click())
onView(withText("AppleFindMy Device")).perform(click())
onView(withText("AirPods")).perform(click())
onView(withText("Apple Device")).perform(click())
onView(withText("Galaxy SmartTag")).perform(click())
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -103,12 +103,14 @@ data class BaseDevice(
DeviceType.UNKNOWN -> Unknown(deviceId)
DeviceType.APPLE -> AppleDevice(deviceId)
DeviceType.AIRPODS -> AirPods(deviceId)
DeviceType.FIND_MY -> FindMy(deviceId)
DeviceType.FIND_MY -> AppleFindMy(deviceId)
DeviceType.TILE -> Tile(deviceId)
DeviceType.CHIPOLO -> Chipolo(deviceId)
DeviceType.PEBBLEBEE -> PebbleBee(deviceId)
DeviceType.SAMSUNG -> SamsungDevice(deviceId)
DeviceType.GALAXY_SMART_TAG -> SmartTag(deviceId)
DeviceType.GALAXY_SMART_TAG_PLUS -> SmartTagPlus(deviceId)
DeviceType.GOOGLE_FIND_MY_NETWORK -> GoogleFindMyNetwork(deviceId)
else -> {
// For backwards compatibility
if (payloadData?.and(0x10)?.toInt() != 0 && connectable == true) {
Expand Down Expand Up @@ -145,13 +147,15 @@ data class BaseDevice(
return when (deviceType) {
DeviceType.TILE -> Tile.getConnectionState(scanResult)
DeviceType.CHIPOLO -> Chipolo.getConnectionState(scanResult)
DeviceType.PEBBLEBEE -> PebbleBee.getConnectionState(scanResult)
DeviceType.SAMSUNG,
DeviceType.GALAXY_SMART_TAG,
DeviceType.GALAXY_SMART_TAG_PLUS -> SamsungDevice.getConnectionState(scanResult)
DeviceType.AIRPODS,
DeviceType.FIND_MY,
DeviceType.AIRTAG,
DeviceType.APPLE -> AppleDevice.getConnectionState(scanResult)
DeviceType.GOOGLE_FIND_MY_NETWORK -> GoogleFindMyNetwork.getConnectionState(scanResult)
else -> ConnectionState.UNKNOWN
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,8 @@ import kotlin.experimental.and

object DeviceManager {

val devices = listOf(AirTag, FindMy, AirPods, AppleDevice, SmartTag, SmartTagPlus, Tile, Chipolo)
private val appleDevices = listOf(AirTag, FindMy, AirPods, AppleDevice)
val devices = listOf(AirTag, AppleFindMy, AirPods, AppleDevice, SmartTag, SmartTagPlus, Tile, Chipolo, PebbleBee, GoogleFindMyNetwork)
private val appleDevices = listOf(AirTag, AppleFindMy, AirPods, AppleDevice)
val unsafeConnectionState = listOf(ConnectionState.OVERMATURE_OFFLINE, ConnectionState.UNKNOWN)
val savedConnectionStates = unsafeConnectionState //enumValues<ConnectionState>().toList()

Expand All @@ -32,7 +32,7 @@ object DeviceManager {
}
}

fun getDeviceTypeFromCache(deviceAddress: String): DeviceType? {
private fun getDeviceTypeFromCache(deviceAddress: String): DeviceType? {
deviceTypeCache[deviceAddress]?.let { cachedDeviceType ->
return cachedDeviceType
}
Expand All @@ -56,10 +56,15 @@ object DeviceManager {
}
}

if (scanRecord.serviceData.contains(GoogleFindMyNetwork.offlineFindingServiceUUID)) {
return GoogleFindMyNetwork.deviceType
}

scanRecord.serviceUuids?.let { services ->
when {
services.contains(Tile.offlineFindingServiceUUID) -> return Tile.deviceType
services.contains(Chipolo.offlineFindingServiceUUID) -> return Chipolo.deviceType
services.contains(PebbleBee.offlineFindingServiceUUID) -> return PebbleBee.deviceType
services.contains(SmartTag.offlineFindingServiceUUID) -> return SamsungDevice.getSamsungDeviceType(scanResult)
else -> return Unknown.deviceType
}
Expand All @@ -75,11 +80,13 @@ object DeviceManager {
DeviceType.APPLE -> AppleDevice.websiteManufacturer
DeviceType.AIRPODS -> AirPods.websiteManufacturer
DeviceType.TILE -> Tile.websiteManufacturer
DeviceType.FIND_MY -> FindMy.websiteManufacturer
DeviceType.FIND_MY -> AppleFindMy.websiteManufacturer
DeviceType.CHIPOLO -> Chipolo.websiteManufacturer
DeviceType.PEBBLEBEE -> PebbleBee.websiteManufacturer
DeviceType.SAMSUNG -> SamsungDevice.websiteManufacturer
DeviceType.GALAXY_SMART_TAG -> SmartTag.websiteManufacturer
DeviceType.GALAXY_SMART_TAG_PLUS -> SmartTagPlus.websiteManufacturer
DeviceType.GOOGLE_FIND_MY_NETWORK -> GoogleFindMyNetwork.websiteManufacturer
}
}

Expand All @@ -91,7 +98,9 @@ object DeviceManager {
return DeviceType.valueOf(deviceTypeString)
}

val scanFilter: List<ScanFilter> = devices.map { it.bluetoothFilter }
val scanFilter: List<ScanFilter> = devices.map {
it.bluetoothFilter
}

val gattIntentFilter: IntentFilter = IntentFilter().apply {
addAction(BluetoothConstants.ACTION_EVENT_RUNNING)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,11 @@ enum class DeviceType {
TILE,
FIND_MY,
CHIPOLO,
PEBBLEBEE,
SAMSUNG,
GALAXY_SMART_TAG,
GALAXY_SMART_TAG_PLUS;
GALAXY_SMART_TAG_PLUS,
GOOGLE_FIND_MY_NETWORK;

companion object {
fun userReadableName(deviceType: DeviceType): String {
Expand All @@ -23,12 +25,14 @@ enum class DeviceType {
AIRPODS -> AirPods.defaultDeviceName
AIRTAG -> AirTag.defaultDeviceName
APPLE -> AppleDevice.defaultDeviceName
FIND_MY -> FindMy.defaultDeviceName
FIND_MY -> AppleFindMy.defaultDeviceName
TILE -> Tile.defaultDeviceName
PEBBLEBEE -> PebbleBee.defaultDeviceName
CHIPOLO -> Chipolo.defaultDeviceName
SAMSUNG -> SamsungDevice.defaultDeviceName
GALAXY_SMART_TAG -> SmartTag.defaultDeviceName
GALAXY_SMART_TAG_PLUS -> SmartTagPlus.defaultDeviceName
GOOGLE_FIND_MY_NETWORK -> GoogleFindMyNetwork.defaultDeviceName
}
}

Expand All @@ -41,9 +45,11 @@ enum class DeviceType {
FIND_MY -> R.drawable.ic_chipolo
TILE -> R.drawable.ic_tile
CHIPOLO -> R.drawable.ic_chipolo
PEBBLEBEE -> R.drawable.ic_baseline_device_unknown_24
SAMSUNG -> R.drawable.ic_baseline_device_unknown_24
GALAXY_SMART_TAG -> R.drawable.ic_smarttag_icon
GALAXY_SMART_TAG_PLUS -> R.drawable.ic_smarttag_icon
GOOGLE_FIND_MY_NETWORK -> R.drawable.ic_chipolo
}
}

Expand All @@ -64,6 +70,8 @@ enum class DeviceType {
allowedDeviceTypes.add(GALAXY_SMART_TAG_PLUS)
}
"tiles" -> allowedDeviceTypes.add(TILE)
"pebblebees" -> allowedDeviceTypes.add(PEBBLEBEE)
"google_find_my_network" -> allowedDeviceTypes.add(GOOGLE_FIND_MY_NETWORK)
}
}

Expand All @@ -77,6 +85,7 @@ enum class DeviceType {
return when (this) {
TILE -> true
CHIPOLO -> true
PEBBLEBEE -> true
else -> false
}
}
Expand All @@ -85,59 +94,67 @@ enum class DeviceType {
return when (this) {
TILE -> Tile.numberOfHoursToBeConsideredForTrackingDetection
CHIPOLO -> Chipolo.numberOfHoursToBeConsideredForTrackingDetection
PEBBLEBEE -> PebbleBee.numberOfHoursToBeConsideredForTrackingDetection
UNKNOWN -> Unknown.numberOfHoursToBeConsideredForTrackingDetection
AIRPODS -> AirPods.numberOfHoursToBeConsideredForTrackingDetection
AIRTAG -> AirTag.numberOfHoursToBeConsideredForTrackingDetection
APPLE -> AppleDevice.numberOfHoursToBeConsideredForTrackingDetection
FIND_MY -> FindMy.numberOfHoursToBeConsideredForTrackingDetection
FIND_MY -> AppleFindMy.numberOfHoursToBeConsideredForTrackingDetection
SAMSUNG -> SamsungDevice.numberOfHoursToBeConsideredForTrackingDetection
GALAXY_SMART_TAG -> SmartTag.numberOfHoursToBeConsideredForTrackingDetection
GALAXY_SMART_TAG_PLUS -> SmartTagPlus.numberOfHoursToBeConsideredForTrackingDetection
GOOGLE_FIND_MY_NETWORK -> GoogleFindMyNetwork.numberOfHoursToBeConsideredForTrackingDetection
}
}

fun getNumberOfLocationsToBeConsideredForTrackingDetectionLow(): Int {
return when (this) {
TILE -> Tile.numberOfLocationsToBeConsideredForTrackingDetectionLow
CHIPOLO -> Chipolo.numberOfLocationsToBeConsideredForTrackingDetectionLow
PEBBLEBEE -> PebbleBee.numberOfLocationsToBeConsideredForTrackingDetectionLow
UNKNOWN -> Unknown.numberOfLocationsToBeConsideredForTrackingDetectionLow
AIRPODS -> AirPods.numberOfLocationsToBeConsideredForTrackingDetectionLow
AIRTAG -> AirTag.numberOfLocationsToBeConsideredForTrackingDetectionLow
APPLE -> AppleDevice.numberOfLocationsToBeConsideredForTrackingDetectionLow
FIND_MY -> FindMy.numberOfLocationsToBeConsideredForTrackingDetectionLow
FIND_MY -> AppleFindMy.numberOfLocationsToBeConsideredForTrackingDetectionLow
SAMSUNG -> SamsungDevice.numberOfLocationsToBeConsideredForTrackingDetectionLow
GALAXY_SMART_TAG -> SmartTag.numberOfLocationsToBeConsideredForTrackingDetectionLow
GALAXY_SMART_TAG_PLUS -> SmartTagPlus.numberOfLocationsToBeConsideredForTrackingDetectionLow
GOOGLE_FIND_MY_NETWORK -> GoogleFindMyNetwork.numberOfLocationsToBeConsideredForTrackingDetectionLow
}
}

fun getNumberOfLocationsToBeConsideredForTrackingDetectionMedium(): Int {
return when (this) {
TILE -> Tile.numberOfLocationsToBeConsideredForTrackingDetectionMedium
CHIPOLO -> Chipolo.numberOfLocationsToBeConsideredForTrackingDetectionMedium
PEBBLEBEE -> PebbleBee.numberOfLocationsToBeConsideredForTrackingDetectionMedium
UNKNOWN -> Unknown.numberOfLocationsToBeConsideredForTrackingDetectionMedium
AIRPODS -> AirPods.numberOfLocationsToBeConsideredForTrackingDetectionMedium
AIRTAG -> AirTag.numberOfLocationsToBeConsideredForTrackingDetectionMedium
APPLE -> AppleDevice.numberOfLocationsToBeConsideredForTrackingDetectionMedium
FIND_MY -> FindMy.numberOfLocationsToBeConsideredForTrackingDetectionMedium
FIND_MY -> AppleFindMy.numberOfLocationsToBeConsideredForTrackingDetectionMedium
SAMSUNG -> SamsungDevice.numberOfLocationsToBeConsideredForTrackingDetectionMedium
GALAXY_SMART_TAG -> SmartTag.numberOfLocationsToBeConsideredForTrackingDetectionMedium
GALAXY_SMART_TAG_PLUS -> SmartTagPlus.numberOfLocationsToBeConsideredForTrackingDetectionMedium
GOOGLE_FIND_MY_NETWORK -> GoogleFindMyNetwork.numberOfLocationsToBeConsideredForTrackingDetectionMedium
}
}

fun getNumberOfLocationsToBeConsideredForTrackingDetectionHigh(): Int {
return when (this) {
TILE -> Tile.numberOfLocationsToBeConsideredForTrackingDetectionHigh
CHIPOLO -> Chipolo.numberOfLocationsToBeConsideredForTrackingDetectionHigh
PEBBLEBEE -> PebbleBee.numberOfLocationsToBeConsideredForTrackingDetectionHigh
UNKNOWN -> Unknown.numberOfLocationsToBeConsideredForTrackingDetectionHigh
AIRPODS -> AirPods.numberOfLocationsToBeConsideredForTrackingDetectionHigh
AIRTAG -> AirTag.numberOfLocationsToBeConsideredForTrackingDetectionHigh
APPLE -> AppleDevice.numberOfLocationsToBeConsideredForTrackingDetectionHigh
FIND_MY -> FindMy.numberOfLocationsToBeConsideredForTrackingDetectionHigh
FIND_MY -> AppleFindMy.numberOfLocationsToBeConsideredForTrackingDetectionHigh
SAMSUNG -> SamsungDevice.numberOfLocationsToBeConsideredForTrackingDetectionHigh
GALAXY_SMART_TAG -> SmartTag.numberOfLocationsToBeConsideredForTrackingDetectionHigh
GALAXY_SMART_TAG_PLUS -> SmartTagPlus.numberOfLocationsToBeConsideredForTrackingDetectionHigh
GOOGLE_FIND_MY_NETWORK -> GoogleFindMyNetwork.numberOfLocationsToBeConsideredForTrackingDetectionHigh
}
}
}
Loading
Loading