Compare commits
	
		
			15 Commits
		
	
	
		
			v1.6.36
			...
			cb430b957f
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| cb430b957f | |||
| b6a0f6dd91 | |||
| bc32cbc179 | |||
| d9cc604bdd | |||
| db21011b7f | |||
| dc35c8b7fb | |||
| 5a7cbfcdc9 | |||
| 913a37a320 | |||
| 14655fe55d | |||
| cfc145c6c4 | |||
| 325bff305c | |||
| 4371fb56f7 | |||
| 6593f6c923 | |||
| 7fbac92360 | |||
| 7415830dd7 | 
							
								
								
									
										17
									
								
								.idea/deploymentTargetDropDown.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								.idea/deploymentTargetDropDown.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <project version="4"> | ||||||
|  |   <component name="deploymentTargetDropDown"> | ||||||
|  |     <targetSelectedWithDropDown> | ||||||
|  |       <Target> | ||||||
|  |         <type value="QUICK_BOOT_TARGET" /> | ||||||
|  |         <deviceKey> | ||||||
|  |           <Key> | ||||||
|  |             <type value="VIRTUAL_DEVICE_PATH" /> | ||||||
|  |             <value value="C:\Users\jens\.android\avd\Android_11.avd" /> | ||||||
|  |           </Key> | ||||||
|  |         </deviceKey> | ||||||
|  |       </Target> | ||||||
|  |     </targetSelectedWithDropDown> | ||||||
|  |     <timeTargetWasSelectedWithDropDown value="2021-08-14T11:41:28.444891400Z" /> | ||||||
|  |   </component> | ||||||
|  | </project> | ||||||
							
								
								
									
										10
									
								
								.idea/runConfigurations.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										10
									
								
								.idea/runConfigurations.xml
									
									
									
										generated
									
									
									
								
							| @@ -1,10 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8"?> |  | ||||||
