forked from jens/Automation
		
	Fixed app crashing when saving rules while service is running.
This commit is contained in:
		| @@ -11,8 +11,8 @@ android { | |||||||
|         compileSdkVersion 29 |         compileSdkVersion 29 | ||||||
|         buildToolsVersion '29.0.2' |         buildToolsVersion '29.0.2' | ||||||
|         useLibrary  'org.apache.http.legacy' |         useLibrary  'org.apache.http.legacy' | ||||||
|         versionCode 100 |         versionCode 101 | ||||||
|         versionName "1.6.24" |         versionName "1.6.25" | ||||||
|  |  | ||||||
|         testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" |         testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -273,34 +273,42 @@ public class ReceiverCoordinator | |||||||
|  |  | ||||||
|         if(Rule.isAnyRuleUsing(Trigger.Trigger_Enum.activityDetection)) |         if(Rule.isAnyRuleUsing(Trigger.Trigger_Enum.activityDetection)) | ||||||
|         { |         { | ||||||
|             boolean isRunning = (Boolean)Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "isActivityDetectionReceiverRunning", null); |             Object runResult = Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "isActivityDetectionReceiverRunning", null);; | ||||||
|             if(isRunning) |             if(runResult instanceof Boolean) | ||||||
|  |             { | ||||||
|  |                 boolean isRunning = (Boolean) runResult; | ||||||
|  |                 if (isRunning) | ||||||
|                 { |                 { | ||||||
|                     Miscellaneous.logEvent("i", "LocationProvider", "Restarting ActivityDetectionReceiver because used in a new/changed rule.", 4); |                     Miscellaneous.logEvent("i", "LocationProvider", "Restarting ActivityDetectionReceiver because used in a new/changed rule.", 4); | ||||||
|                 boolean haveAllPerms = (Boolean)Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "haveAllPermission", null); |                     boolean haveAllPerms = (Boolean) Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "haveAllPermission", null); | ||||||
|                 if(haveAllPerms) |                     if (haveAllPerms) | ||||||
|                         Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "restartActivityDetectionReceiver", null); |                         Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "restartActivityDetectionReceiver", null); | ||||||
| //                    ActivityDetectionReceiver.restartActivityDetectionReceiver(); | //                    ActivityDetectionReceiver.restartActivityDetectionReceiver(); | ||||||
|                 } |                 } | ||||||
|                 else |                 else | ||||||
|                 { |                 { | ||||||
|                     Miscellaneous.logEvent("i", "LocationProvider", "Starting ActivityDetectionReceiver because used in a new/changed rule.", 4); |                     Miscellaneous.logEvent("i", "LocationProvider", "Starting ActivityDetectionReceiver because used in a new/changed rule.", 4); | ||||||
|                 boolean haveAllPerms = (Boolean)Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "haveAllPermission", null); |                     boolean haveAllPerms = (Boolean) Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "haveAllPermission", null); | ||||||
|                 if(haveAllPerms) |                     if (haveAllPerms) | ||||||
|                         Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "startActivityDetectionReceiver", null); |                         Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "startActivityDetectionReceiver", null); | ||||||
| //                    ActivityDetectionReceiver.startActivityDetectionReceiver(); | //                    ActivityDetectionReceiver.startActivityDetectionReceiver(); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |         } | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             boolean isRunning = (Boolean)Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "isActivityDetectionReceiverRunning", null); |             Object runResult = Miscellaneous.runMethodReflective(activityDetectionClassPath, "isActivityDetectionReceiverRunning", null); | ||||||
|             if(isRunning) |             if(runResult instanceof Boolean) | ||||||
|  |             { | ||||||
|  |                 boolean isRunning = (Boolean) runResult; | ||||||
|  |                 if (isRunning) | ||||||
|                 { |                 { | ||||||
|                     Miscellaneous.logEvent("i", "LocationProvider", "Shutting down ActivityDetectionReceiver because not used in any rule.", 4); |                     Miscellaneous.logEvent("i", "LocationProvider", "Shutting down ActivityDetectionReceiver because not used in any rule.", 4); | ||||||
|                     Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "stopActivityDetectionReceiver", null); |                     Miscellaneous.runMethodReflective("ActivityDetectionReceiver", "stopActivityDetectionReceiver", null); | ||||||
| //                ActivityDetectionReceiver.stopActivityDetectionReceiver(); | //                ActivityDetectionReceiver.stopActivityDetectionReceiver(); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|         if(Rule.isAnyRuleUsing(Trigger.Trigger_Enum.bluetoothConnection)) |         if(Rule.isAnyRuleUsing(Trigger.Trigger_Enum.bluetoothConnection)) | ||||||
|         { |         { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user