123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 |
- /**
- * ownCloud Android client application
- *
- * Copyright (C) 2015 ownCloud Inc.
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2,
- * as published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
- package com.owncloud.android.utils;
- import android.content.ContentResolver;
- import android.content.Context;
- import android.database.Cursor;
- import android.net.Uri;
- import android.provider.MediaStore;
- import android.webkit.MimeTypeMap;
- import com.owncloud.android.lib.common.utils.Log_OC;
- import java.util.Locale;
- /**
- * A helper class for some Uri operations.
- */
- public final class UriUtils {
- private static final String TAG = UriUtils.class.getSimpleName();
- public static final String URI_CONTENT_SCHEME = "content://";
- private UriUtils() {
- // utility class -> private constructor
- }
- public static String getDisplayNameForUri(Uri uri, Context context) {
- if (uri == null || context == null) {
- throw new IllegalArgumentException("Received NULL!");
- }
- String displayName;
- if (!ContentResolver.SCHEME_CONTENT.equals(uri.getScheme())) {
- displayName = uri.getLastPathSegment(); // ready to return
- } else {
- // content: URI
- displayName = getDisplayNameFromContentResolver(uri, context);
- try {
- if (displayName == null) {
- // last chance to have a name
- displayName = uri.getLastPathSegment().replaceAll("\\s", "");
- }
- // Add best possible extension
- int index = displayName.lastIndexOf('.');
- if (index == -1 || MimeTypeMap.getSingleton().
- getMimeTypeFromExtension(displayName.substring(index + 1).toLowerCase(Locale.ROOT)) == null) {
- String mimeType = context.getContentResolver().getType(uri);
- String extension = MimeTypeMap.getSingleton().getExtensionFromMimeType(mimeType);
- if (extension != null) {
- displayName += "." + extension;
- }
- }
- } catch (Exception e) {
- Log_OC.e(TAG, "No way to get a display name for " + uri.toString());
- }
- }
- // Replace path separator characters to avoid inconsistent paths
- return displayName.replaceAll("/", "-");
- }
- private static String getDisplayNameFromContentResolver(Uri uri, Context context) {
- String displayName = null;
- String mimeType = context.getContentResolver().getType(uri);
- if (mimeType != null) {
- String displayNameColumn;
- if (MimeTypeUtil.isImage(mimeType)) {
- displayNameColumn = MediaStore.Images.ImageColumns.DISPLAY_NAME;
- } else if (MimeTypeUtil.isVideo(mimeType)) {
- displayNameColumn = MediaStore.Video.VideoColumns.DISPLAY_NAME;
- } else if (MimeTypeUtil.isAudio(mimeType)) {
- displayNameColumn = MediaStore.Audio.AudioColumns.DISPLAY_NAME;
- } else {
- displayNameColumn = MediaStore.Files.FileColumns.DISPLAY_NAME;
- }
- try (Cursor cursor = context.getContentResolver().query(
- uri,
- new String[]{displayNameColumn},
- null,
- null,
- null
- )) {
- if (cursor != null) {
- cursor.moveToFirst();
- displayName = cursor.getString(cursor.getColumnIndex(displayNameColumn));
- }
- } catch (Exception e) {
- Log_OC.e(TAG, "Could not retrieve display name for " + uri.toString());
- // nothing else, displayName keeps null
- }
- }
- return displayName;
- }
- }
|