package androidx.core.content; import android.annotation.SuppressLint; import android.content.ContentProvider; import android.content.ContentValues; import android.content.Context; import android.content.pm.ProviderInfo; import android.content.res.XmlResourceParser; import android.database.Cursor; import android.database.MatrixCursor; import android.net.Uri; import android.os.Bundle; import android.os.Environment; import android.os.ParcelFileDescriptor; import android.text.TextUtils; import android.webkit.MimeTypeMap; import androidx.annotation.CallSuper; import androidx.annotation.GuardedBy; import androidx.annotation.NonNull; import androidx.annotation.Nullable; import androidx.annotation.RequiresApi; import androidx.annotation.VisibleForTesting; import androidx.annotation.XmlRes; import androidx.core.util.ObjectsCompat; import com.google.android.gms.drive.DriveFile; import java.io.File; import java.io.FileNotFoundException; import java.io.IOException; import java.util.HashMap; import java.util.Map; import org.xmlpull.v1.XmlPullParserException; /* loaded from: classes.dex */ public class FileProvider extends ContentProvider { private static final String ATTR_NAME = "name"; private static final String ATTR_PATH = "path"; private static final String DISPLAYNAME_FIELD = "displayName"; private static final String META_DATA_FILE_PROVIDER_PATHS = "android.support.FILE_PROVIDER_PATHS"; private static final String TAG_CACHE_PATH = "cache-path"; private static final String TAG_EXTERNAL = "external-path"; private static final String TAG_EXTERNAL_CACHE = "external-cache-path"; private static final String TAG_EXTERNAL_FILES = "external-files-path"; private static final String TAG_EXTERNAL_MEDIA = "external-media-path"; private static final String TAG_FILES_PATH = "files-path"; private static final String TAG_ROOT_PATH = "root-path"; @GuardedBy("mLock") private String mAuthority; @Nullable @GuardedBy("mLock") private PathStrategy mLocalPathStrategy; @NonNull private final Object mLock; private final int mResourceId; private static final String[] COLUMNS = {"_display_name", "_size"}; private static final File DEVICE_ROOT = new File("/"); @GuardedBy("sCache") private static final HashMap sCache = new HashMap<>(); public interface PathStrategy { File getFileForUri(Uri uri); Uri getUriForFile(File file); } @Override // android.content.ContentProvider @Nullable public String getTypeAnonymous(@NonNull Uri uri) { return "application/octet-stream"; } @Override // android.content.ContentProvider public boolean onCreate() { return true; } public FileProvider() { this(0); } public FileProvider(@XmlRes int i) { this.mLock = new Object(); this.mResourceId = i; } @Override // android.content.ContentProvider @CallSuper public void attachInfo(@NonNull Context context, @NonNull ProviderInfo providerInfo) { super.attachInfo(context, providerInfo); if (providerInfo.exported) { throw new SecurityException("Provider must not be exported"); } if (!providerInfo.grantUriPermissions) { throw new SecurityException("Provider must grant uri permissions"); } String str = providerInfo.authority.split(";")[0]; synchronized (this.mLock) { this.mAuthority = str; } HashMap hashMap = sCache; synchronized (hashMap) { hashMap.remove(str); } } public static Uri getUriForFile(@NonNull Context context, @NonNull String str, @NonNull File file) { return getPathStrategy(context, str, 0).getUriForFile(file); } @NonNull @SuppressLint({"StreamFiles"}) public static Uri getUriForFile(@NonNull Context context, @NonNull String str, @NonNull File file, @NonNull String str2) { return getUriForFile(context, str, file).buildUpon().appendQueryParameter(DISPLAYNAME_FIELD, str2).build(); } @Override // android.content.ContentProvider @NonNull public Cursor query(@NonNull Uri uri, @Nullable String[] strArr, @Nullable String str, @Nullable String[] strArr2, @Nullable String str2) { int i; File fileForUri = getLocalPathStrategy().getFileForUri(uri); String queryParameter = uri.getQueryParameter(DISPLAYNAME_FIELD); if (strArr == null) { strArr = COLUMNS; } String[] strArr3 = new String[strArr.length]; Object[] objArr = new Object[strArr.length]; int i2 = 0; for (String str3 : strArr) { if ("_display_name".equals(str3)) { strArr3[i2] = "_display_name"; i = i2 + 1; objArr[i2] = queryParameter == null ? fileForUri.getName() : queryParameter; } else if ("_size".equals(str3)) { strArr3[i2] = "_size"; i = i2 + 1; objArr[i2] = Long.valueOf(fileForUri.length()); } i2 = i; } String[] copyOf = copyOf(strArr3, i2); Object[] copyOf2 = copyOf(objArr, i2); MatrixCursor matrixCursor = new MatrixCursor(copyOf, 1); matrixCursor.addRow(copyOf2); return matrixCursor; } @Override // android.content.ContentProvider @Nullable public String getType(@NonNull Uri uri) { File fileForUri = getLocalPathStrategy().getFileForUri(uri); int lastIndexOf = fileForUri.getName().lastIndexOf(46); if (lastIndexOf < 0) { return "application/octet-stream"; } String mimeTypeFromExtension = MimeTypeMap.getSingleton().getMimeTypeFromExtension(fileForUri.getName().substring(lastIndexOf + 1)); return mimeTypeFromExtension != null ? mimeTypeFromExtension : "application/octet-stream"; } @Override // android.content.ContentProvider public Uri insert(@NonNull Uri uri, @NonNull ContentValues contentValues) { throw new UnsupportedOperationException("No external inserts"); } @Override // android.content.ContentProvider public int update(@NonNull Uri uri, @NonNull ContentValues contentValues, @Nullable String str, @Nullable String[] strArr) { throw new UnsupportedOperationException("No external updates"); } @Override // android.content.ContentProvider public int delete(@NonNull Uri uri, @Nullable String str, @Nullable String[] strArr) { return getLocalPathStrategy().getFileForUri(uri).delete() ? 1 : 0; } @Override // android.content.ContentProvider @SuppressLint({"UnknownNullness"}) public ParcelFileDescriptor openFile(@NonNull Uri uri, @NonNull String str) throws FileNotFoundException { return ParcelFileDescriptor.open(getLocalPathStrategy().getFileForUri(uri), modeToMode(str)); } @NonNull private PathStrategy getLocalPathStrategy() { PathStrategy pathStrategy; synchronized (this.mLock) { try { ObjectsCompat.requireNonNull(this.mAuthority, "mAuthority is null. Did you override attachInfo and did not call super.attachInfo()?"); if (this.mLocalPathStrategy == null) { this.mLocalPathStrategy = getPathStrategy(getContext(), this.mAuthority, this.mResourceId); } pathStrategy = this.mLocalPathStrategy; } catch (Throwable th) { throw th; } } return pathStrategy; } private static PathStrategy getPathStrategy(Context context, String str, int i) { PathStrategy pathStrategy; HashMap hashMap = sCache; synchronized (hashMap) { try { pathStrategy = hashMap.get(str); if (pathStrategy == null) { try { try { pathStrategy = parsePathStrategy(context, str, i); hashMap.put(str, pathStrategy); } catch (IOException e) { throw new IllegalArgumentException("Failed to parse android.support.FILE_PROVIDER_PATHS meta-data", e); } } catch (XmlPullParserException e2) { throw new IllegalArgumentException("Failed to parse android.support.FILE_PROVIDER_PATHS meta-data", e2); } } } catch (Throwable th) { throw th; } } return pathStrategy; } @VisibleForTesting public static XmlResourceParser getFileProviderPathsMetaData(Context context, String str, @Nullable ProviderInfo providerInfo, int i) { if (providerInfo == null) { throw new IllegalArgumentException("Couldn't find meta-data for provider with authority " + str); } if (providerInfo.metaData == null && i != 0) { Bundle bundle = new Bundle(1); providerInfo.metaData = bundle; bundle.putInt(META_DATA_FILE_PROVIDER_PATHS, i); } XmlResourceParser loadXmlMetaData = providerInfo.loadXmlMetaData(context.getPackageManager(), META_DATA_FILE_PROVIDER_PATHS); if (loadXmlMetaData != null) { return loadXmlMetaData; } throw new IllegalArgumentException("Missing android.support.FILE_PROVIDER_PATHS meta-data"); } private static PathStrategy parsePathStrategy(Context context, String str, int i) throws IOException, XmlPullParserException { SimplePathStrategy simplePathStrategy = new SimplePathStrategy(str); XmlResourceParser fileProviderPathsMetaData = getFileProviderPathsMetaData(context, str, context.getPackageManager().resolveContentProvider(str, 128), i); while (true) { int next = fileProviderPathsMetaData.next(); if (next == 1) { return simplePathStrategy; } if (next == 2) { String name = fileProviderPathsMetaData.getName(); File file = null; String attributeValue = fileProviderPathsMetaData.getAttributeValue(null, "name"); String attributeValue2 = fileProviderPathsMetaData.getAttributeValue(null, "path"); if (TAG_ROOT_PATH.equals(name)) { file = DEVICE_ROOT; } else if (TAG_FILES_PATH.equals(name)) { file = context.getFilesDir(); } else if (TAG_CACHE_PATH.equals(name)) { file = context.getCacheDir(); } else if (TAG_EXTERNAL.equals(name)) { file = Environment.getExternalStorageDirectory(); } else if (TAG_EXTERNAL_FILES.equals(name)) { File[] externalFilesDirs = ContextCompat.getExternalFilesDirs(context, null); if (externalFilesDirs.length > 0) { file = externalFilesDirs[0]; } } else if (TAG_EXTERNAL_CACHE.equals(name)) { File[] externalCacheDirs = ContextCompat.getExternalCacheDirs(context); if (externalCacheDirs.length > 0) { file = externalCacheDirs[0]; } } else if (TAG_EXTERNAL_MEDIA.equals(name)) { File[] externalMediaDirs = Api21Impl.getExternalMediaDirs(context); if (externalMediaDirs.length > 0) { file = externalMediaDirs[0]; } } if (file != null) { simplePathStrategy.addRoot(attributeValue, buildPath(file, attributeValue2)); } } } } public static class SimplePathStrategy implements PathStrategy { private final String mAuthority; private final HashMap mRoots = new HashMap<>(); public SimplePathStrategy(String str) { this.mAuthority = str; } public void addRoot(String str, File file) { if (TextUtils.isEmpty(str)) { throw new IllegalArgumentException("Name must not be empty"); } try { this.mRoots.put(str, file.getCanonicalFile()); } catch (IOException e) { throw new IllegalArgumentException("Failed to resolve canonical path for " + file, e); } } @Override // androidx.core.content.FileProvider.PathStrategy public Uri getUriForFile(File file) { String substring; try { String canonicalPath = file.getCanonicalPath(); Map.Entry entry = null; for (Map.Entry entry2 : this.mRoots.entrySet()) { String path = entry2.getValue().getPath(); if (belongsToRoot(canonicalPath, path) && (entry == null || path.length() > entry.getValue().getPath().length())) { entry = entry2; } } if (entry == null) { throw new IllegalArgumentException("Failed to find configured root that contains " + canonicalPath); } String path2 = entry.getValue().getPath(); if (path2.endsWith("/")) { substring = canonicalPath.substring(path2.length()); } else { substring = canonicalPath.substring(path2.length() + 1); } return new Uri.Builder().scheme("content").authority(this.mAuthority).encodedPath(Uri.encode(entry.getKey()) + '/' + Uri.encode(substring, "/")).build(); } catch (IOException unused) { throw new IllegalArgumentException("Failed to resolve canonical path for " + file); } } @Override // androidx.core.content.FileProvider.PathStrategy public File getFileForUri(Uri uri) { String encodedPath = uri.getEncodedPath(); int indexOf = encodedPath.indexOf(47, 1); String decode = Uri.decode(encodedPath.substring(1, indexOf)); String decode2 = Uri.decode(encodedPath.substring(indexOf + 1)); File file = this.mRoots.get(decode); if (file == null) { throw new IllegalArgumentException("Unable to find configured root for " + uri); } File file2 = new File(file, decode2); try { File canonicalFile = file2.getCanonicalFile(); if (belongsToRoot(canonicalFile.getPath(), file.getPath())) { return canonicalFile; } throw new SecurityException("Resolved path jumped beyond configured root"); } catch (IOException unused) { throw new IllegalArgumentException("Failed to resolve canonical path for " + file2); } } private boolean belongsToRoot(@NonNull String str, @NonNull String str2) { String removeTrailingSlash = FileProvider.removeTrailingSlash(str); String removeTrailingSlash2 = FileProvider.removeTrailingSlash(str2); if (!removeTrailingSlash.equals(removeTrailingSlash2)) { if (!removeTrailingSlash.startsWith(removeTrailingSlash2 + '/')) { return false; } } return true; } } private static int modeToMode(String str) { if ("r".equals(str)) { return DriveFile.MODE_READ_ONLY; } if ("w".equals(str) || "wt".equals(str)) { return 738197504; } if ("wa".equals(str)) { return 704643072; } if ("rw".equals(str)) { return 939524096; } if ("rwt".equals(str)) { return 1006632960; } throw new IllegalArgumentException("Invalid mode: " + str); } private static File buildPath(File file, String... strArr) { for (String str : strArr) { if (str != null) { file = new File(file, str); } } return file; } private static String[] copyOf(String[] strArr, int i) { String[] strArr2 = new String[i]; System.arraycopy(strArr, 0, strArr2, 0, i); return strArr2; } private static Object[] copyOf(Object[] objArr, int i) { Object[] objArr2 = new Object[i]; System.arraycopy(objArr, 0, objArr2, 0, i); return objArr2; } /* JADX INFO: Access modifiers changed from: private */ @NonNull public static String removeTrailingSlash(@NonNull String str) { return (str.length() <= 0 || str.charAt(str.length() + (-1)) != '/') ? str : str.substring(0, str.length() - 1); } @RequiresApi(21) public static class Api21Impl { private Api21Impl() { } public static File[] getExternalMediaDirs(Context context) { return context.getExternalMediaDirs(); } } }