Harden geofence automation and home editing
This commit is contained in:
@@ -1,12 +1,13 @@
|
||||
import 'package:flutter/services.dart';
|
||||
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
||||
import 'package:geolocator/geolocator.dart';
|
||||
|
||||
import '../../homes/providers/homes_providers.dart';
|
||||
import '../../homes/providers/location_providers.dart';
|
||||
import '../../shared/providers/core_providers.dart';
|
||||
import '../models/app_theme_preset.dart';
|
||||
import '../models/geofence_system_state.dart';
|
||||
import '../models/notification_permission_status.dart';
|
||||
import '../services/geofence_system_status_service.dart';
|
||||
import '../services/notification_permission_status_service.dart';
|
||||
|
||||
final initialAppThemePresetProvider = Provider<AppThemePreset>(
|
||||
(ref) => AppThemePreset.fallback,
|
||||
@@ -29,53 +30,11 @@ class AppThemeNotifier extends Notifier<AppThemePreset> {
|
||||
}
|
||||
}
|
||||
|
||||
abstract class GeofenceSystemStatusService {
|
||||
Future<GeofenceSystemState> inspect({
|
||||
required bool hasActiveHome,
|
||||
required bool hasCoordinates,
|
||||
});
|
||||
}
|
||||
|
||||
class DeviceGeofenceSystemStatusService implements GeofenceSystemStatusService {
|
||||
@override
|
||||
Future<GeofenceSystemState> inspect({
|
||||
required bool hasActiveHome,
|
||||
required bool hasCoordinates,
|
||||
}) async {
|
||||
if (!hasActiveHome) {
|
||||
return const GeofenceSystemState(GeofenceSystemIssue.noActiveHome);
|
||||
}
|
||||
if (!hasCoordinates) {
|
||||
return const GeofenceSystemState(GeofenceSystemIssue.missingCoordinates);
|
||||
}
|
||||
if (!await Geolocator.isLocationServiceEnabled()) {
|
||||
return const GeofenceSystemState(
|
||||
GeofenceSystemIssue.locationServicesDisabled,
|
||||
);
|
||||
}
|
||||
|
||||
final permission = await Geolocator.checkPermission();
|
||||
return switch (permission) {
|
||||
LocationPermission.denied => const GeofenceSystemState(
|
||||
GeofenceSystemIssue.permissionDenied,
|
||||
),
|
||||
LocationPermission.deniedForever => const GeofenceSystemState(
|
||||
GeofenceSystemIssue.permissionDeniedForever,
|
||||
),
|
||||
LocationPermission.whileInUse => const GeofenceSystemState(
|
||||
GeofenceSystemIssue.backgroundPermissionRequired,
|
||||
),
|
||||
LocationPermission.always => const GeofenceSystemState(
|
||||
GeofenceSystemIssue.ready,
|
||||
),
|
||||
_ => const GeofenceSystemState(GeofenceSystemIssue.permissionDenied),
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
final geofenceSystemStatusServiceProvider =
|
||||
Provider<GeofenceSystemStatusService>(
|
||||
(ref) => DeviceGeofenceSystemStatusService(),
|
||||
(ref) => DeviceGeofenceSystemStatusService(
|
||||
locationPlatformService: ref.read(locationPlatformServiceProvider),
|
||||
),
|
||||
);
|
||||
|
||||
final geofenceSystemStatusProvider = FutureProvider<GeofenceSystemState>((
|
||||
@@ -90,49 +49,6 @@ final geofenceSystemStatusProvider = FutureProvider<GeofenceSystemState>((
|
||||
);
|
||||
});
|
||||
|
||||
abstract class NotificationPermissionStatusService {
|
||||
Future<NotificationPermissionStatus> inspect();
|
||||
|
||||
Future<void> requestPermission();
|
||||
|
||||
Future<void> openSettings();
|
||||
}
|
||||
|
||||
class DeviceNotificationPermissionStatusService
|
||||
implements NotificationPermissionStatusService {
|
||||
static const _channel = MethodChannel('ignis/geofence_automation');
|
||||
|
||||
@override
|
||||
Future<NotificationPermissionStatus> inspect() async {
|
||||
try {
|
||||
final value = await _channel.invokeMethod<String>(
|
||||
'getNotificationPermissionStatus',
|
||||
);
|
||||
return NotificationPermissionStatus.fromPlatformValue(value);
|
||||
} on MissingPluginException {
|
||||
return NotificationPermissionStatus.unsupported;
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
Future<void> requestPermission() async {
|
||||
try {
|
||||
await _channel.invokeMethod<void>('requestNotificationPermission');
|
||||
} on MissingPluginException {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
Future<void> openSettings() async {
|
||||
try {
|
||||
await _channel.invokeMethod<void>('openNotificationSettings');
|
||||
} on MissingPluginException {
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
final notificationPermissionStatusServiceProvider =
|
||||
Provider<NotificationPermissionStatusService>(
|
||||
(ref) => DeviceNotificationPermissionStatusService(),
|
||||
|
||||
@@ -0,0 +1,52 @@
|
||||
import 'package:geolocator/geolocator.dart';
|
||||
|
||||
import '../../homes/services/location_platform_service.dart';
|
||||
import '../models/geofence_system_state.dart';
|
||||
|
||||
abstract class GeofenceSystemStatusService {
|
||||
Future<GeofenceSystemState> inspect({
|
||||
required bool hasActiveHome,
|
||||
required bool hasCoordinates,
|
||||
});
|
||||
}
|
||||
|
||||
class DeviceGeofenceSystemStatusService implements GeofenceSystemStatusService {
|
||||
final LocationPlatformService locationPlatformService;
|
||||
|
||||
DeviceGeofenceSystemStatusService({required this.locationPlatformService});
|
||||
|
||||
@override
|
||||
Future<GeofenceSystemState> inspect({
|
||||
required bool hasActiveHome,
|
||||
required bool hasCoordinates,
|
||||
}) async {
|
||||
if (!hasActiveHome) {
|
||||
return const GeofenceSystemState(GeofenceSystemIssue.noActiveHome);
|
||||
}
|
||||
if (!hasCoordinates) {
|
||||
return const GeofenceSystemState(GeofenceSystemIssue.missingCoordinates);
|
||||
}
|
||||
if (!await locationPlatformService.isLocationServiceEnabled()) {
|
||||
return const GeofenceSystemState(
|
||||
GeofenceSystemIssue.locationServicesDisabled,
|
||||
);
|
||||
}
|
||||
|
||||
final permission = await locationPlatformService.checkPermission();
|
||||
return switch (permission) {
|
||||
LocationPermission.denied => const GeofenceSystemState(
|
||||
GeofenceSystemIssue.permissionDenied,
|
||||
),
|
||||
LocationPermission.deniedForever => const GeofenceSystemState(
|
||||
GeofenceSystemIssue.permissionDeniedForever,
|
||||
),
|
||||
LocationPermission.whileInUse => const GeofenceSystemState(
|
||||
GeofenceSystemIssue.backgroundPermissionRequired,
|
||||
),
|
||||
LocationPermission.always => const GeofenceSystemState(
|
||||
GeofenceSystemIssue.ready,
|
||||
),
|
||||
_ => const GeofenceSystemState(GeofenceSystemIssue.permissionDenied),
|
||||
};
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,46 @@
|
||||
import 'package:flutter/services.dart';
|
||||
|
||||
import '../models/notification_permission_status.dart';
|
||||
|
||||
abstract class NotificationPermissionStatusService {
|
||||
Future<NotificationPermissionStatus> inspect();
|
||||
|
||||
Future<void> requestPermission();
|
||||
|
||||
Future<void> openSettings();
|
||||
}
|
||||
|
||||
class DeviceNotificationPermissionStatusService
|
||||
implements NotificationPermissionStatusService {
|
||||
static const _channel = MethodChannel('ignis/geofence_automation');
|
||||
|
||||
@override
|
||||
Future<NotificationPermissionStatus> inspect() async {
|
||||
try {
|
||||
final value = await _channel.invokeMethod<String>(
|
||||
'getNotificationPermissionStatus',
|
||||
);
|
||||
return NotificationPermissionStatus.fromPlatformValue(value);
|
||||
} on MissingPluginException {
|
||||
return NotificationPermissionStatus.unsupported;
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
Future<void> requestPermission() async {
|
||||
try {
|
||||
await _channel.invokeMethod<void>('requestNotificationPermission');
|
||||
} on MissingPluginException {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
Future<void> openSettings() async {
|
||||
try {
|
||||
await _channel.invokeMethod<void>('openNotificationSettings');
|
||||
} on MissingPluginException {
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user