diff --git a/app/src/main/java/eu/faircode/email/FragmentOptionsMisc.java b/app/src/main/java/eu/faircode/email/FragmentOptionsMisc.java index 4633bf4bff..7db1f4513b 100644 --- a/app/src/main/java/eu/faircode/email/FragmentOptionsMisc.java +++ b/app/src/main/java/eu/faircode/email/FragmentOptionsMisc.java @@ -859,82 +859,11 @@ public class FragmentOptionsMisc extends FragmentBase implements SharedPreferenc setLastCleanup(prefs.getLong("last_cleanup", -1)); + setPermissionInfo(); + swExactAlarms.setEnabled(AlarmManagerCompatEx.canScheduleExactAlarms(getContext())); swTestIab.setVisibility(BuildConfig.DEBUG ? View.VISIBLE : View.GONE); - try { - int start = 0; - int dp24 = Helper.dp2pixels(getContext(), 24); - SpannableStringBuilder ssb = new SpannableStringBuilder(); - PackageManager pm = getContext().getPackageManager(); - PackageInfo pi = pm.getPackageInfo(BuildConfig.APPLICATION_ID, PackageManager.GET_PERMISSIONS); - for (int i = 0; i < pi.requestedPermissions.length; i++) { - boolean granted = ((pi.requestedPermissionsFlags[i] & PackageInfo.REQUESTED_PERMISSION_GRANTED) != 0); - - PermissionInfo info; - try { - info = pm.getPermissionInfo(pi.requestedPermissions[i], PackageManager.GET_META_DATA); - } catch (Throwable ex) { - info = new PermissionInfo(); - info.name = pi.requestedPermissions[i]; - if (!(ex instanceof PackageManager.NameNotFoundException)) - info.group = ex.toString(); - } - - ssb.append(info.name).append('\n'); - if (granted) - ssb.setSpan(new StyleSpan(Typeface.BOLD), start, ssb.length(), 0); - start = ssb.length(); - - if (info.group != null) { - ssb.append(info.group).append('\n'); - ssb.setSpan(new IndentSpan(dp24), start, ssb.length(), 0); - start = ssb.length(); - } - - CharSequence description = info.loadDescription(pm); - if (description != null) { - ssb.append(description).append('\n'); - ssb.setSpan(new IndentSpan(dp24), start, ssb.length(), 0); - ssb.setSpan(new RelativeSizeSpan(HtmlHelper.FONT_SMALL), start, ssb.length(), 0); - start = ssb.length(); - } - - if (info.protectionLevel != 0) { - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P) - switch (info.getProtection()) { - case PermissionInfo.PROTECTION_DANGEROUS: - ssb.append("dangerous "); - break; - case PermissionInfo.PROTECTION_NORMAL: - ssb.append("normal "); - break; - case PermissionInfo.PROTECTION_SIGNATURE: - ssb.append("signature "); - break; - case PermissionInfo.PROTECTION_SIGNATURE_OR_SYSTEM: - ssb.append("signatureOrSystem "); - break; - } - - ssb.append(Integer.toHexString(info.protectionLevel)); - - if (info.flags != 0) - ssb.append(' ').append(Integer.toHexString(info.flags)); - - ssb.append('\n'); - ssb.setSpan(new IndentSpan(dp24), start, ssb.length(), 0); - start = ssb.length(); - } - - ssb.append('\n'); - } - tvPermissions.setText(ssb); - } catch (Throwable ex) { - Log.w(ex); - tvPermissions.setText(ex.toString()); - } - PreferenceManager.getDefaultSharedPreferences(getContext()).registerOnSharedPreferenceChangeListener(this); return view; @@ -1183,6 +1112,81 @@ public class FragmentOptionsMisc extends FragmentBase implements SharedPreferenc time < 0 ? "-" : DTF.format(time))); } + private void setPermissionInfo() { + try { + int start = 0; + int dp24 = Helper.dp2pixels(getContext(), 24); + SpannableStringBuilder ssb = new SpannableStringBuilder(); + PackageManager pm = getContext().getPackageManager(); + PackageInfo pi = pm.getPackageInfo(BuildConfig.APPLICATION_ID, PackageManager.GET_PERMISSIONS); + for (int i = 0; i < pi.requestedPermissions.length; i++) { + boolean granted = ((pi.requestedPermissionsFlags[i] & PackageInfo.REQUESTED_PERMISSION_GRANTED) != 0); + + PermissionInfo info; + try { + info = pm.getPermissionInfo(pi.requestedPermissions[i], PackageManager.GET_META_DATA); + } catch (Throwable ex) { + info = new PermissionInfo(); + info.name = pi.requestedPermissions[i]; + if (!(ex instanceof PackageManager.NameNotFoundException)) + info.group = ex.toString(); + } + + ssb.append(info.name).append('\n'); + if (granted) + ssb.setSpan(new StyleSpan(Typeface.BOLD), start, ssb.length(), 0); + start = ssb.length(); + + if (info.group != null) { + ssb.append(info.group).append('\n'); + ssb.setSpan(new IndentSpan(dp24), start, ssb.length(), 0); + start = ssb.length(); + } + + CharSequence description = info.loadDescription(pm); + if (description != null) { + ssb.append(description).append('\n'); + ssb.setSpan(new IndentSpan(dp24), start, ssb.length(), 0); + ssb.setSpan(new RelativeSizeSpan(HtmlHelper.FONT_SMALL), start, ssb.length(), 0); + start = ssb.length(); + } + + if (info.protectionLevel != 0) { + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P) + switch (info.getProtection()) { + case PermissionInfo.PROTECTION_DANGEROUS: + ssb.append("dangerous "); + break; + case PermissionInfo.PROTECTION_NORMAL: + ssb.append("normal "); + break; + case PermissionInfo.PROTECTION_SIGNATURE: + ssb.append("signature "); + break; + case PermissionInfo.PROTECTION_SIGNATURE_OR_SYSTEM: + ssb.append("signatureOrSystem "); + break; + } + + ssb.append(Integer.toHexString(info.protectionLevel)); + + if (info.flags != 0) + ssb.append(' ').append(Integer.toHexString(info.flags)); + + ssb.append('\n'); + ssb.setSpan(new IndentSpan(dp24), start, ssb.length(), 0); + start = ssb.length(); + } + + ssb.append('\n'); + } + tvPermissions.setText(ssb); + } catch (Throwable ex) { + Log.w(ex); + tvPermissions.setText(ex.toString()); + } + } + private static class StorageData { private long hused; private long hmax;