Compare commits
	
		
			6 Commits
		
	
	
		
			47898e84ea
			...
			a8646ef61d
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| a8646ef61d | |||
| f641de9893 | |||
| bca8b44ad6 | |||
| c34dfa4af4 | |||
| 38644cee28 | |||
| ac74b52aed | 
| @@ -261,6 +261,17 @@ | ||||
|             android:exported="true" | ||||
|             /> | ||||
|  | ||||
|         <service android:name=".MyAccessibilityService" | ||||
|             android:permission="android.permission.BIND_ACCESSIBILITY_SERVICE"> | ||||
|             <intent-filter> | ||||
|                 <action android:name="android.accessibilityservice.AccessibilityService" /> | ||||
|             </intent-filter> | ||||
|  | ||||
|             <meta-data | ||||
|                 android:name="android.accessibilityservice" | ||||
|                 android:resource="@xml/config_accessibility_service" /> | ||||
|         </service> | ||||
|  | ||||
|     </application> | ||||
|  | ||||
| </manifest> | ||||
| @@ -246,6 +246,17 @@ | ||||
|             android:exported="true" | ||||
|             /> | ||||
|  | ||||
|         <service android:name=".MyAccessibilityService" | ||||
|             android:permission="android.permission.BIND_ACCESSIBILITY_SERVICE"> | ||||
|             <intent-filter> | ||||
|                 <action android:name="android.accessibilityservice.AccessibilityService" /> | ||||
|             </intent-filter> | ||||
|  | ||||
|             <meta-data | ||||
|                 android:name="android.accessibilityservice" | ||||
|                 android:resource="@xml/config_accessibility_service" /> | ||||
|         </service> | ||||
|  | ||||
|     </application> | ||||
|  | ||||
| </manifest> | ||||
| @@ -245,6 +245,17 @@ | ||||
|             android:exported="true" | ||||
|             /> | ||||
|  | ||||
|         <service android:name=".MyAccessibilityService" | ||||
|             android:permission="android.permission.BIND_ACCESSIBILITY_SERVICE"> | ||||
|             <intent-filter> | ||||
|                 <action android:name="android.accessibilityservice.AccessibilityService" /> | ||||
|             </intent-filter> | ||||
|  | ||||
|             <meta-data | ||||
|                 android:name="android.accessibilityservice" | ||||
|                 android:resource="@xml/config_accessibility_service" /> | ||||
|         </service> | ||||
|  | ||||
|     </application> | ||||
|  | ||||
| </manifest> | ||||
| @@ -56,6 +56,7 @@ public class Action | ||||
| 		startPhoneCall, | ||||
| 		stopPhoneCall, | ||||
| 		copyToClipboard, | ||||
| 		takeScreenshot, | ||||
| 		sendTextMessage; | ||||
|  | ||||
| 		public String getFullName(Context context) | ||||
| @@ -140,6 +141,9 @@ public class Action | ||||
| 					return context.getResources().getString(R.string.endPhoneCall); | ||||
| 				case copyToClipboard: | ||||
| 					return context.getResources().getString(R.string.copyTextToClipboard); | ||||
| 				case takeScreenshot: | ||||
| 					return context.getResources().getString(R.string.takeScreenshot); | ||||
|  | ||||
| 				default: | ||||
| 					return "Unknown"; | ||||
| 			} | ||||
| @@ -307,6 +311,10 @@ public class Action | ||||
| 					break; | ||||
| 				case copyToClipboard: | ||||
| 					returnString.append(Miscellaneous.getAnyContext().getResources().getString(R.string.copyTextToClipboard)); | ||||
| 					break; | ||||
| 				case takeScreenshot: | ||||
| 					returnString.append(Miscellaneous.getAnyContext().getResources().getString(R.string.takeScreenshot)); | ||||
| 					break; | ||||
| 				default: | ||||
| 					returnString.append(action.toString()); | ||||
| 			} | ||||
| @@ -632,6 +640,9 @@ public class Action | ||||
| 				case copyToClipboard: | ||||
| 					Actions.copyToClipboard(context, Miscellaneous.replaceVariablesInText(this.getParameter2(), context)); | ||||
| 					break; | ||||
| 				case takeScreenshot: | ||||
| 					Actions.takeScreenshot(); | ||||
| 					break; | ||||
| 				default: | ||||
| 					Miscellaneous.logEvent("w", "Action", context.getResources().getString(R.string.unknownActionSpecified), 3); | ||||
| 					break; | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| package com.jens.automation2; | ||||
|  | ||||
| import android.Manifest; | ||||
| import android.accessibilityservice.AccessibilityService; | ||||
| import android.annotation.SuppressLint; | ||||
| import android.annotation.TargetApi; | ||||
| import android.app.NotificationManager; | ||||
| @@ -2286,14 +2287,18 @@ public class Actions | ||||
|  | ||||
| 	public static void startPhoneCall(Context context, String phoneNumber) | ||||
| 	{ | ||||
| 		Intent intent; | ||||
|  | ||||
| 		/* | ||||
| 			You can use Intent.ACTION_DIAL instead of Intent.ACTION_CALL. | ||||
| 			This shows the dialer with the number already entered, but | ||||
| 			allows the user to decide whether to actually make the call or not. | ||||
| 			ACTION_DIAL does not require the CALL_PHONE permission. | ||||
| 			Bug in Android 14 makes it necessary to add double quotes around MMI code. | ||||
| 			More precisely it's required for codes containing the # character. | ||||
| 		 */ | ||||
|  | ||||
| 		Intent intent = new Intent(Intent.ACTION_CALL, Uri.parse("tel:" + Uri.encode(phoneNumber))); | ||||
| 		if(Build.VERSION.SDK_INT >= 34) | ||||
| 			intent = new Intent(Intent.ACTION_CALL, Uri.parse("tel:" + Uri.encode("\"" + phoneNumber + "\""))); | ||||
| 		else | ||||
| 			intent = new Intent(Intent.ACTION_CALL, Uri.parse("tel:" + Uri.encode(phoneNumber))); | ||||
|  | ||||
| //			intent.setClassName("com.android.phone","com.android.phone.OutgoingCallBroadcaster"); | ||||
| 		intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); | ||||
| 		intent.addFlags(Intent.FLAG_FROM_BACKGROUND); | ||||
| @@ -2346,4 +2351,12 @@ public class Actions | ||||
| 			clipboard.setPrimaryClip(clip); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	public static void takeScreenshot() | ||||
| 	{ | ||||
| 		if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P) | ||||
| 		{ | ||||
| 			MyAccessibilityService.getInstance().performGlobalAction(AccessibilityService.GLOBAL_ACTION_TAKE_SCREENSHOT); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @@ -2126,6 +2126,8 @@ public class ActivityManageRule extends Activity | ||||
| 			} | ||||
| 			else if(types[i].toString().equals(Action_Enum.copyToClipboard.toString())) | ||||
| 				items.add(new Item(typesLong[i].toString(), R.drawable.clipboard)); | ||||
| 			else if(types[i].toString().equals(Action_Enum.takeScreenshot.toString())) | ||||
| 				items.add(new Item(typesLong[i].toString(), R.drawable.copier)); | ||||
| 			else | ||||
| 				items.add(new Item(typesLong[i].toString(), R.drawable.placeholder)); | ||||
| 		} | ||||
| @@ -2352,6 +2354,12 @@ public class ActivityManageRule extends Activity | ||||
| 						Intent intent = new Intent(ActivityManageRule.this, ActivityManageActionCopyToClipboard.class); | ||||
| 						startActivityForResult(intent, requestCodeActionCopyTextToClipboardAdd); | ||||
| 					} | ||||
| 					else if(Action.getActionTypesAsArray()[which].toString().equals(Action_Enum.takeScreenshot.toString())) | ||||
| 					{ | ||||
| 						newAction.setAction(Action_Enum.takeScreenshot); | ||||
| 						ruleToEdit.getActionSet().add(newAction); | ||||
| 						refreshActionList(); | ||||
| 					} | ||||
| 				} | ||||
| 			}); | ||||
|  | ||||
|   | ||||
| @@ -18,6 +18,7 @@ import android.os.Bundle; | ||||
| import android.os.PowerManager; | ||||
| import android.provider.Settings; | ||||
| import android.text.Html; | ||||
| import android.text.TextUtils; | ||||
| import android.util.Log; | ||||
| import android.view.View; | ||||
| import android.widget.Button; | ||||
| @@ -51,12 +52,13 @@ public class ActivityPermissions extends Activity | ||||
|     private static final int requestCodeForPermissionsBatteryOptimization = 12048; | ||||
|     private static final int requestCodeForPermissionNotificationAccessAndroid13 = 12049; | ||||
|     private static final int requestCodeForPermissionsManageOverlay = 12050; | ||||
|     private static final int requestCodeForPermissionsAccessibility = 12051; | ||||
|     protected String[] specificPermissionsToRequest = null; | ||||
|  | ||||
|     public static String intentExtraName = "permissionsToBeRequested"; | ||||
|  | ||||
|     Button bCancelPermissions, bRequestPermissions; | ||||
|     TextView tvPermissionsExplanation, tvPermissionsExplanationSystemSettings, tvPermissionsExplanationLong; | ||||
|     TextView tvPermissionsExplanation, tvPermissionsExplanationSystemSettings, tvPermissionsExplanationLong, tvRestrictionPermissionsNotice; | ||||
|     static ActivityPermissions instance = null; | ||||
|  | ||||
|     public final static String permissionNameWireguard = "com.wireguard.android.permission.CONTROL_TUNNELS"; | ||||
| @@ -87,6 +89,7 @@ public class ActivityPermissions extends Activity | ||||
|             tvPermissionsExplanation = (TextView)findViewById(R.id.tvPermissionsExplanation); | ||||
|             tvPermissionsExplanationSystemSettings = (TextView)findViewById(R.id.tvPermissionsExplanationSystemSettings); | ||||
|             tvPermissionsExplanationLong = (TextView)findViewById(R.id.tvPermissionsExplanationLong); | ||||
|             tvRestrictionPermissionsNotice = (TextView)findViewById(R.id.tvRestrictionPermissionsNotice); | ||||
|  | ||||
|             bCancelPermissions.setOnClickListener(new View.OnClickListener() | ||||
|             { | ||||
| @@ -305,6 +308,10 @@ public class ActivityPermissions extends Activity | ||||
|             { | ||||
|                 return android.provider.Settings.canDrawOverlays(Miscellaneous.getAnyContext()); | ||||
|             } | ||||
|             else if(s.equals(Manifest.permission.BIND_ACCESSIBILITY_SERVICE)) | ||||
|             { | ||||
|                 return haveAccessibilityAccess(Miscellaneous.getAnyContext()); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 int res = context.checkCallingOrSelfPermission(s); | ||||
| @@ -323,11 +330,59 @@ public class ActivityPermissions extends Activity | ||||
|         return active; | ||||
|     } | ||||
|  | ||||
|     public static boolean haveAccessibilityAccess(Context mContext) | ||||
|     { | ||||
|         int accessibilityEnabled = 0; | ||||
|  | ||||
|         final String service = mContext.getPackageName() + "/" + BuildConfig.APPLICATION_ID + ".MyAccessibilityService"; | ||||
|  | ||||
|         boolean accessibilityFound = false; | ||||
|         try | ||||
|         { | ||||
|             accessibilityEnabled = Settings.Secure.getInt(mContext.getApplicationContext().getContentResolver(), Settings.Secure.ACCESSIBILITY_ENABLED); | ||||
| //            Log.v(TAG, "accessibilityEnabled = " + accessibilityEnabled); | ||||
|         } | ||||
|         catch (Settings.SettingNotFoundException e) | ||||
|         { | ||||
| //            Log.e(TAG, "Error finding setting, default accessibility to not found: " + e.getMessage()); | ||||
|         } | ||||
|         TextUtils.SimpleStringSplitter mStringColonSplitter = new TextUtils.SimpleStringSplitter(':'); | ||||
|  | ||||
|         if (accessibilityEnabled == 1) | ||||
|         { | ||||
|             String settingValue = Settings.Secure.getString(mContext.getApplicationContext().getContentResolver(), Settings.Secure.ENABLED_ACCESSIBILITY_SERVICES); | ||||
|             if (settingValue != null) | ||||
|             { | ||||
|                 TextUtils.SimpleStringSplitter splitter = mStringColonSplitter; | ||||
|                 splitter.setString(settingValue); | ||||
|                 while (splitter.hasNext()) | ||||
|                 { | ||||
|                     String accessibilityService = splitter.next(); | ||||
|  | ||||
|                     if (accessibilityService.equalsIgnoreCase(service)) | ||||
|                     { | ||||
|                         return true; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return accessibilityFound; | ||||
|     } | ||||
|  | ||||
|     public static void requestOverlay() | ||||
|     { | ||||
|         Intent intent = new Intent(android.provider.Settings.ACTION_MANAGE_OVERLAY_PERMISSION); | ||||
|         ActivityPermissions.getInstance().startActivityForResult(intent, requestCodeForPermissionsManageOverlay); | ||||
|     } | ||||
|  | ||||
|     public static void requestBindAccessibilityService() | ||||
|     { | ||||
|         Intent intent = new Intent(Settings.ACTION_ACCESSIBILITY_SETTINGS); | ||||
|         intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); | ||||
|         ActivityPermissions.getInstance().startActivityForResult(intent, requestCodeForPermissionsAccessibility); | ||||
|     } | ||||
|  | ||||
|     public static void requestDeviceAdmin() | ||||
|     { | ||||
|         if(!haveDeviceAdmin()) | ||||
| @@ -370,10 +425,13 @@ public class ActivityPermissions extends Activity | ||||
|             if(!havePermission(Manifest.permission.REQUEST_IGNORE_BATTERY_OPTIMIZATIONS, workingContext)) | ||||
|                 addToArrayListUnique(Manifest.permission.REQUEST_IGNORE_BATTERY_OPTIMIZATIONS, requiredPermissions); | ||||
|  | ||||
|             for(Profile p : Profile.getProfileCollection()) | ||||
|             if(!havePermission(Manifest.permission.READ_EXTERNAL_STORAGE, workingContext)) | ||||
|             { | ||||
|                 if(p.changeIncomingCallsRingtone || p.changeNotificationRingtone) | ||||
|                     addToArrayListUnique(Manifest.permission.READ_EXTERNAL_STORAGE, requiredPermissions); | ||||
|                 for (Profile p : Profile.getProfileCollection()) | ||||
|                 { | ||||
|                     if (p.changeIncomingCallsRingtone || p.changeNotificationRingtone) | ||||
|                         addToArrayListUnique(Manifest.permission.READ_EXTERNAL_STORAGE, requiredPermissions); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             if (!onlyGeneral) | ||||
| @@ -407,27 +465,6 @@ public class ActivityPermissions extends Activity | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|           /* | ||||
|             Not all permissions need to be asked for. | ||||
|            */ | ||||
|  | ||||
|           /*if(shouldShowRequestPermissionRationale("android.permission.RECORD_AUDIO")) | ||||
|               Toast.makeText(ActivityMainScreen.this, "shouldShowRequestPermissionRationale", Toast.LENGTH_LONG).show(); | ||||
|           else | ||||
|               Toast.makeText(ActivityMainScreen.this, "not shouldShowRequestPermissionRationale", Toast.LENGTH_LONG).show();*/ | ||||
|  | ||||
| //			  addToArrayListUnique("Manifest.permission.RECORD_AUDIO", requiredPermissions); | ||||
|         /*int hasPermission = checkSelfPermission(Manifest.permission.RECORD_AUDIO); | ||||
|         if (hasPermission == PackageManager.PERMISSION_DENIED) | ||||
|         { | ||||
|             Toast.makeText(ActivityMainScreen.this, "Don't have record_audio. Requesting...", Toast.LENGTH_LONG).show(); | ||||
| //				  requestPermissions(new String[]{"Manifest.permission.CAMERA"}, requestCodeForPermissions); | ||||
|             ActivityCompat.requestPermissions(ActivityMainScreen.this, new String[]{"Manifest.permission.CAMERA"}, requestCodeForPermissions); | ||||
|         } | ||||
|         else | ||||
|             Toast.makeText(ActivityMainScreen.this, "Have record_audio.", Toast.LENGTH_LONG).show();*/ | ||||
|  | ||||
|         } | ||||
|  | ||||
|         return requiredPermissions.toArray(new String[requiredPermissions.size()]); | ||||
| @@ -722,6 +759,8 @@ public class ActivityPermissions extends Activity | ||||
|                     case stopPhoneCall: | ||||
|                         addToArrayListUnique(Manifest.permission.ANSWER_PHONE_CALLS, requiredPermissions); | ||||
|                         break; | ||||
|                     case takeScreenshot: | ||||
|                         addToArrayListUnique(Manifest.permission.BIND_ACCESSIBILITY_SERVICE, requiredPermissions); | ||||
|                     default: | ||||
|                         break; | ||||
|                 } | ||||
| @@ -971,6 +1010,10 @@ public class ActivityPermissions extends Activity | ||||
|             case Manifest.permission.QUERY_ALL_PACKAGES: | ||||
|                 usingElements.add(getResources().getString(R.string.queryAllPackages)); | ||||
|                 break; | ||||
|             case Manifest.permission.BIND_ACCESSIBILITY_SERVICE: | ||||
|                 for(String ruleName : getRulesUsing(Action.Action_Enum.takeScreenshot)) | ||||
|                     usingElements.add(String.format(getResources().getString(R.string.ruleXrequiresThis), ruleName)); | ||||
|                 break; | ||||
|         } | ||||
|  | ||||
|         return usingElements; | ||||
| @@ -979,6 +1022,15 @@ public class ActivityPermissions extends Activity | ||||
|     @Override | ||||
|     protected void onActivityResult(int requestCode, int resultCode, Intent data) | ||||
|     { | ||||
|         /* | ||||
|             All of the following permissions need to be "manually" activated by the user in some | ||||
|             buried system menu. | ||||
|             In my opinion by mistake the function will be called when the user has just landed | ||||
|             on one of those screens, not when he exits it again. To compensate for that onResume() | ||||
|             is overridden. This enables the permission screen to automatically close after all | ||||
|             required permissions have been granted. | ||||
|          */ | ||||
|  | ||||
|         super.onActivityResult(requestCode, resultCode, data); | ||||
|  | ||||
|         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) | ||||
| @@ -1026,6 +1078,10 @@ public class ActivityPermissions extends Activity | ||||
|             if (requestCode == requestCodeForPermissionsManageOverlay) | ||||
|                 if(havePermission(Manifest.permission.SYSTEM_ALERT_WINDOW, ActivityPermissions.this)) | ||||
|                     requestPermissions(cachedPermissionsToRequest, true); | ||||
|  | ||||
|             if (requestCode == requestCodeForPermissionsAccessibility) | ||||
|                 if(havePermission(Manifest.permission.BIND_ACCESSIBILITY_SERVICE, ActivityPermissions.this)) | ||||
|                     requestPermissions(cachedPermissionsToRequest, true); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -1085,10 +1141,14 @@ public class ActivityPermissions extends Activity | ||||
|                     } | ||||
|                     else if (s.equalsIgnoreCase(Manifest.permission.ACCESS_NOTIFICATION_POLICY)) | ||||
|                     { | ||||
|                         if(BuildConfig.FLAVOR.equals(AutomationService.flavor_name_apk)) | ||||
|                             Miscellaneous.messageBox(getResources().getString(R.string.info), getResources().getString(R.string.noticeRestrictedPermissions), ActivityPermissions.this).show(); | ||||
|  | ||||
|                         requiredPermissions.remove(s); | ||||
|                         cachedPermissionsToRequest = requiredPermissions; | ||||
|                         Intent intent = new Intent(android.provider.Settings.ACTION_NOTIFICATION_POLICY_ACCESS_SETTINGS); | ||||
|                         startActivityForResult(intent, requestCodeForPermissionsNotificationPolicy); | ||||
|  | ||||
|                         return; | ||||
|                     } | ||||
|                     else if (s.equalsIgnoreCase(Manifest.permission.SYSTEM_ALERT_WINDOW)) | ||||
| @@ -1107,6 +1167,22 @@ public class ActivityPermissions extends Activity | ||||
|                         diag.show(); | ||||
|                         return; | ||||
|                     } | ||||
|                     else if (s.equalsIgnoreCase(Manifest.permission.BIND_ACCESSIBILITY_SERVICE)) | ||||
|                     { | ||||
|                         AlertDialog diag = Miscellaneous.messageBox(getResources().getString(R.string.info), getResources().getString(R.string.accessibilityApiPermissionHint), ActivityPermissions.this); | ||||
|                         diag.setOnDismissListener(new DialogInterface.OnDismissListener() | ||||
|                         { | ||||
|                             @Override | ||||
|                             public void onDismiss(DialogInterface dialogInterface) | ||||
|                             { | ||||
|                                 requiredPermissions.remove(s); | ||||
|                                 cachedPermissionsToRequest = requiredPermissions; | ||||
|                                 requestBindAccessibilityService(); | ||||
|                             } | ||||
|                         }); | ||||
|                         diag.show(); | ||||
|                         return; | ||||
|                     } | ||||
|                     else if (s.equalsIgnoreCase(Manifest.permission.BIND_NOTIFICATION_LISTENER_SERVICE)) | ||||
|                     { | ||||
|                         if(Build.VERSION.SDK_INT >= 33) | ||||
| @@ -1589,4 +1665,47 @@ public class ActivityPermissions extends Activity | ||||
|             return false; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     protected void onResume() | ||||
|     { | ||||
|         super.onResume(); | ||||
|  | ||||
|         if(Build.VERSION.SDK_INT >= 33 && BuildConfig.FLAVOR.equals(AutomationService.flavor_name_apk)) | ||||
|         { | ||||
|             for (String p : getRequiredPermissions(false)) | ||||
|             { | ||||
|                 if (p.equals(Manifest.permission.BIND_NOTIFICATION_LISTENER_SERVICE) || p.equals(Manifest.permission.BIND_ACCESSIBILITY_SERVICE)) | ||||
|                 { | ||||
|                     tvRestrictionPermissionsNotice.setText(getResources().getString(R.string.noticeRestrictedPermissions)); | ||||
|  | ||||
|                     /* | ||||
|                         Opening the app's settings directly does not work because the | ||||
|                         mentioned 3 dots are only displayed when you went there the hard way. | ||||
|                      */ | ||||
|                     /* | ||||
|                     tvRestrictionPermissionsNotice.setOnClickListener(new View.OnClickListener() | ||||
|                     { | ||||
|                         @Override | ||||
|                         public void onClick(View view) | ||||
|                         { | ||||
|                             Intent intent = new Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS); | ||||
|                             intent.setData(Uri.parse("package:" + getPackageName())); | ||||
|                             startActivity(intent); | ||||
|                         } | ||||
|                     })*/; | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         for(String p : getRequiredPermissions(false)) | ||||
|         { | ||||
|             if(!havePermission(p, this)) | ||||
|                 return; | ||||
|         } | ||||
|  | ||||
|         // have all | ||||
|         setHaveAllPermissions(); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,51 @@ | ||||
| package com.jens.automation2; | ||||
|  | ||||
| import android.accessibilityservice.AccessibilityService; | ||||
| import android.os.Build; | ||||
| import android.util.Log; | ||||
| import android.view.Display; | ||||
| import android.view.accessibility.AccessibilityEvent; | ||||
|  | ||||
| import androidx.annotation.NonNull; | ||||
| import androidx.annotation.RequiresApi; | ||||
|  | ||||
| public class MyAccessibilityService extends AccessibilityService | ||||
| { | ||||
|     static MyAccessibilityService instance; | ||||
|  | ||||
|     public static MyAccessibilityService getInstance() | ||||
|     { | ||||
|         if(instance == null) | ||||
|         { | ||||
|             instance = new MyAccessibilityService(); | ||||
|         } | ||||
|  | ||||
|         return instance; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void onAccessibilityEvent(AccessibilityEvent accessibilityEvent) | ||||
|     { | ||||
|  | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void onInterrupt() | ||||
|     { | ||||
|  | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void onCreate() | ||||
|     { | ||||
|         super.onCreate(); | ||||
|         instance = this; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     protected void onServiceConnected() | ||||
|     { | ||||
|         super.onServiceConnected(); | ||||
|         Miscellaneous.logEvent("i", "Accessibility service", "Service started.", 4); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/drawable-hdpi/copier.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/src/main/res/drawable-hdpi/copier.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 1.7 KiB | 
| @@ -66,6 +66,12 @@ | ||||
|  | ||||
|             </LinearLayout> | ||||
|  | ||||
|             <TextView | ||||
|                 android:id="@+id/tvRestrictionPermissionsNotice" | ||||
|                 android:textColor="@color/red" | ||||
|                 android:layout_width="match_parent" | ||||
|                 android:layout_height="wrap_content" /> | ||||
|  | ||||
|             <ScrollView | ||||
|                         android:layout_width="match_parent" | ||||
|                         android:layout_height="wrap_content" | ||||
|   | ||||
| @@ -802,4 +802,11 @@ | ||||
|     <string name="wifiTriggerDisconnectionHint">Dieser Auslöser ist gültig, wenn Sie gerade die Verbindung zu dem oben angegebenen WLAN getrennt haben ODER während der Dienst noch gestartet wird und wenn Sie mit keinem WLAN verbunden sind. Wenn Sie möchten, dass der Auslöser nur ausgelöst wird, wenn Sie die Verbindung zu einem bestimmten WLAN explizit trennen, fügen Sie einen weiteren Auslöser hinzu: \"Der Dienst wird nicht gestartet\".</string> | ||||
|     <string name="className">Klassenname</string> | ||||
|     <string name="startAppByStartForegroundService">per startForegroundService()</string> | ||||
|     <string name="method">Methode</string> | ||||
|     <string name="takeScreenshot">Screenshot erstellen</string> | ||||
|     <string name="android.permission.BIND_ACCESSIBILITY_SERVICE">An den Barrierefreiheitsdienst anbinden</string> | ||||
|     <string name="bindAccessibilityService">An den Barrierefreiheitsdienst anbinden</string> | ||||
|     <string name="accessibilityApiPermissionHint">Nachdem Sie auf OK geklickt haben, werden Sie zu einem Systemdialog weitergeleitet. Bitte wählen Sie dort Automatisierung aus und erlauben Sie die Barrierefreiheits-API.</string> | ||||
|     <string name="accessibility_service_explanation">Erforderlich für bestimmte Aktionen.</string> | ||||
|     <string name="noticeRestrictedPermissions">Wenn Sie eine der folgenden Berechtigungen nicht erteilen und eine Systemmeldung wie \"Eingeschränkte Berechtigung\" erhalten, müssen Sie zuerst zu den Android-Einstellungen und dann zu den Anwendungen gehen und Automatisierung auswählen. Nun sollten sich 3 Punkte in der oberen rechten Ecke befinden. Klicken Sie auf \"Eingeschränkte Einstellungen zulassen\". Danach sollte die erforderliche Erlaubnis erteilt werden können. Dies sollte nur für die APK-Version der App gelten, nicht für die von F-Droid oder dem Play Store.</string> | ||||
| </resources> | ||||
| @@ -43,7 +43,7 @@ | ||||
|     <string name="enterAname">Inserte un nombre.</string> | ||||
|     <string name="username">Nombre de usuario</string> | ||||
|     <string name="ok">Ok</string> | ||||
|     <string name="continueText">continuar</string> | ||||
|     <string name="continueText">Continuar</string> | ||||
|     <string name="rule">Regla</string> | ||||
|     <string name="android.permission.SEND_SMS">Enviar mensajes SMS</string> | ||||
|     <string name="android.permission.READ_CONTACTS">Leer directorio</string> | ||||
| @@ -197,7 +197,7 @@ | ||||
|     <string name="android.permission.RECORD_AUDIO">Grabar audio</string> | ||||
|     <string name="android.permission.PROCESS_OUTGOING_CALLS">Detectar llamadas salientes</string> | ||||
|     <string name="android.permission.READ_PHONE_STATE">Detectar el estado del dispositivo</string> | ||||
|     <string name="android.permission.READ_EXTERNAL_STORAGE">Leer la almacenamiento</string> | ||||
|     <string name="android.permission.READ_EXTERNAL_STORAGE">Leer el almacenamiento</string> | ||||
|     <string name="android.permission.WRITE_EXTERNAL_STORAGE">Escribir en el almacenamiento</string> | ||||
|     <string name="android.permission.WRITE_SETTINGS">Modificar la configuración del dispositivo</string> | ||||
|     <string name="android.permission.BATTERY_STATS">Determinar el estado de la bateria</string> | ||||
| @@ -801,4 +801,11 @@ | ||||
|     <string name="wifiTriggerDisconnectionHint">Este activador será válido si acabas de desconectarte del wifi especificado anteriormente O mientras el servicio aún se está iniciando y si no estás conectado a ningún wifi. Si desea que el activador se active solo cuando se desconecte explícitamente de una determinada red WiFi, agregue otro activador \"el servicio no se está iniciando\".</string> | ||||
|     <string name="className">Nombre de la clase</string> | ||||
|     <string name="startAppByStartForegroundService">a través de startForegroundService((</string> | ||||
|     <string name="method">Método</string> | ||||
|     <string name="takeScreenshot">Tomar captura de pantalla</string> | ||||
|     <string name="android.permission.BIND_ACCESSIBILITY_SERVICE">Enlazar al servicio de accesibilidad</string> | ||||
|     <string name="bindAccessibilityService">Enlazar al servicio de accesibilidad</string> | ||||
|     <string name="accessibilityApiPermissionHint">Después de hacer clic en Aceptar, se le enviará a un cuadro de diálogo del sistema. Seleccione Automatización allí y permita Permitir API de accesibilidad.</string> | ||||
|     <string name="accessibility_service_explanation">Requerido para ciertas acciones.</string> | ||||
|     <string name="noticeRestrictedPermissions">Si no le otorga a uno el siguiente permiso y un mensaje del sistema como \"Ajuste restringido\", primero debe ir a la configuración de Android, luego a las aplicaciones, elija Automatización. Ahora debería haber 3 puntos en la esquina superior derecha. Haga clic en \"Permitir configuraciones restringidas\". Después de eso, el permiso necesario debería poder otorgarse. Esto solo debería aplicarse a la versión APK de la aplicación, no a las de F-Droid o Play Store.</string> | ||||
| </resources> | ||||
| @@ -801,4 +801,11 @@ | ||||
|     <string name="wifiTriggerDisconnectionHint">Ce déclencheur sera valide si vous venez de vous déconnecter du wifi spécifié ci-dessus OU alors que le service est encore en cours de démarrage et si vous n\'êtes connecté à aucun wifi. Si vous souhaitez que le déclencheur ne se déclenche que lorsque vous vous déconnectez explicitement d\'un certain wifi, ajoutez un autre déclencheur « le service ne démarre pas ».</string> | ||||
|     <string name="className">Nom de la classe</string> | ||||
|     <string name="startAppByStartForegroundService">par startForegroundService()</string> | ||||
|     <string name="method">Méthode</string> | ||||
|     <string name="takeScreenshot">Prendre une capture d\'écran</string> | ||||
|     <string name="android.permission.BIND_ACCESSIBILITY_SERVICE">Se lier au service d\'accessibilité</string> | ||||
|     <string name="bindAccessibilityService">Se lier au service d\'accessibilité</string> | ||||
|     <string name="accessibilityApiPermissionHint">Après avoir cliqué sur OK, vous serez redirigé vers une boîte de dialogue système. Sélectionnez Automatisation et autorisez l\'option Autoriser l\'API d\'accessibilité.</string> | ||||
|     <string name="accessibility_service_explanation">Obligatoire pour certaines actions.</string> | ||||
|     <string name="noticeRestrictedPermissions">Si vous ne parvenez pas à accorder à l\'un d\'entre eux l\'autorisation suivante et un message système tel que « Autorisation restreinte », vous devez d\'abord accéder aux paramètres Android, puis aux applications, puis choisir Automatisation. Maintenant, il devrait y avoir 3 points dans le coin supérieur droit. Cliquez sur « Autoriser les paramètres restreints ». Après cela, l\'autorisation nécessaire devrait pouvoir être accordée. Cela ne devrait s\'appliquer qu\'à la version APK de l\'application, pas à celles de F-Droid ou du Play Store.</string> | ||||
| </resources> | ||||
|   | ||||
| @@ -802,4 +802,11 @@ | ||||
|     <string name="wifiTriggerDisconnectionHint">Questo trigger sarà valido se ti sei appena disconnesso dal Wi-Fi specificato sopra OPPURE mentre il servizio è ancora in fase di avvio e se non sei connesso a nessuna rete Wi-Fi. Se vuoi che il trigger si attivi solo quando ti stai disconnettendo esplicitamente da una determinata rete Wi-Fi, aggiungi un altro trigger \"il servizio non si avvia\".</string> | ||||
|     <string name="className">Nome della classe</string> | ||||
|     <string name="startAppByStartForegroundService">di startForegroundService()</string> | ||||
|     <string name="method">Metodo</string> | ||||
|     <string name="takeScreenshot">Fai uno screenshot</string> | ||||
|     <string name="android.permission.BIND_ACCESSIBILITY_SERVICE">Associare al servizio di accessibilità</string> | ||||
|     <string name="bindAccessibilityService">Associare al servizio di accessibilità</string> | ||||
|     <string name="accessibilityApiPermissionHint">Dopo aver fatto clic su OK, verrà visualizzata una finestra di dialogo di sistema. Seleziona Automazione e consenti Consenti API di accessibilità.</string> | ||||
|     <string name="accessibility_service_explanation">Obbligatorio per determinate azioni.</string> | ||||
|     <string name="noticeRestrictedPermissions">Se non riesci a concedere una delle seguenti autorizzazioni e un messaggio di sistema come \"Autorizzazione limitata\", devi prima andare alle impostazioni di Android, quindi alle applicazioni, scegli Automazione. Ora dovrebbero esserci 3 punti nell\'angolo in alto a destra. Fai clic su \"Consenti impostazioni limitate\". Dopodiché dovrebbe essere concessa l\'autorizzazione necessaria. Questo dovrebbe valere solo per la versione APK dell\'app, non per quelle di F-Droid o Play Store.</string> | ||||
| </resources> | ||||
|   | ||||
| @@ -800,5 +800,12 @@ | ||||
|     <string name="wifiTriggerDisconnectionHint">Deze trigger is geldig als je net de verbinding met de hierboven gespecificeerde wifi hebt verbroken OF terwijl de service nog aan het starten is en als je niet verbonden bent met wifi. Als je wilt dat de trigger alleen wordt geactiveerd wanneer je expliciet de verbinding met een bepaalde wifi verbreekt, voeg dan nog een trigger toe \"service start niet\".</string> | ||||
|     <string name="className">Naam van de klasse</string> | ||||
|     <string name="startAppByStartForegroundService">door startForegroundService()</string> | ||||
|     <string name="method">Methode</string> | ||||
|     <string name="takeScreenshot">Screenshot maken</string> | ||||
|     <string name="android.permission.BIND_ACCESSIBILITY_SERVICE">Binden aan toegankelijkheidsservice</string> | ||||
|     <string name="bindAccessibilityService">Binden aan toegankelijkheidsservice</string> | ||||
|     <string name="accessibilityApiPermissionHint">Nadat u op OK hebt geklikt, wordt u naar een systeemdialoogvenster gestuurd. Selecteer daar Automatisering en sta Toegankelijkheids-API toestaan toe.</string> | ||||
|     <string name="accessibility_service_explanation">Vereist voor bepaalde acties.</string> | ||||
|     <string name="noticeRestrictedPermissions">Als u er niet in slaagt om een van de volgende machtigingen en een systeembericht zoals \"Beperkte toestemming\" te verlenen, moet u eerst naar Android-instellingen gaan en vervolgens naar toepassingen en Automatisering kiezen. Nu zouden er 3 stippen in de rechterbovenhoek moeten zijn. Klik op \"Beperkte instellingen toestaan\". Daarna moet de benodigde toestemming aanvaardbaar zijn. Dit zou alleen van toepassing moeten zijn op de APK-versie van de app, niet die van F-Droid of Play Store.</string> | ||||
|  | ||||
| </resources> | ||||
|   | ||||
| @@ -899,4 +899,11 @@ | ||||
|     <string name="wifiTriggerDisconnectionHint">Ten wyzwalacz będzie prawidłowy, jeśli właśnie rozłączyłeś się z Wi-Fi określonym powyżej LUB gdy usługa jest nadal uruchomiona i jeśli nie masz połączenia z żadną siecią Wi-Fi. Jeśli chcesz, aby wyzwalacz uruchamiał się tylko wtedy, gdy jawnie rozłączasz się z określoną siecią Wi-Fi, dodaj kolejny wyzwalacz \"usługa nie uruchamia się\".</string> | ||||
|     <string name="className">nazwa klasy</string> | ||||
|     <string name="startAppByStartForegroundService">przez startForegroundService()</string> | ||||
|     <string name="method">Metoda</string> | ||||
|     <string name="takeScreenshot">Zrób zrzut ekranu</string> | ||||
|     <string name="android.permission.BIND_ACCESSIBILITY_SERVICE">Powiąż z usługą ułatwień dostępu</string> | ||||
|     <string name="bindAccessibilityService">Powiąż z usługą ułatwień dostępu</string> | ||||
|     <string name="accessibilityApiPermissionHint">Po kliknięciu OK zostaniesz przekierowany do systemowego okna dialogowego. Wybierz tam Automatyzację i zezwól na Zezwalaj na interfejs API ułatwień dostępu.</string> | ||||
|     <string name="accessibility_service_explanation">Wymagane w przypadku niektórych działań.</string> | ||||
|     <string name="noticeRestrictedPermissions">Jeśli nie uda Ci się przyznać następującego uprawnienia i komunikatu systemowego, takiego jak \"Ograniczone uprawnienia\", musisz najpierw przejść do ustawień Androida, a następnie aplikacji, wybrać Automatyzacja. Teraz w prawym górnym rogu powinny znajdować się 3 kropki. Kliknij \"Zezwól na ustawienia z ograniczeniami\". Następnie powinno być możliwe udzielenie niezbędnego pozwolenia. Powinno to dotyczyć tylko wersji APK aplikacji, a nie tych z F-Droid lub Sklepu Play.</string> | ||||
| </resources> | ||||
|   | ||||
| @@ -859,4 +859,11 @@ | ||||
|     <string name="wifiTriggerDisconnectionHint">Этот триггер будет действителен, если вы только что отключились от Wi-Fi, указанного выше, ИЛИ во время запуска службы и если вы не подключены ни к одному Wi-Fi. Если вы хотите, чтобы триггер срабатывал только тогда, когда вы явно отключаетесь от определенного Wi-Fi, добавьте еще один триггер «сервис не запускается».</string> | ||||
|     <string name="className">Имя класса</string> | ||||
|     <string name="startAppByStartForegroundService">no startForegroundService()</string> | ||||
|   <string name="method">Метод</string> | ||||
|   <string name="takeScreenshot">Сделать снимок экрана</string> | ||||
|   <string name="android.permission.BIND_ACCESSIBILITY_SERVICE">Привязка к службе специальных возможностей</string> | ||||
|   <string name="bindAccessibilityService">Привязка к службе специальных возможностей</string> | ||||
|   <string name="accessibilityApiPermissionHint">После нажатия кнопки «ОК» вы попадете в системное диалоговое окно. Выберите там «Автоматизация» и разрешите «Разрешить API специальных возможностей».</string> | ||||
|   <string name="accessibility_service_explanation">Required for certain actions.</string> | ||||
|   <string name="noticeRestrictedPermissions">Если вы не можете предоставить одно из следующих разрешений и системное сообщение типа «Ограниченное разрешение», вам нужно сначала перейти в настройки Android, затем в приложения, выбрать «Автоматизация». Теперь в правом верхнем углу должно быть 3 точки. Нажмите «Разрешить ограниченные настройки». После этого необходимо получить необходимое разрешение. Это должно относиться только к APK-версии приложения, а не к версии из F-Droid или Play Store.</string> | ||||
| </resources> | ||||
|   | ||||
| @@ -800,4 +800,11 @@ | ||||
|     <string name="wifiTriggerDisconnectionHint">如果您刚刚断开了与上面指定的 wifi 的连接,或者在服务仍在启动并且您没有连接到任何 wifi,则此触发器将有效。 如果您希望触发器仅在您明确断开与某个 wifi 的连接时触发,请添加另一个触发器\"服务未启动\"。</string> | ||||
|     <string name="className">类名</string> | ||||
|     <string name="startAppByStartForegroundService">来自 startForegroundService()</string> | ||||
|     <string name="method">方法</string> | ||||
|     <string name="takeScreenshot">截屏</string> | ||||
|     <string name="android.permission.BIND_ACCESSIBILITY_SERVICE">绑定到辅助功能服务</string> | ||||
|     <string name="bindAccessibilityService">绑定到辅助功能服务</string> | ||||
|     <string name="accessibilityApiPermissionHint">单击\"确定\"后,您将被发送到系统对话框。请在此处选择\"自动化\",并允许\"允许辅助功能 API\"。</string> | ||||
|     <string name="accessibility_service_explanation">对于某些操作是必需的。</string> | ||||
|     <string name="noticeRestrictedPermissions">如果您未能授予以下权限和\"受限权限\"之类的系统消息,则需要先转到 Android 设置,然后转到应用程序,选择自动化。现在右上角应该有 3 个点。单击\"允许受限设置\"。之后,应该可以授予必要的权限。这应该仅适用于应用的 APK 版本,而不适用于 F-Droid 或 Play 商店中的版本。</string> | ||||
| </resources> | ||||
| @@ -892,4 +892,10 @@ | ||||
|     <string name="method">Method</string> | ||||
|     <string name="methodGet" translatable="false">GET</string> | ||||
|     <string name="methodPost" translatable="false">POST</string> | ||||
|     <string name="takeScreenshot">Take screenshot</string> | ||||
|     <string name="android.permission.BIND_ACCESSIBILITY_SERVICE">Bind to accessibility service</string> | ||||
|     <string name="bindAccessibilityService">Bind to accessibility service</string> | ||||
|     <string name="accessibilityApiPermissionHint">After clicking OK you\'ll be sent to a system dialog. Please select Automation there and allow "Allow accessibility API".</string> | ||||
|     <string name="accessibility_service_explanation">Required for certain actions.</string> | ||||
|     <string name="noticeRestrictedPermissions">If you fail to grant one the following permission and a system message like \"Restricted permission\" you need to go to Android settings first, then applications, choose Automation. Now there should be 3 dots in the upper right corner. Click \"Allow restricted settings\". After that the necessary permission should be grantable. This should only apply to the APK version of the app, not the ones from F-Droid or Play Store.</string> | ||||
| </resources> | ||||
							
								
								
									
										12
									
								
								app/src/main/res/xml/config_accessibility_service.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								app/src/main/res/xml/config_accessibility_service.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| <?xml version="1.0" encoding="utf-8"?> | ||||
| <accessibility-service xmlns:android="http://schemas.android.com/apk/res/android" | ||||
|     android:accessibilityEventTypes="typeAllMask" | ||||
|     android:accessibilityFlags="flagDefault" | ||||
|     android:accessibilityFeedbackType="feedbackSpoken" | ||||
|     android:canPerformGestures="false" | ||||
|     android:canRequestFilterKeyEvents="false" | ||||
|     android:canRequestFingerprintGestures="false" | ||||
|     android:canRetrieveWindowContent="false" | ||||
|     android:canTakeScreenshot="true" | ||||
|     android:notificationTimeout="0" | ||||
|     android:description="@string/accessibility_service_explanation" /> | ||||
| @@ -1,3 +1,5 @@ | ||||
| * Fixed: Overlay permission for start other program action only required if startByActivity() is selected | ||||
| * Fixed: Broadcast receiver trigger would not trigger anything, but crash | ||||
| * Added: One can now choose between GET and POST when using triggerURL action | ||||
| * Fixed: Bug in Android 14 (not in Automation!!!) required a change when dialing MMI codes containing a # character. | ||||
| * Added: One can now choose between GET and POST when using triggerURL action | ||||
| * Added: new action -> take screenshot | ||||
		Reference in New Issue
	
	Block a user