refactore phone helper to ignore security exception
This commit is contained in:
parent
a337be982f
commit
5e15c48206
|
@ -141,7 +141,7 @@ public class PublishProfilePictureActivity extends XmppActivity {
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
this.defaultUri = PhoneHelper.getSelfiUri(getApplicationContext());
|
this.defaultUri = PhoneHelper.getProfilePictureUri(getApplicationContext());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void chooseAvatar(boolean crop) {
|
private void chooseAvatar(boolean crop) {
|
||||||
|
|
|
@ -82,45 +82,23 @@ public class PhoneHelper {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class NotThrowCursorLoader extends CursorLoader {
|
public static Uri getProfilePictureUri(Context context) {
|
||||||
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M && context.checkSelfPermission(Manifest.permission.READ_CONTACTS) != PackageManager.PERMISSION_GRANTED) {
|
||||||
public NotThrowCursorLoader(Context c, Uri u, String[] p, String s, String[] sa, String so) {
|
return null;
|
||||||
super(c, u, p, s, sa, so);
|
|
||||||
}
|
}
|
||||||
|
final String[] projection = new String[]{Profile._ID, Profile.PHOTO_URI};
|
||||||
@Override
|
final Cursor cursor;
|
||||||
public Cursor loadInBackground() {
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return (super.loadInBackground());
|
cursor = context.getContentResolver().query(Profile.CONTENT_URI, projection, null, null, null);
|
||||||
} catch (Throwable e) {
|
} catch (SecurityException e) {
|
||||||
return(null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Uri getSelfiUri(Context context) {
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M
|
|
||||||
&& context.checkSelfPermission(Manifest.permission.READ_CONTACTS) != PackageManager.PERMISSION_GRANTED) {
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
String[] mProjection = new String[]{Profile._ID, Profile.PHOTO_URI};
|
if (cursor == null) {
|
||||||
Cursor mProfileCursor = context.getContentResolver().query(
|
|
||||||
Profile.CONTENT_URI, mProjection, null, null, null);
|
|
||||||
|
|
||||||
if (mProfileCursor == null || mProfileCursor.getCount() == 0) {
|
|
||||||
return null;
|
return null;
|
||||||
} else {
|
|
||||||
mProfileCursor.moveToFirst();
|
|
||||||
String uri = mProfileCursor.getString(1);
|
|
||||||
mProfileCursor.close();
|
|
||||||
if (uri == null) {
|
|
||||||
return null;
|
|
||||||
} else {
|
|
||||||
return Uri.parse(uri);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
final String uri = cursor.moveToFirst() ? cursor.getString(1) : null;
|
||||||
|
cursor.close();
|
||||||
|
return uri == null ? null : Uri.parse(uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String getVersionName(Context context) {
|
public static String getVersionName(Context context) {
|
||||||
|
@ -135,4 +113,22 @@ public class PhoneHelper {
|
||||||
return "unknown";
|
return "unknown";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static class NotThrowCursorLoader extends CursorLoader {
|
||||||
|
|
||||||
|
private NotThrowCursorLoader(Context c, Uri u, String[] p, String s, String[] sa, String so) {
|
||||||
|
super(c, u, p, s, sa, so);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Cursor loadInBackground() {
|
||||||
|
|
||||||
|
try {
|
||||||
|
return (super.loadInBackground());
|
||||||
|
} catch (Throwable e) {
|
||||||
|
return (null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue