Rabbit-R1/original r1/java/sources/androidx/media3/exoplayer/offline/DefaultDownloadIndex.java

366 lines
18 KiB
Java
Raw Normal View History

2024-05-21 16:08:36 -05:00
package androidx.media3.exoplayer.offline;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;
import android.net.Uri;
import android.text.TextUtils;
import androidx.media3.common.StreamKey;
import androidx.media3.common.util.Assertions;
import androidx.media3.common.util.Util;
import androidx.media3.database.DatabaseIOException;
import androidx.media3.database.DatabaseProvider;
import androidx.media3.database.VersionTable;
import androidx.media3.exoplayer.offline.DownloadRequest;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
/* loaded from: classes2.dex */
public final class DefaultDownloadIndex implements WritableDownloadIndex {
private static final String COLUMN_DATA = "data";
private static final String COLUMN_ID = "id";
private static final int COLUMN_INDEX_BYTES_DOWNLOADED = 13;
private static final int COLUMN_INDEX_CONTENT_LENGTH = 9;
private static final int COLUMN_INDEX_CUSTOM_CACHE_KEY = 4;
private static final int COLUMN_INDEX_DATA = 5;
private static final int COLUMN_INDEX_FAILURE_REASON = 11;
private static final int COLUMN_INDEX_ID = 0;
private static final int COLUMN_INDEX_KEY_SET_ID = 14;
private static final int COLUMN_INDEX_MIME_TYPE = 1;
private static final int COLUMN_INDEX_PERCENT_DOWNLOADED = 12;
private static final int COLUMN_INDEX_START_TIME_MS = 7;
private static final int COLUMN_INDEX_STATE = 6;
private static final int COLUMN_INDEX_STOP_REASON = 10;
private static final int COLUMN_INDEX_STREAM_KEYS = 3;
private static final int COLUMN_INDEX_UPDATE_TIME_MS = 8;
private static final int COLUMN_INDEX_URI = 2;
private static final String COLUMN_STATE = "state";
private static final String COLUMN_STOP_REASON = "stop_reason";
private static final String TABLE_PREFIX = "ExoPlayerDownloads";
private static final String TABLE_SCHEMA = "(id TEXT PRIMARY KEY NOT NULL,mime_type TEXT,uri TEXT NOT NULL,stream_keys TEXT NOT NULL,custom_cache_key TEXT,data BLOB NOT NULL,state INTEGER NOT NULL,start_time_ms INTEGER NOT NULL,update_time_ms INTEGER NOT NULL,content_length INTEGER NOT NULL,stop_reason INTEGER NOT NULL,failure_reason INTEGER NOT NULL,percent_downloaded REAL NOT NULL,bytes_downloaded INTEGER NOT NULL,key_set_id BLOB NOT NULL)";
static final int TABLE_VERSION = 3;
private static final String TRUE = "1";
private static final String WHERE_ID_EQUALS = "id = ?";
private static final String WHERE_STATE_IS_DOWNLOADING = "state = 2";
private final DatabaseProvider databaseProvider;
private final Object initializationLock;
private boolean initialized;
private final String name;
private final String tableName;
private static final String WHERE_STATE_IS_TERMINAL = getStateQuery(3, 4);
private static final String COLUMN_MIME_TYPE = "mime_type";
private static final String COLUMN_URI = "uri";
private static final String COLUMN_STREAM_KEYS = "stream_keys";
private static final String COLUMN_CUSTOM_CACHE_KEY = "custom_cache_key";
private static final String COLUMN_START_TIME_MS = "start_time_ms";
private static final String COLUMN_UPDATE_TIME_MS = "update_time_ms";
private static final String COLUMN_CONTENT_LENGTH = "content_length";
private static final String COLUMN_FAILURE_REASON = "failure_reason";
private static final String COLUMN_PERCENT_DOWNLOADED = "percent_downloaded";
private static final String COLUMN_BYTES_DOWNLOADED = "bytes_downloaded";
private static final String COLUMN_KEY_SET_ID = "key_set_id";
private static final String[] COLUMNS = {"id", COLUMN_MIME_TYPE, COLUMN_URI, COLUMN_STREAM_KEYS, COLUMN_CUSTOM_CACHE_KEY, "data", "state", COLUMN_START_TIME_MS, COLUMN_UPDATE_TIME_MS, COLUMN_CONTENT_LENGTH, "stop_reason", COLUMN_FAILURE_REASON, COLUMN_PERCENT_DOWNLOADED, COLUMN_BYTES_DOWNLOADED, COLUMN_KEY_SET_ID};
public DefaultDownloadIndex(DatabaseProvider databaseProvider) {
this(databaseProvider, "");
}
public DefaultDownloadIndex(DatabaseProvider databaseProvider, String str) {
this.name = str;
this.databaseProvider = databaseProvider;
this.tableName = TABLE_PREFIX + str;
this.initializationLock = new Object();
}
@Override // androidx.media3.exoplayer.offline.DownloadIndex
public Download getDownload(String str) throws DatabaseIOException {
ensureInitialized();
try {
Cursor cursor = getCursor(WHERE_ID_EQUALS, new String[]{str});
try {
if (cursor.getCount() == 0) {
if (cursor == null) {
return null;
}
cursor.close();
return null;
}
cursor.moveToNext();
Download downloadForCurrentRow = getDownloadForCurrentRow(cursor);
if (cursor != null) {
cursor.close();
}
return downloadForCurrentRow;
} finally {
}
} catch (SQLiteException e) {
throw new DatabaseIOException(e);
}
}
@Override // androidx.media3.exoplayer.offline.DownloadIndex
public DownloadCursor getDownloads(int... iArr) throws DatabaseIOException {
ensureInitialized();
return new DownloadCursorImpl(getCursor(getStateQuery(iArr), null));
}
@Override // androidx.media3.exoplayer.offline.WritableDownloadIndex
public void putDownload(Download download) throws DatabaseIOException {
ensureInitialized();
try {
putDownloadInternal(download, this.databaseProvider.getWritableDatabase());
} catch (SQLiteException e) {
throw new DatabaseIOException(e);
}
}
@Override // androidx.media3.exoplayer.offline.WritableDownloadIndex
public void removeDownload(String str) throws DatabaseIOException {
ensureInitialized();
try {
this.databaseProvider.getWritableDatabase().delete(this.tableName, WHERE_ID_EQUALS, new String[]{str});
} catch (SQLiteException e) {
throw new DatabaseIOException(e);
}
}
@Override // androidx.media3.exoplayer.offline.WritableDownloadIndex
public void setDownloadingStatesToQueued() throws DatabaseIOException {
ensureInitialized();
try {
ContentValues contentValues = new ContentValues();
contentValues.put("state", (Integer) 0);
this.databaseProvider.getWritableDatabase().update(this.tableName, contentValues, WHERE_STATE_IS_DOWNLOADING, null);
} catch (SQLException e) {
throw new DatabaseIOException(e);
}
}
@Override // androidx.media3.exoplayer.offline.WritableDownloadIndex
public void setStatesToRemoving() throws DatabaseIOException {
ensureInitialized();
try {
ContentValues contentValues = new ContentValues();
contentValues.put("state", (Integer) 5);
contentValues.put(COLUMN_FAILURE_REASON, (Integer) 0);
this.databaseProvider.getWritableDatabase().update(this.tableName, contentValues, null, null);
} catch (SQLException e) {
throw new DatabaseIOException(e);
}
}
@Override // androidx.media3.exoplayer.offline.WritableDownloadIndex
public void setStopReason(int i) throws DatabaseIOException {
ensureInitialized();
try {
ContentValues contentValues = new ContentValues();
contentValues.put("stop_reason", Integer.valueOf(i));
this.databaseProvider.getWritableDatabase().update(this.tableName, contentValues, WHERE_STATE_IS_TERMINAL, null);
} catch (SQLException e) {
throw new DatabaseIOException(e);
}
}
@Override // androidx.media3.exoplayer.offline.WritableDownloadIndex
public void setStopReason(String str, int i) throws DatabaseIOException {
ensureInitialized();
try {
ContentValues contentValues = new ContentValues();
contentValues.put("stop_reason", Integer.valueOf(i));
this.databaseProvider.getWritableDatabase().update(this.tableName, contentValues, WHERE_STATE_IS_TERMINAL + " AND id = ?", new String[]{str});
} catch (SQLException e) {
throw new DatabaseIOException(e);
}
}
private void ensureInitialized() throws DatabaseIOException {
synchronized (this.initializationLock) {
if (this.initialized) {
return;
}
try {
int version = VersionTable.getVersion(this.databaseProvider.getReadableDatabase(), 0, this.name);
if (version != 3) {
SQLiteDatabase writableDatabase = this.databaseProvider.getWritableDatabase();
writableDatabase.beginTransactionNonExclusive();
try {
VersionTable.setVersion(writableDatabase, 0, this.name, 3);
List<Download> loadDownloadsFromVersion2 = version == 2 ? loadDownloadsFromVersion2(writableDatabase) : new ArrayList<>();
writableDatabase.execSQL("DROP TABLE IF EXISTS " + this.tableName);
writableDatabase.execSQL("CREATE TABLE " + this.tableName + " (id TEXT PRIMARY KEY NOT NULL,mime_type TEXT,uri TEXT NOT NULL,stream_keys TEXT NOT NULL,custom_cache_key TEXT,data BLOB NOT NULL,state INTEGER NOT NULL,start_time_ms INTEGER NOT NULL,update_time_ms INTEGER NOT NULL,content_length INTEGER NOT NULL,stop_reason INTEGER NOT NULL,failure_reason INTEGER NOT NULL,percent_downloaded REAL NOT NULL,bytes_downloaded INTEGER NOT NULL,key_set_id BLOB NOT NULL)");
Iterator<Download> it = loadDownloadsFromVersion2.iterator();
while (it.hasNext()) {
putDownloadInternal(it.next(), writableDatabase);
}
writableDatabase.setTransactionSuccessful();
writableDatabase.endTransaction();
} catch (Throwable th) {
writableDatabase.endTransaction();
throw th;
}
}
this.initialized = true;
} catch (SQLException e) {
throw new DatabaseIOException(e);
}
}
}
private void putDownloadInternal(Download download, SQLiteDatabase sQLiteDatabase) {
byte[] bArr = download.request.keySetId == null ? Util.EMPTY_BYTE_ARRAY : download.request.keySetId;
ContentValues contentValues = new ContentValues();
contentValues.put("id", download.request.id);
contentValues.put(COLUMN_MIME_TYPE, download.request.mimeType);
contentValues.put(COLUMN_URI, download.request.uri.toString());
contentValues.put(COLUMN_STREAM_KEYS, encodeStreamKeys(download.request.streamKeys));
contentValues.put(COLUMN_CUSTOM_CACHE_KEY, download.request.customCacheKey);
contentValues.put("data", download.request.data);
contentValues.put("state", Integer.valueOf(download.state));
contentValues.put(COLUMN_START_TIME_MS, Long.valueOf(download.startTimeMs));
contentValues.put(COLUMN_UPDATE_TIME_MS, Long.valueOf(download.updateTimeMs));
contentValues.put(COLUMN_CONTENT_LENGTH, Long.valueOf(download.contentLength));
contentValues.put("stop_reason", Integer.valueOf(download.stopReason));
contentValues.put(COLUMN_FAILURE_REASON, Integer.valueOf(download.failureReason));
contentValues.put(COLUMN_PERCENT_DOWNLOADED, Float.valueOf(download.getPercentDownloaded()));
contentValues.put(COLUMN_BYTES_DOWNLOADED, Long.valueOf(download.getBytesDownloaded()));
contentValues.put(COLUMN_KEY_SET_ID, bArr);
sQLiteDatabase.replaceOrThrow(this.tableName, null, contentValues);
}
private List<Download> loadDownloadsFromVersion2(SQLiteDatabase sQLiteDatabase) {
ArrayList arrayList = new ArrayList();
if (!Util.tableExists(sQLiteDatabase, this.tableName)) {
return arrayList;
}
Cursor query = sQLiteDatabase.query(this.tableName, new String[]{"id", "title", COLUMN_URI, COLUMN_STREAM_KEYS, COLUMN_CUSTOM_CACHE_KEY, "data", "state", COLUMN_START_TIME_MS, COLUMN_UPDATE_TIME_MS, COLUMN_CONTENT_LENGTH, "stop_reason", COLUMN_FAILURE_REASON, COLUMN_PERCENT_DOWNLOADED, COLUMN_BYTES_DOWNLOADED}, null, null, null, null, null);
while (query.moveToNext()) {
try {
arrayList.add(getDownloadForCurrentRowV2(query));
} finally {
}
}
if (query != null) {
query.close();
}
return arrayList;
}
private static String inferMimeType(String str) {
return "dash".equals(str) ? "application/dash+xml" : "hls".equals(str) ? "application/x-mpegURL" : "ss".equals(str) ? "application/vnd.ms-sstr+xml" : "video/x-unknown";
}
private Cursor getCursor(String str, String[] strArr) throws DatabaseIOException {
try {
return this.databaseProvider.getReadableDatabase().query(this.tableName, COLUMNS, str, strArr, null, null, "start_time_ms ASC");
} catch (SQLiteException e) {
throw new DatabaseIOException(e);
}
}
static String encodeStreamKeys(List<StreamKey> list) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < list.size(); i++) {
StreamKey streamKey = list.get(i);
sb.append(streamKey.periodIndex).append('.').append(streamKey.groupIndex).append('.').append(streamKey.streamIndex).append(',');
}
if (sb.length() > 0) {
sb.setLength(sb.length() - 1);
}
return sb.toString();
}
private static String getStateQuery(int... iArr) {
if (iArr.length == 0) {
return "1";
}
StringBuilder sb = new StringBuilder("state IN (");
for (int i = 0; i < iArr.length; i++) {
if (i > 0) {
sb.append(',');
}
sb.append(iArr[i]);
}
sb.append(')');
return sb.toString();
}
/* JADX INFO: Access modifiers changed from: private */
public static Download getDownloadForCurrentRow(Cursor cursor) {
byte[] blob = cursor.getBlob(14);
DownloadRequest.Builder streamKeys = new DownloadRequest.Builder((String) Assertions.checkNotNull(cursor.getString(0)), Uri.parse((String) Assertions.checkNotNull(cursor.getString(2)))).setMimeType(cursor.getString(1)).setStreamKeys(decodeStreamKeys(cursor.getString(3)));
if (blob.length <= 0) {
blob = null;
}
DownloadRequest build = streamKeys.setKeySetId(blob).setCustomCacheKey(cursor.getString(4)).setData(cursor.getBlob(5)).build();
DownloadProgress downloadProgress = new DownloadProgress();
downloadProgress.bytesDownloaded = cursor.getLong(13);
downloadProgress.percentDownloaded = cursor.getFloat(12);
int i = cursor.getInt(6);
return new Download(build, i, cursor.getLong(7), cursor.getLong(8), cursor.getLong(9), cursor.getInt(10), i == 4 ? cursor.getInt(11) : 0, downloadProgress);
}
private static Download getDownloadForCurrentRowV2(Cursor cursor) {
DownloadRequest build = new DownloadRequest.Builder((String) Assertions.checkNotNull(cursor.getString(0)), Uri.parse((String) Assertions.checkNotNull(cursor.getString(2)))).setMimeType(inferMimeType(cursor.getString(1))).setStreamKeys(decodeStreamKeys(cursor.getString(3))).setCustomCacheKey(cursor.getString(4)).setData(cursor.getBlob(5)).build();
DownloadProgress downloadProgress = new DownloadProgress();
downloadProgress.bytesDownloaded = cursor.getLong(13);
downloadProgress.percentDownloaded = cursor.getFloat(12);
int i = cursor.getInt(6);
return new Download(build, i, cursor.getLong(7), cursor.getLong(8), cursor.getLong(9), cursor.getInt(10), i == 4 ? cursor.getInt(11) : 0, downloadProgress);
}
private static List<StreamKey> decodeStreamKeys(String str) {
ArrayList arrayList = new ArrayList();
if (TextUtils.isEmpty(str)) {
return arrayList;
}
for (String str2 : Util.split(str, ",")) {
String[] split = Util.split(str2, "\\.");
Assertions.checkState(split.length == 3);
arrayList.add(new StreamKey(Integer.parseInt(split[0]), Integer.parseInt(split[1]), Integer.parseInt(split[2])));
}
return arrayList;
}
/* loaded from: classes2.dex */
private static final class DownloadCursorImpl implements DownloadCursor {
private final Cursor cursor;
private DownloadCursorImpl(Cursor cursor) {
this.cursor = cursor;
}
@Override // androidx.media3.exoplayer.offline.DownloadCursor
public Download getDownload() {
return DefaultDownloadIndex.getDownloadForCurrentRow(this.cursor);
}
@Override // androidx.media3.exoplayer.offline.DownloadCursor
public int getCount() {
return this.cursor.getCount();
}
@Override // androidx.media3.exoplayer.offline.DownloadCursor
public int getPosition() {
return this.cursor.getPosition();
}
@Override // androidx.media3.exoplayer.offline.DownloadCursor
public boolean moveToPosition(int i) {
return this.cursor.moveToPosition(i);
}
@Override // androidx.media3.exoplayer.offline.DownloadCursor, java.io.Closeable, java.lang.AutoCloseable
public void close() {
this.cursor.close();
}
@Override // androidx.media3.exoplayer.offline.DownloadCursor
public boolean isClosed() {
return this.cursor.isClosed();
}
}
}