From 63c592f7cd897caf918fd3bd5f129c72432d2b55 Mon Sep 17 00:00:00 2001 From: Olivier Bouillet <62574056+freeboub@users.noreply.github.com> Date: Sun, 1 Dec 2024 13:29:24 +0100 Subject: [PATCH] fix(android): disable caching on local asset files (#4304) --- .../main/java/com/brentvatne/common/api/Source.kt | 12 ++++++++++++ .../com/brentvatne/exoplayer/ReactExoplayerView.java | 4 ++-- examples/expo/package.json | 2 ++ src/Video.tsx | 6 ++++++ src/specs/VideoNativeComponent.ts | 1 + src/types/video.ts | 1 + 6 files changed, 24 insertions(+), 2 deletions(-) diff --git a/android/src/main/java/com/brentvatne/common/api/Source.kt b/android/src/main/java/com/brentvatne/common/api/Source.kt index 2d5ede07..a0e0cfea 100644 --- a/android/src/main/java/com/brentvatne/common/api/Source.kt +++ b/android/src/main/java/com/brentvatne/common/api/Source.kt @@ -30,6 +30,12 @@ class Source { /** Parsed value of source to playback */ var uri: Uri? = null + /** True if source is a local JS asset */ + var isLocalAssetFile: Boolean = false + + /** True if source is a local file asset://, ... */ + var isAsset: Boolean = false + /** Start position of playback used to resume playback */ var startPositionMs: Int = -1 @@ -101,6 +107,8 @@ class Source { sideLoadedTextTracks == other.sideLoadedTextTracks && adsProps == other.adsProps && minLoadRetryCount == other.minLoadRetryCount && + isLocalAssetFile == other.isLocalAssetFile && + isAsset == other.isAsset && bufferConfig == other.bufferConfig ) } @@ -157,6 +165,8 @@ class Source { companion object { private const val TAG = "Source" private const val PROP_SRC_URI = "uri" + private const val PROP_SRC_IS_LOCAL_ASSET_FILE = "isLocalAssetFile" + private const val PROP_SRC_IS_ASSET = "isAsset" private const val PROP_SRC_START_POSITION = "startPosition" private const val PROP_SRC_CROP_START = "cropStart" private const val PROP_SRC_CROP_END = "cropEnd" @@ -223,6 +233,8 @@ class Source { } source.uriString = uriString source.uri = uri + source.isLocalAssetFile = safeGetBool(src, PROP_SRC_IS_LOCAL_ASSET_FILE, false) + source.isAsset = safeGetBool(src, PROP_SRC_IS_ASSET, false) source.startPositionMs = safeGetInt(src, PROP_SRC_START_POSITION, -1) source.cropStartMs = safeGetInt(src, PROP_SRC_CROP_START, -1) source.cropEndMs = safeGetInt(src, PROP_SRC_CROP_END, -1) diff --git a/android/src/main/java/com/brentvatne/exoplayer/ReactExoplayerView.java b/android/src/main/java/com/brentvatne/exoplayer/ReactExoplayerView.java index c6d52c7c..935f8844 100644 --- a/android/src/main/java/com/brentvatne/exoplayer/ReactExoplayerView.java +++ b/android/src/main/java/com/brentvatne/exoplayer/ReactExoplayerView.java @@ -747,7 +747,7 @@ public class ReactExoplayerView extends FrameLayout implements // Initialize core configuration and listeners initializePlayerCore(self); } - if (source.getBufferConfig().getCacheSize() > 0) { + if (!source.isLocalAssetFile() && !source.isAsset() && source.getBufferConfig().getCacheSize() > 0) { RNVSimpleCache.INSTANCE.setSimpleCache( this.getContext(), source.getBufferConfig().getCacheSize() @@ -1186,7 +1186,7 @@ public class ReactExoplayerView extends FrameLayout implements DataSource.Factory assetDataSourceFactory = DataSourceUtil.buildAssetDataSourceFactory(themedReactContext, uri); mediaSourceFactory = new ProgressiveMediaSource.Factory(assetDataSourceFactory); } catch (Exception e) { - throw new IllegalStateException("cannot open input file" + uri); + throw new IllegalStateException("cannot open input file:" + uri); } } else if ("file".equals(uri.getScheme()) || !useCache) { diff --git a/examples/expo/package.json b/examples/expo/package.json index 230a5682..faa6f2ff 100644 --- a/examples/expo/package.json +++ b/examples/expo/package.json @@ -7,6 +7,8 @@ "start:tv": "EXPO_TV=1 expo start", "android:tv": "EXPO_TV=1 expo run:android", "android": "EXPO_TV=0 expo run:android", + "release:android": "cd android && EXPO_TV=0 ./gradlew assembleRelease && cd -", + "release:android:tv": "cd android && EXPO_TV=1 ./gradlew assembleRelease && cd -", "ios:tv": "EXPO_TV=1 expo run:ios", "ios": "EXPO_TV=0 expo run:ios", "web": "expo start --web", diff --git a/src/Video.tsx b/src/Video.tsx index 0aaa1199..45c755c5 100644 --- a/src/Video.tsx +++ b/src/Video.tsx @@ -151,6 +151,11 @@ const Video = forwardRef( if (!_source) { return undefined; } + + const isLocalAssetFile = + typeof _source === 'number' || + ('uri' in _source && typeof _source.uri === 'number'); + const resolvedSource = resolveAssetSourceForVideo(_source); let uri = resolvedSource.uri || ''; if (uri && uri.match(/^\//)) { @@ -226,6 +231,7 @@ const Video = forwardRef( uri, isNetwork, isAsset, + isLocalAssetFile, shouldCache: resolvedSource.shouldCache || false, type: resolvedSource.type || '', mainVer: resolvedSource.mainVer || 0, diff --git a/src/specs/VideoNativeComponent.ts b/src/specs/VideoNativeComponent.ts index d434d585..fdd9c7e5 100644 --- a/src/specs/VideoNativeComponent.ts +++ b/src/specs/VideoNativeComponent.ts @@ -35,6 +35,7 @@ export type VideoSrc = Readonly<{ uri?: string; isNetwork?: boolean; isAsset?: boolean; + isLocalAssetFile?: boolean; shouldCache?: boolean; type?: string; mainVer?: Int32; diff --git a/src/types/video.ts b/src/types/video.ts index 6a213d1d..5dab4ec9 100644 --- a/src/types/video.ts +++ b/src/types/video.ts @@ -24,6 +24,7 @@ export type ReactVideoSourceProperties = { uri?: string; isNetwork?: boolean; isAsset?: boolean; + isLocalAssetFile?: boolean; shouldCache?: boolean; type?: string; mainVer?: number;