I am trying to bypass Android Security and enabling my Application to get Accessibility Permissions without asking the user to do it.
Searching around in StackOverflow i found out that is possible, click here to see, by using the InstrumentationRegistry
, however that class is now deprecated and so i started using the Process
class and launching the method you can see above:
String packageName = "com.example.rat";
String serviceName = packageName+"/"+"rat.modules.KeyLogger";
String service = "enabled_accessibility_services";
String cmd = "settings put secure "+service+" "+serviceName;
System.out.println("Command: "+cmd);
Scanner s = new Scanner(cmd);
s.useDelimiter(" ");
Process p = Runtime.getRuntime().exec(new String[]{s.next(),s.next(),s.next(),s.next(),s.next()});
String error = "";
String line = "";
BufferedReader br = new BufferedReader(new InputStreamReader(p.getErrorStream()));
while ((line = br.readLine()) != null) {
error += line;
}
System.out.println("Response: "+error);
The error i get from the previously shown code is here:
Security exception: You either need MANAGE_USERS or CREATE_USERS permission to: query userjava.lang.SecurityException: You either need MANAGE_USERS or CREATE_USERS permission to: query user at com.android.server.pm.UserManagerService.checkManageOrCreateUsersPermission(UserManagerService.java:1854) at com.android.server.pm.UserManagerService.getUserInfo(UserManagerService.java:1039) at android.os.UserManager.getUserInfo(UserManager.java:1366) at com.android.providers.settings.SettingsService$MyShellCommand.onCommand(SettingsService.java:273) at android.os.ShellCommand.exec(ShellCommand.java:96) at com.android.providers.settings.SettingsService.onShellCommand(SettingsService.java:51) at android.os.Binder.shellCommand(Binder.java:581) at android.os.Binder.onTransact(Binder.java:481) at android.os.Binder.execTransact(Binder.java:682)
Is there anyway to bypass it? i am open to every kind of idea.