| <project version="4"> |  | ||||||
|   <component name="RunConfigurationProducerService"> |  | ||||||
|     <option name="ignoredProducers"> |  | ||||||
|       <set> |  | ||||||
|         <option value="com.android.tools.idea.compose.preview.runconfiguration.ComposePreviewRunConfigurationProducer" /> |  | ||||||
|       </set> |  | ||||||
|     </option> |  | ||||||
|   </component> |  | ||||||
| </project> |  | ||||||
| @@ -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 107 |         versionCode 112 | ||||||
|         versionName "1.6.36" |         versionName "1.6.42" | ||||||
|  |  | ||||||
|         testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" |         testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| { | { | ||||||
|   "version": 2, |   "version": 3, | ||||||
|   "artifactType": { |   "artifactType": { | ||||||
|     "type": "APK", |     "type": "APK", | ||||||
|     "kind": "Directory" |     "kind": "Directory" | ||||||
| @@ -10,9 +10,11 @@ | |||||||
|     { |     { | ||||||
|       "type": "SINGLE", |       "type": "SINGLE", | ||||||
|       "filters": [], |       "filters": [], | ||||||
|       "versionCode": 106, |       "attributes": [], | ||||||
|       "versionName": "1.6.35-googlePlay", |       "versionCode": 112, | ||||||
|  |       "versionName": "1.6.42-googlePlay", | ||||||
|       "outputFile": "app-googlePlayFlavor-release.apk" |       "outputFile": "app-googlePlayFlavor-release.apk" | ||||||
|     } |     } | ||||||
|   ] |   ], | ||||||
|  |   "elementType": "File" | ||||||
| } | } | ||||||
| @@ -1,11 +1,14 @@ | |||||||
| package com.jens.automation2; | package com.jens.automation2; | ||||||
|  |  | ||||||
| import android.annotation.SuppressLint; | import android.annotation.SuppressLint; | ||||||
|  | import android.app.Notification; | ||||||
| import android.bluetooth.BluetoothDevice; | import android.bluetooth.BluetoothDevice; | ||||||
| import android.content.Context; | import android.content.Context; | ||||||
| import android.os.AsyncTask; | import android.os.AsyncTask; | ||||||
| import android.os.Build; | import android.os.Build; | ||||||
|  | import android.os.Bundle; | ||||||
| import android.os.Looper; | import android.os.Looper; | ||||||
|  | import android.os.Parcelable; | ||||||
| import android.service.notification.StatusBarNotification; | import android.service.notification.StatusBarNotification; | ||||||
| import android.telephony.TelephonyManager; | import android.telephony.TelephonyManager; | ||||||
| import android.util.Log; | import android.util.Log; | ||||||
| @@ -34,6 +37,10 @@ import static com.jens.automation2.Trigger.triggerParameter2Split; | |||||||
| import static com.jens.automation2.receivers.NotificationListener.EXTRA_TEXT; | import static com.jens.automation2.receivers.NotificationListener.EXTRA_TEXT; | ||||||
| import static com.jens.automation2.receivers.NotificationListener.EXTRA_TITLE; | import static com.jens.automation2.receivers.NotificationListener.EXTRA_TITLE; | ||||||
|  |  | ||||||
|  | import androidx.core.app.NotificationCompat; | ||||||
|  |  | ||||||
|  | import org.apache.commons.lang3.StringUtils; | ||||||
|  |  | ||||||
|  |  | ||||||
| public class Rule implements Comparable<Rule> | public class Rule implements Comparable<Rule> | ||||||
| { | { | ||||||
| @@ -794,13 +801,13 @@ public class Rule implements Comparable<Rule> | |||||||
|  |  | ||||||
| 						String myApp = params[0]; | 						String myApp = params[0]; | ||||||
| 						String myTitleDir = params[1]; | 						String myTitleDir = params[1]; | ||||||
| 						String myTitle = params[2]; | 						String requiredTitle = params[2]; | ||||||
| 						String myTextDir = params[3]; | 						String myTextDir = params[3]; | ||||||
| 						String myText; | 						String requiredText; | ||||||
| 						if (params.length >= 5) | 						if (params.length >= 5) | ||||||
| 							myText = params[4]; | 							requiredText = params[4]; | ||||||
| 						else | 						else | ||||||
| 							myText = ""; | 							requiredText = ""; | ||||||
|  |  | ||||||
| 						if(oneTrigger.getTriggerParameter()) | 						if(oneTrigger.getTriggerParameter()) | ||||||
| 						{ | 						{ | ||||||
| @@ -812,38 +819,58 @@ public class Rule implements Comparable<Rule> | |||||||
| 							{ | 							{ | ||||||
| 								if(getLastExecution() == null || sbn.getPostTime() > this.lastExecution.getTimeInMillis()) | 								if(getLastExecution() == null || sbn.getPostTime() > this.lastExecution.getTimeInMillis()) | ||||||
| 								{ | 								{ | ||||||
| 									String app = sbn.getPackageName(); | 									String notificationApp = sbn.getPackageName(); | ||||||
| 									String title = sbn.getNotification().extras.getString(EXTRA_TITLE); | 									String notificationTitle = null; | ||||||
| 									String text = sbn.getNotification().extras.getString(EXTRA_TEXT); | 									String notificationText = null; | ||||||
|  |  | ||||||
| 									Miscellaneous.logEvent("i", "NotificationCheck", "Checking if this notification matches our rule " + this.getName() + ". App: " + app + ", title: " + title + ", text: " + text, 5); | 									Miscellaneous.logEvent("i", "NotificationCheck", "Checking if this notification matches our rule " + this.getName() + ". App: " + notificationApp + ", title: " + notificationTitle + ", text: " + notificationText, 5); | ||||||
|  |  | ||||||
| 									if (!myApp.equals("-1")) | 									if (!myApp.equals("-1")) | ||||||
| 									{ | 									{ | ||||||
| 										if (!app.equalsIgnoreCase(myApp)) | 										if (!notificationApp.equalsIgnoreCase(myApp)) | ||||||
| 										{ | 										{ | ||||||
| 											Miscellaneous.logEvent("i", "NotificationCheck", "Notification app name does not match rule.", 5); | 											Miscellaneous.logEvent("i", "NotificationCheck", "Notification app name does not match rule.", 5); | ||||||
| 											continue; | 											continue; | ||||||
| 										} | 										} | ||||||
| 									} | 									} | ||||||
|  |  | ||||||
| 									if (myTitle.length() > 0) | 									/* | ||||||
|  | 										If there are multiple notifications ("stacked") title or text might be null: | ||||||
|  | 										https://stackoverflow.com/questions/28047767/notificationlistenerservice-not-reading-text-of-stacked-notifications | ||||||
|  | 									 */ | ||||||
|  |  | ||||||
|  | 									Bundle extras = sbn.getNotification().extras; | ||||||
|  |  | ||||||
|  | 									// T I T L E | ||||||
|  | 									if (extras.containsKey(EXTRA_TITLE)) | ||||||
|  | 										notificationTitle = sbn.getNotification().extras.getString(EXTRA_TITLE); | ||||||
|  |  | ||||||
|  | 									if (!StringUtils.isEmpty(requiredTitle)) | ||||||
| 									{ | 									{ | ||||||
| 										if (!Miscellaneous.compare(myTitleDir, myTitle, title)) | 										if (!Miscellaneous.compare(myTitleDir, requiredTitle, notificationTitle)) | ||||||
| 										{ | 										{ | ||||||
| 											Miscellaneous.logEvent("i", "NotificationCheck", "Notification title does not match rule.", 5); | 											Miscellaneous.logEvent("i", "NotificationCheck", "Notification title does not match rule.", 5); | ||||||
| 											continue; | 											continue; | ||||||
| 										} | 										} | ||||||
| 									} | 									} | ||||||
|  | 									else | ||||||
|  | 										Miscellaneous.logEvent("i", "NotificationCheck", "A required title for a notification trigger was not specified.", 5); | ||||||
|  |  | ||||||
| 									if (myText.length() > 0) | 									// T E X T | ||||||
|  |  | ||||||
|  | 									if (extras.containsKey(EXTRA_TEXT)) | ||||||
|  | 										notificationText = sbn.getNotification().extras.getString(EXTRA_TEXT); | ||||||
|  |  | ||||||
|  | 									if (!StringUtils.isEmpty(requiredText)) | ||||||
| 									{ | 									{ | ||||||
| 										if (!Miscellaneous.compare(myTextDir, myText, text)) | 										if (!Miscellaneous.compare(myTextDir, requiredText, notificationText)) | ||||||
| 										{ | 										{ | ||||||
| 											Miscellaneous.logEvent("i", "NotificationCheck", "Notification text does not match rule.", 5); | 											Miscellaneous.logEvent("i", "NotificationCheck", "Notification text does not match rule.", 5); | ||||||
| 											continue; | 											continue; | ||||||
| 										} | 										} | ||||||
| 									} | 									} | ||||||
|  | 									else | ||||||
|  | 										Miscellaneous.logEvent("i", "NotificationCheck", "A required text for a notification trigger was not specified.", 5); | ||||||
|  |  | ||||||
| 									foundMatch = true; | 									foundMatch = true; | ||||||
| 									break; | 									break; | ||||||
| @@ -871,15 +898,15 @@ public class Rule implements Comparable<Rule> | |||||||
| 											return false; | 											return false; | ||||||
| 									} | 									} | ||||||
|  |  | ||||||
| 									if (myTitle.length() > 0) | 									if (requiredTitle.length() > 0) | ||||||
| 									{ | 									{ | ||||||
| 										if (!Miscellaneous.compare(myTitleDir, title, myTitle)) | 										if (!Miscellaneous.compare(myTitleDir, title, requiredTitle)) | ||||||
| 											return false; | 											return false; | ||||||
| 									} | 									} | ||||||
|  |  | ||||||
| 									if (myText.length() > 0) | 									if (requiredText.length() > 0) | ||||||
| 									{ | 									{ | ||||||
| 										if (!Miscellaneous.compare(myTextDir, text, myText)) | 										if (!Miscellaneous.compare(myTextDir, text, requiredText)) | ||||||
| 											return false; | 											return false; | ||||||
| 									} | 									} | ||||||
| 								} | 								} | ||||||
|   | |||||||
| @@ -225,6 +225,19 @@ public class Rule implements Comparable<Rule> | |||||||
| 		return XmlFileInterface.writeFile(); | 		return XmlFileInterface.writeFile(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	public boolean cloneRule(Context context) | ||||||
|  | 	{ | ||||||
|  | 		Rule newRule = new Rule(); | ||||||
|  | 		newRule.setName(this.getName() + " - clone"); | ||||||
|  | 		newRule.setRuleActive(this.isRuleActive()); | ||||||
|  | 		newRule.setRuleToggle(this.isRuleToggle()); | ||||||
|  |  | ||||||
|  | 		newRule.setTriggerSet(this.getTriggerSet()); | ||||||
|  | 		newRule.setActionSet(this.getActionSet()); | ||||||
|  |  | ||||||
|  | 		return newRule.create(context); | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
| 	private boolean checkBeforeSaving(Context context, boolean changeExistingRule) | 	private boolean checkBeforeSaving(Context context, boolean changeExistingRule) | ||||||
| 	{ | 	{ | ||||||
| 		if(this.getName() == null || this.getName().length()==0) | 		if(this.getName() == null || this.getName().length()==0) | ||||||
|   | |||||||
| @@ -88,13 +88,12 @@ public class ActivityManageRule extends Activity | |||||||
| 	final static int requestCodeActionStartActivityEdit = 3001; | 	final static int requestCodeActionStartActivityEdit = 3001; | ||||||
| 	final static int requestCodeTriggerNfcTagAdd = 4000; | 	final static int requestCodeTriggerNfcTagAdd = 4000; | ||||||
| 	final static int requestCodeTriggerNfcTagEdit = 4001; | 	final static int requestCodeTriggerNfcTagEdit = 4001; | ||||||
| 	final static int requestCodeActionSpeakTextAdd = 5000; | 	final static int requestCodeActionSpeakTextAdd = 5101; | ||||||
| 	final static int requestCodeActionSpeakTextEdit = 1001; | 	final static int requestCodeActionSpeakTextEdit = 5102; | ||||||
| 	final static int requestCodeTriggerBluetoothAdd = 6000; | 	final static int requestCodeTriggerBluetoothAdd = 6000; | ||||||
| 	final static int requestCodeTriggerBluetoothEdit = 6001; | 	final static int requestCodeTriggerBluetoothEdit = 6001; | ||||||
| 	final static int requestCodeActionScreenBrightnessAdd = 401; | 	final static int requestCodeActionScreenBrightnessAdd = 401; | ||||||
| 	final static int requestCodeActionScreenBrightnessEdit = 402; | 	final static int requestCodeActionScreenBrightnessEdit = 402; | ||||||
| 	final static int requestCodeActionSendTextMessage = 7001; |  | ||||||
| 	final static int requestCodeTriggerNotificationAdd = 8000; | 	final static int requestCodeTriggerNotificationAdd = 8000; | ||||||
| 	final static int requestCodeTriggerNfcNotificationEdit = 8001; | 	final static int requestCodeTriggerNfcNotificationEdit = 8001; | ||||||
| 	final static int requestCodeActionPlaySoundAdd = 501; | 	final static int requestCodeActionPlaySoundAdd = 501; | ||||||
| @@ -104,6 +103,7 @@ public class ActivityManageRule extends Activity | |||||||
| 	final static int requestCodeTriggerWifiAdd = 723; | 	final static int requestCodeTriggerWifiAdd = 723; | ||||||
| 	final static int requestCodeTriggerWifiEdit = 724; | 	final static int requestCodeTriggerWifiEdit = 724; | ||||||
| 	final static int requestCodeActionSendTextMessageAdd = 5001; | 	final static int requestCodeActionSendTextMessageAdd = 5001; | ||||||
|  | 	final static int requestCodeActionSendTextMessageEdit = 5002; | ||||||
| 	final static int requestCodeActionVibrateAdd = 801; | 	final static int requestCodeActionVibrateAdd = 801; | ||||||
| 	final static int requestCodeActionVibrateEdit = 802; | 	final static int requestCodeActionVibrateEdit = 802; | ||||||
| 	 | 	 | ||||||
| @@ -315,7 +315,7 @@ public class ActivityManageRule extends Activity | |||||||
| 						Intent activitySendTextMessageIntent = new Intent(ActivityManageRule.this, ActivityManageActionSendTextMessage.class); | 						Intent activitySendTextMessageIntent = new Intent(ActivityManageRule.this, ActivityManageActionSendTextMessage.class); | ||||||
| 						ActivityManageActionSendTextMessage.resultingAction = a; | 						ActivityManageActionSendTextMessage.resultingAction = a; | ||||||
| 						activitySendTextMessageIntent.putExtra("edit", true); | 						activitySendTextMessageIntent.putExtra("edit", true); | ||||||
| 						startActivityForResult(activitySendTextMessageIntent, requestCodeActionSendTextMessage); | 						startActivityForResult(activitySendTextMessageIntent, requestCodeActionSendTextMessageEdit); | ||||||
| 						break; | 						break; | ||||||
| 					case setScreenBrightness: | 					case setScreenBrightness: | ||||||
| 						Intent activityEditScreenBrightnessIntent = new Intent(ActivityManageRule.this, ActivityManageActionBrightnessSetting.class); | 						Intent activityEditScreenBrightnessIntent = new Intent(ActivityManageRule.this, ActivityManageActionBrightnessSetting.class); | ||||||
| @@ -1224,8 +1224,8 @@ public class ActivityManageRule extends Activity | |||||||
| 		{ | 		{ | ||||||
| 			if(resultCode == RESULT_OK) | 			if(resultCode == RESULT_OK) | ||||||
| 			{ | 			{ | ||||||
| 				//add SpeakText | 				//edit SpeakText | ||||||
| 				ruleToEdit.getActionSet().add(ActivityManageActionSendTextMessage.resultingAction); | 				newAction = ActivityManageActionSpeakText.resultingAction; | ||||||
| 				this.refreshActionList(); | 				this.refreshActionList(); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| @@ -1315,17 +1315,25 @@ public class ActivityManageRule extends Activity | |||||||
| 				this.refreshActionList(); | 				this.refreshActionList(); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  | 		else if(requestCode == requestCodeActionSendTextMessageAdd) | ||||||
| 		//TODO: Check with has data been changed or something like that. |  | ||||||
| 		/*try |  | ||||||
| 		{ | 		{ | ||||||
| 			Miscellaneous.logEvent("i", "ActivityManageSpecificRule", getResources().getString(R.string.noDataChangedReadingAnyway), 4); | 			if(resultCode == RESULT_OK) | ||||||
| 			XmlFileInterface.readFile(); | 			{ | ||||||
|  | 				//add SendTextMessage | ||||||
|  | 				ruleToEdit.getActionSet().add(ActivityManageActionSendTextMessage.resultingAction); | ||||||
|  | 				this.refreshActionList(); | ||||||
| 			} | 			} | ||||||
| 		catch (FileNotFoundException e) | 		} | ||||||
|  | 		else if(requestCode == requestCodeActionSendTextMessageEdit) | ||||||
| 		{ | 		{ | ||||||
| 			Miscellaneous.logEvent("e", "ActivityManageSpecificRule", getResources().getString(R.string.errorReadingPoisAndRulesFromFile) + ": " + Log.getStackTraceString(e), 5); | 			if(resultCode == RESULT_OK) | ||||||
| 		}*/ | 			{ | ||||||
|  | 				//edit SendTextMessage | ||||||
|  | 				newAction = ActivityManageActionSendTextMessage.resultingAction; | ||||||
|  | 				//ruleToEdit.getActionSet().add(ActivityManageActionSendTextMessage.resultingAction); | ||||||
|  | 				this.refreshActionList(); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	protected Dialog getActionTypeDialog() | 	protected Dialog getActionTypeDialog() | ||||||
|   | |||||||
| @@ -7,9 +7,12 @@ import android.content.Context; | |||||||
| import android.content.DialogInterface; | import android.content.DialogInterface; | ||||||
| import android.content.Intent; | import android.content.Intent; | ||||||
| import android.content.pm.PackageManager; | import android.content.pm.PackageManager; | ||||||
|  | import android.net.wifi.ScanResult; | ||||||
| import android.net.wifi.WifiConfiguration; | import android.net.wifi.WifiConfiguration; | ||||||
| import android.net.wifi.WifiManager; | import android.net.wifi.WifiManager; | ||||||
|  | import android.os.Build; | ||||||
| import android.os.Bundle; | import android.os.Bundle; | ||||||
|  | import android.util.Log; | ||||||
| import android.view.View; | import android.view.View; | ||||||
| import android.widget.AdapterView; | import android.widget.AdapterView; | ||||||
| import android.widget.ArrayAdapter; | import android.widget.ArrayAdapter; | ||||||
| @@ -55,6 +58,7 @@ public class ActivityManageTriggerWifi extends Activity | |||||||
|  |  | ||||||
|         wifiSpinnerAdapter = new ArrayAdapter<String>(this, R.layout.text_view_for_poi_listview_mediumtextsize, wifiList); |         wifiSpinnerAdapter = new ArrayAdapter<String>(this, R.layout.text_view_for_poi_listview_mediumtextsize, wifiList); | ||||||
|         spinnerWifiList.setAdapter(wifiSpinnerAdapter); |         spinnerWifiList.setAdapter(wifiSpinnerAdapter); | ||||||
|  |         spinnerWifiList.setEnabled(false);  // bug in Android; this only works when done in code, not in xml | ||||||
|  |  | ||||||
|         if (getIntent().hasExtra("edit")) |         if (getIntent().hasExtra("edit")) | ||||||
|         { |         { | ||||||
| @@ -127,13 +131,21 @@ public class ActivityManageTriggerWifi extends Activity | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     void reallyLoadWifiList() |     void reallyLoadWifiList() | ||||||
|  |     { | ||||||
|  |         if(Build.VERSION.SDK_INT >= 30) | ||||||
|  |         { | ||||||
|  |             Miscellaneous.messageBox(getResources().getString(R.string.hint), getResources().getString(R.string.wifiApi30), ActivityManageTriggerWifi.this).show(); | ||||||
|  |             loadListOfVisibleWifis(); | ||||||
|  |         } | ||||||
|  |         else | ||||||
|         { |         { | ||||||
|             WifiManager myWifiManager = (WifiManager) getApplicationContext().getSystemService(Context.WIFI_SERVICE); |             WifiManager myWifiManager = (WifiManager) getApplicationContext().getSystemService(Context.WIFI_SERVICE); | ||||||
|  |  | ||||||
|             for (WifiConfiguration wifi : myWifiManager.getConfiguredNetworks()) |             for (WifiConfiguration wifi : myWifiManager.getConfiguredNetworks()) | ||||||
|                 wifiList.add(wifi.SSID.replaceAll("\"+$", "").replaceAll("^\"+", "")); |                 wifiList.add(wifi.SSID.replaceAll("\"+$", "").replaceAll("^\"+", "")); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         if(wifiList.size() > 0) |         if (wifiList.size() > 0) | ||||||
|         { |         { | ||||||
|             spinnerWifiList.setEnabled(true); |             spinnerWifiList.setEnabled(true); | ||||||
|             Collections.sort(wifiList); |             Collections.sort(wifiList); | ||||||
| @@ -147,6 +159,24 @@ public class ActivityManageTriggerWifi extends Activity | |||||||
|         wifiSpinnerAdapter.notifyDataSetChanged(); |         wifiSpinnerAdapter.notifyDataSetChanged(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     void loadListOfVisibleWifis() | ||||||
|  |     { | ||||||
|  |         List<ScanResult> results = null; | ||||||
|  |  | ||||||
|  |         try | ||||||
|  |         { | ||||||
|  |             WifiManager wifiManager = (WifiManager) getApplicationContext().getSystemService(WIFI_SERVICE); | ||||||
|  |             results = wifiManager.getScanResults(); | ||||||
|  |  | ||||||
|  |             for (ScanResult wifi : results) | ||||||
|  |                 wifiList.add(wifi.SSID.replaceAll("\"+$", "").replaceAll("^\"+", "")); | ||||||
|  |         } | ||||||
|  |         catch(Exception e) | ||||||
|  |         { | ||||||
|  |             Miscellaneous.logEvent("e", "loadListOfVisibleWifis()", Log.getStackTraceString(e), 1); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) |     public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) | ||||||
|     { |     { | ||||||
|   | |||||||
| @@ -447,6 +447,14 @@ public class Miscellaneous extends Service | |||||||
|  |  | ||||||
| 	public static boolean compare(String direction, String needle, String haystack) | 	public static boolean compare(String direction, String needle, String haystack) | ||||||
| 	{ | 	{ | ||||||
|  | 		// If only one of needle or haystack is null | ||||||
|  | 		if( | ||||||
|  | 				(needle == null && haystack != null) | ||||||
|  | 					|| | ||||||
|  | 				(needle != null && haystack == null) | ||||||
|  | 		) | ||||||
|  | 			return false; | ||||||
|  |  | ||||||
| 		switch(direction) | 		switch(direction) | ||||||
| 		{ | 		{ | ||||||
| 			case Trigger.directionEquals: | 			case Trigger.directionEquals: | ||||||
|   | |||||||
| @@ -244,7 +244,7 @@ | |||||||
|     <string name="volumeRingtoneNotifications">Sonido polifónico ý notificaciónes</string> |     <string name="volumeRingtoneNotifications">Sonido polifónico ý notificaciónes</string> | ||||||
|     <string name="notificationRingtone">Sonido polifónico para notificaciónes</string> |     <string name="notificationRingtone">Sonido polifónico para notificaciónes</string> | ||||||
|     <string name="incomingCallsRingtone">Sonido de llamadas</string> |     <string name="incomingCallsRingtone">Sonido de llamadas</string> | ||||||
|     <string name="batteryLevel">NIvel de la bateria</string> |     <string name="batteryLevel">Nivel de la bateria</string> | ||||||
|     <string name="selectBattery">Elija nivel de la bateria</string> |     <string name="selectBattery">Elija nivel de la bateria</string> | ||||||
|     <string name="triggerNoiseLevel">Nivel del ruido fondo</string> |     <string name="triggerNoiseLevel">Nivel del ruido fondo</string> | ||||||
|     <string name="anotherAppIsRunning">Otra app esta encendida/terminada</string> |     <string name="anotherAppIsRunning">Otra app esta encendida/terminada</string> | ||||||
| @@ -591,6 +591,6 @@ | |||||||
|     <string name="pleaseEnterValidVibrationPattern">Por favor introduzca un patrón de vibración válido.</string> |     <string name="pleaseEnterValidVibrationPattern">Por favor introduzca un patrón de vibración válido.</string> | ||||||
|     <string name="tabsPlacementSummary">Elija done la barra de tabs está puesto.</string> |     <string name="tabsPlacementSummary">Elija done la barra de tabs está puesto.</string> | ||||||
|     <string name="intentDataComment">Si su parametro es de tipo Uri y especifica \"IntentData\" como nombre (minúscula/mayáscula no es importante), el parametro no está añadido como un parametro normal con puExtra(), pero estará añadido al intent con setData().</string> |     <string name="intentDataComment">Si su parametro es de tipo Uri y especifica \"IntentData\" como nombre (minúscula/mayáscula no es importante), el parametro no está añadido como un parametro normal con puExtra(), pero estará añadido al intent con setData().</string> | ||||||
|     <string name="locationEngineDisabledLong">Desafortunadamente su posición todavia no puede ser determinada. Gratitud va para Google por su sabiduria y amabilidad infinita.\n\nDejenme explicarselo mas. Comenzando con Android 10 un nuevo permiso se introdujo que es necesario para determinar la posición en el fondo (que es necesario para una app como esta). Aunque lo considero una buena idea, conlleva a una chicana para desarolladores.\n\nCuando se esta desarrollando una app se puede intentar calificar para este permiso mientras se sigue un catalogo de condiciones. Desafortunadamente nuevas versiones de mi app fueron rechazadas por un periodo de trés meses. Cumplé todas las condiciones, pero Google's mierda servicio para desarolladores afirmó que no. Despues de presentar pruebas, que cumplí con todo, recibí una respuesta de "No puedo ayudarte mas.". En algun momento me rendí.\n\nComo consecuencia la version Google Play todavia no sabe usar la locación como una condición. Mi única alternativa fue remover la applicación de Google Play.\n\nLo siento mucho, pero hicé todo lo posible para discutir con un support que no sabe aprobar la prueba de Turing repetidamente.\n\nLa noticia positiva: Usted todavia puede tener todo!\n\nAutomation ahora es open source y se puede encontrar en F-Droid. Es un app store que se preocupa por su privacidad - en vez de solo simular eso. Simplemente guarde su configuración, desinstale la app, instale la de F-Droid, restaure su configuración - terminado.\n\nCliquee aqui para averiguar más:</string> |     <string name="locationEngineDisabledLong">Desafortunadamente su posición todavia no puede ser determinada. Gratitud va para Google por su sabiduria y amabilidad infinita.\n\nDejenme explicarselo mas. Comenzando con Android 10 un nuevo permiso se introdujo que es necesario para determinar la posición en el fondo (que es necesario para una app como esta). Aunque lo considero una buena idea, conlleva a una chicana para desarolladores.\n\nCuando se esta desarrollando una app se puede intentar calificar para este permiso mientras se sigue un catalogo de condiciones. Desafortunadamente nuevas versiones de mi app fueron rechazadas por un periodo de trés meses. Cumplé todas las condiciones, pero Google\'s mierda servicio para desarolladores afirmó que no. Despues de presentar pruebas, que cumplí con todo, recibí una respuesta de \"No puedo ayudarte mas.\". En algun momento me rendí.\n\nComo consecuencia la version Google Play todavia no sabe usar la locación como una condición. Mi única alternativa fue remover la applicación de Google Play.\n\nLo siento mucho, pero hicé todo lo posible para discutir con un support que no sabe aprobar la prueba de Turing repetidamente.\n\nLa noticia positiva: Usted todavia puede tener todo!\n\nAutomation ahora es open source y se puede encontrar en F-Droid. Es un app store que se preocupa por su privacidad - en vez de solo simular eso. Simplemente guarde su configuración, desinstale la app, instale la de F-Droid, restaure su configuración - terminado.\n\nCliquee aqui para averiguar más:</string> | ||||||
|     <string name="startAppChoiceNote">Aqui tiene 2 opciones generales:\\n\\n1. Puede encender un programa seleccionando un activity. Imagine eso como preseleccionar una pantalla/ventana especifica de una aplicación. Tenga en cuenta que no siempre funcionará. Eso es porque las ventanas de una app pueden interactuar entre ellas, por ejemplo dar parametros. Si se abre una ventana especifica directamente esta interacción todavia no ha ocurrido y la ventana se podría cerrar al instante (por lo tanto nunca será presentada). Pruebe esto sin embargo! Puede introducir una trayectoria de una activity manualmente, pero es recomendable usar el boton \"Elegir\". Si decide introducir la trayectoria de la app manualmente en la casilla de arriba y la trayectoria completa de una activity en la de abajo.\\n\\n2.Elección con action\\nContrariamente a elegir una ventana especifica, tambien puede encender una app con un action. Es similar a llamar \"Queria xyz\" y si hay una app que le puede ayudar a usted sera encendida. Un ejemplo bueno seria \"abrir browser\" - podria tener multiples (una normalemente es el valor predeterminado). Usted necesita introducirlo manualmente, PackageName es opcional aqui. Tenga en cuenta las variables no seran resueltas. Si por ejemplo quiere encender la camara usando \"MediaStore.ACTION_IMAGE_CAPTURE\" no va a funcionar. Tiene que mirar en la documentación de Android y usar el valor real de esta variable que - en este ejemplo - seria \"android.media.action.IMAGE_CAPTURE\".</string> |     <string name="startAppChoiceNote">Aqui tiene 2 opciones generales:\\n\\n1. Puede encender un programa seleccionando un activity. Imagine eso como preseleccionar una pantalla/ventana especifica de una aplicación. Tenga en cuenta que no siempre funcionará. Eso es porque las ventanas de una app pueden interactuar entre ellas, por ejemplo dar parametros. Si se abre una ventana especifica directamente esta interacción todavia no ha ocurrido y la ventana se podría cerrar al instante (por lo tanto nunca será presentada). Pruebe esto sin embargo! Puede introducir una trayectoria de una activity manualmente, pero es recomendable usar el boton \"Elegir\". Si decide introducir la trayectoria de la app manualmente en la casilla de arriba y la trayectoria completa de una activity en la de abajo.\\n\\n2.Elección con action\\nContrariamente a elegir una ventana especifica, tambien puede encender una app con un action. Es similar a llamar \"Queria xyz\" y si hay una app que le puede ayudar a usted sera encendida. Un ejemplo bueno seria \"abrir browser\" - podria tener multiples (una normalemente es el valor predeterminado). Usted necesita introducirlo manualmente, PackageName es opcional aqui. Tenga en cuenta las variables no seran resueltas. Si por ejemplo quiere encender la camara usando \"MediaStore.ACTION_IMAGE_CAPTURE\" no va a funcionar. Tiene que mirar en la documentación de Android y usar el valor real de esta variable que - en este ejemplo - seria \"android.media.action.IMAGE_CAPTURE\".</string> | ||||||
| </resources> | </resources> | ||||||
| @@ -670,7 +670,7 @@ | |||||||
|     <string name="matching">matching</string> |     <string name="matching">matching</string> | ||||||
|     <string name="urlRegex" translatable="false">https://regex101.com/</string> |     <string name="urlRegex" translatable="false">https://regex101.com/</string> | ||||||
|     <string name="loadWifiList">Load wifi list</string> |     <string name="loadWifiList">Load wifi list</string> | ||||||
|     <string name="needLocationPermForWifiList">The list of wifis your device has been connected to could be used to determine which places you have been to. That\'s why the location permission is required to load the list of wifis. If you want to be able to pick one from the list you need to grant that permission. If not you can still enter your wifi name manually.</string> |     <string name="needLocationPermForWifiList">The list of wifis your device has been connected to could be used to determine which places you have been to. That\'s why the location permission is required to load the list of wifis. If you want to be able to pick one from the list you need to grant that permission. If you do not want that, you can still enter your wifi name manually.</string> | ||||||
|     <string name="noKnownWifis">There are no known wifis on your device.</string> |     <string name="noKnownWifis">There are no known wifis on your device.</string> | ||||||
|     <string name="urlToTriggerExplanation">This feature does NOT open a browser, but triggers a URL in the background. You can use this e.g. to send commands to your home automation.</string> |     <string name="urlToTriggerExplanation">This feature does NOT open a browser, but triggers a URL in the background. You can use this e.g. to send commands to your home automation.</string> | ||||||
|     <string name="automaticUpdateCheck">Check for updates</string> |     <string name="automaticUpdateCheck">Check for updates</string> | ||||||
| @@ -690,4 +690,5 @@ | |||||||
|     <string name="bottom">Bottom</string> |     <string name="bottom">Bottom</string> | ||||||
|     <string name="tabsPlacement">Position of tab bar</string> |     <string name="tabsPlacement">Position of tab bar</string> | ||||||
|     <string name="tabsPlacementSummary">Choose where the tabs bar should be placed.</string> |     <string name="tabsPlacementSummary">Choose where the tabs bar should be placed.</string> | ||||||
|  |     <string name="wifiApi30">Because Google screwd up yet another part of Android, starting with API 30 only the currently visible wifis can be displayed. Not all the ones your device knows.</string> | ||||||
| </resources> | </resources> | ||||||
| @@ -1,5 +1,6 @@ | |||||||
| <network-security-config> | <network-security-config> | ||||||
|     <base-config> |     <base-config | ||||||
|  |         cleartextTrafficPermitted="true"> | ||||||
|         <trust-anchors> |         <trust-anchors> | ||||||
|             <!-- Trust preinstalled CAs --> |             <!-- Trust preinstalled CAs --> | ||||||
|             <certificates src="system" /> |             <certificates src="system" /> | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ buildscript { | |||||||
|         jcenter() |         jcenter() | ||||||
|     } |     } | ||||||
|     dependencies { |     dependencies { | ||||||
|         classpath 'com.android.tools.build:gradle:4.2.2' |         classpath 'com.android.tools.build:gradle:7.0.2' | ||||||
|  |  | ||||||
|         // NOTE: Do not place your application dependencies here; they belong |         // NOTE: Do not place your application dependencies here; they belong | ||||||
|         // in the individual module build.gradle files |         // in the individual module build.gradle files | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								fastlane/metadata/android/de-DE/changelogs/109.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								fastlane/metadata/android/de-DE/changelogs/109.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | * Klartext HTTP Datenverkehr für URL-Auslösen-Aktionen ermöglicht. | ||||||
							
								
								
									
										1
									
								
								fastlane/metadata/android/de-DE/changelogs/110.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								fastlane/metadata/android/de-DE/changelogs/110.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | * HTTP Klartext wieder entfernt, hat nicht kompiliert. | ||||||
							
								
								
									
										1
									
								
								fastlane/metadata/android/de-DE/changelogs/111.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								fastlane/metadata/android/de-DE/changelogs/111.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | * Klartext HTTP Datenverkehr für URL-Auslösen-Aktionen ermöglicht. | ||||||
							
								
								
									
										4
									
								
								fastlane/metadata/android/de-DE/changelogs/112.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								fastlane/metadata/android/de-DE/changelogs/112.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | * Fehler im Benachrichtigungsauslöser behoben | ||||||
|  | * WLAN Liste laden für API > 30 (soweit möglich) | ||||||
|  | * Fehler behoben beim Hinzufügen/Ändern der SMS-senden Aktion | ||||||
|  | * Fehler behoben beim Ändern der Text-sprechen Aktion | ||||||
| @@ -39,7 +39,7 @@ Mögliche Aktionen: | |||||||
| * SMS verschicken | * SMS verschicken | ||||||
| * Sounddatei abspielen. | * Sounddatei abspielen. | ||||||
|  |  | ||||||
| Es ist ziemlich schwierig diese Anwendung über die vielen verschiedenen Geräte sowie die vielen Änderungen an Android Versionen am Laufen zu halten. Ich kann vieles im Emulator testen, aber eben nicht alles. | Es ist ziemlich schwierig diese Anwendung über die vielen verschiedenen Geräte und Android Versionen am Laufen zu halten. Ich kann vieles im Emulator testen, aber eben nicht alles. | ||||||
| Wenn also eine bestimmte Funktion nicht so tut wie sie sollte - lassen Sie es mich wissen. Über die Jahre habe ich noch alle Fehler behoben, die mir vernünftig gemeldet wurden. Aber dafür bin ich auf Ihre Mithilfe angewiesen. | Wenn also eine bestimmte Funktion nicht so tut wie sie sollte - lassen Sie es mich wissen. Über die Jahre habe ich noch alle Fehler behoben, die mir vernünftig gemeldet wurden. Aber dafür bin ich auf Ihre Mithilfe angewiesen. | ||||||
|  |  | ||||||
| Wenn Sie ein Problem mit der Anwendung haben und mich dazu kontaktieren möchten, updaten Sie bitte vorher auf die neueste Version und schauen Sie, ob Ihr Problem darin auch besteht. | Wenn Sie ein Problem mit der Anwendung haben und mich dazu kontaktieren möchten, updaten Sie bitte vorher auf die neueste Version und schauen Sie, ob Ihr Problem darin auch besteht. | ||||||
|   | |||||||
| @@ -1 +1 @@ | |||||||
| Automatisieren Sie Dinge auf Ihrem Ger<EFBFBD>t, indem Sie Regeln anlegen. | Automatisieren Sie Dinge auf Ihrem Gerät, indem Sie Regeln anlegen. | ||||||
							
								
								
									
										4
									
								
								fastlane/metadata/android/en-US/changelogs/108.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								fastlane/metadata/android/en-US/changelogs/108.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | * Translations updated. | ||||||
|  | * New action: Vibrate | ||||||
|  | * Improved speed calculation | ||||||
|  | * Position of tab-bar can be chosen (top/bottom) | ||||||
							
								
								
									
										1
									
								
								fastlane/metadata/android/en-US/changelogs/109.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								fastlane/metadata/android/en-US/changelogs/109.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | * Allowed cleartext HTTP traffic for rules using triggerUrl action | ||||||
							
								
								
									
										1
									
								
								fastlane/metadata/android/en-US/changelogs/110.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								fastlane/metadata/android/en-US/changelogs/110.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | * Removed again, wouldn't compile. | ||||||
							
								
								
									
										1
									
								
								fastlane/metadata/android/en-US/changelogs/111.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								fastlane/metadata/android/en-US/changelogs/111.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | * Allowed cleartext HTTP traffic for rules using triggerUrl action | ||||||
							
								
								
									
										4
									
								
								fastlane/metadata/android/en-US/changelogs/112.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								fastlane/metadata/android/en-US/changelogs/112.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | * Fixed bug in notification trigger. | ||||||
|  | * Load wifi list for API > 30 (as far as possible) | ||||||
|  | * Fixed a bug when adding/editing sendTextMessage action | ||||||
|  | * Fixed a bug when editing speakText action | ||||||
							
								
								
									
										4
									
								
								fastlane/metadata/android/es-ES/112.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								fastlane/metadata/android/es-ES/112.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | * Error fijo en el gatillo de notificación. | ||||||
|  | * Lista de wifi de carga para API > 30 (en la medida de lo posible) | ||||||
|  | * Arregló un error al añadir/editar sendTextMessage acción | ||||||
|  | * Arregló un error al editar la acción de TalkText | ||||||
							
								
								
									
										1
									
								
								fastlane/metadata/android/es-ES/changelogs/111.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								fastlane/metadata/android/es-ES/changelogs/111.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | * Permitido texto claro HTTP tráfico para reglas usando el gatillo Acción urgente | ||||||
							
								
								
									
										1
									
								
								fastlane/metadata/android/it-IT/changelogs/111.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								fastlane/metadata/android/it-IT/changelogs/111.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | * Cleartext http traffico dati per le azioni di trigger URL abilitate. | ||||||
							
								
								
									
										4
									
								
								fastlane/metadata/android/it-IT/changelogs/112.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								fastlane/metadata/android/it-IT/changelogs/112.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | * Corretto bug nel trigger di notifica. | ||||||
|  | * Carica elenco wifi per API > 30 (per quanto possibile) | ||||||
|  | * Corretto un bug quando si aggiunge / modifica l'azione di sendTextMessage | ||||||
|  | * Corretto un bug quando si modifica l'azione del testo | ||||||
							
								
								
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							| @@ -3,4 +3,4 @@ distributionBase=GRADLE_USER_HOME | |||||||
| distributionPath=wrapper/dists | distributionPath=wrapper/dists | ||||||
| zipStoreBase=GRADLE_USER_HOME | zipStoreBase=GRADLE_USER_HOME | ||||||
| zipStorePath=wrapper/dists | zipStorePath=wrapper/dists | ||||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-6.7.1-bin.zip | distributionUrl=https\://services.gradle.org/distributions/gradle-7.0.2-bin.zip | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user