From b3d190f1d409ea0f55d7666e845c2a3e3bb34707 Mon Sep 17 00:00:00 2001 From: Inbal Vasserman Date: Sun, 2 Jun 2024 15:01:55 +0300 Subject: [PATCH 1/3] fix(SUP-38389):Offline download DRM issues --- .../com/kaltura/tvplayer/offline/dtg/DTGOfflineManager.java | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/tvplayer/src/main/java/com/kaltura/tvplayer/offline/dtg/DTGOfflineManager.java b/tvplayer/src/main/java/com/kaltura/tvplayer/offline/dtg/DTGOfflineManager.java index 6117981d..40ddc148 100644 --- a/tvplayer/src/main/java/com/kaltura/tvplayer/offline/dtg/DTGOfflineManager.java +++ b/tvplayer/src/main/java/com/kaltura/tvplayer/offline/dtg/DTGOfflineManager.java @@ -65,7 +65,7 @@ public void onDownloadStart(DownloadItem item) { postEvent(() -> getListener().onStateChanged(assetId, DownloadType.FULL, new DTGAssetInfo(item, AssetDownloadState.started))); - postEventDelayed(() -> registerDrmAsset(assetId, true), 4000); + postEventDelayed(() -> registerDrmAsset(assetId, true), 7000); } @Override @@ -289,6 +289,7 @@ private void registerDrmAsset(String assetId, boolean allowFileNotFound) { } try { + //todo: ad change here? final byte[] widevineInitData = getWidevineInitData(localFile); lam.registerWidevineAsset(assetId, getAssetFormat(assetId), licenseUri, widevineInitData, forceWidevineL3Playback); postEvent(() -> getListener().onRegistered(assetId, getDrmStatus(assetId, widevineInitData))); From 06f4d8a8a78642c73aaa8984058b15d6e8a204a1 Mon Sep 17 00:00:00 2001 From: Inbal Vasserman Date: Sun, 2 Jun 2024 15:07:24 +0300 Subject: [PATCH 2/3] remove un-needed notes --- .../java/com/kaltura/tvplayer/offline/dtg/DTGOfflineManager.java | 1 - 1 file changed, 1 deletion(-) diff --git a/tvplayer/src/main/java/com/kaltura/tvplayer/offline/dtg/DTGOfflineManager.java b/tvplayer/src/main/java/com/kaltura/tvplayer/offline/dtg/DTGOfflineManager.java index 40ddc148..8f4c0d9f 100644 --- a/tvplayer/src/main/java/com/kaltura/tvplayer/offline/dtg/DTGOfflineManager.java +++ b/tvplayer/src/main/java/com/kaltura/tvplayer/offline/dtg/DTGOfflineManager.java @@ -289,7 +289,6 @@ private void registerDrmAsset(String assetId, boolean allowFileNotFound) { } try { - //todo: ad change here? final byte[] widevineInitData = getWidevineInitData(localFile); lam.registerWidevineAsset(assetId, getAssetFormat(assetId), licenseUri, widevineInitData, forceWidevineL3Playback); postEvent(() -> getListener().onRegistered(assetId, getDrmStatus(assetId, widevineInitData))); From 6b0ab15c92caff3b8aeed6d4f3eea830538397ef Mon Sep 17 00:00:00 2001 From: volodymyr-bondarenko85 <131799099+volodymyr-bondarenko85@users.noreply.github.com> Date: Mon, 3 Jun 2024 13:55:54 +0300 Subject: [PATCH 3/3] Codec failure retry timeout logic (#178) --- .../src/main/java/com/kaltura/tvplayer/KalturaPlayer.java | 6 ++++++ .../main/java/com/kaltura/tvplayer/PlayerInitOptions.java | 3 ++- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/tvplayer/src/main/java/com/kaltura/tvplayer/KalturaPlayer.java b/tvplayer/src/main/java/com/kaltura/tvplayer/KalturaPlayer.java index 3e6ee961..797ce4a8 100644 --- a/tvplayer/src/main/java/com/kaltura/tvplayer/KalturaPlayer.java +++ b/tvplayer/src/main/java/com/kaltura/tvplayer/KalturaPlayer.java @@ -434,6 +434,12 @@ private void updatePlayerSettings() { if (initOptions.shutterStaysOnRenderedFirstFrame != null) { pkPlayer.getSettings().setShutterStaysOnRenderedFirstFrame(initOptions.shutterStaysOnRenderedFirstFrame); } + if (initOptions.codecFailureRetryCount != null) { + pkPlayer.getSettings().setCodecFailureRetryCount(initOptions.codecFailureRetryCount); + } + if (initOptions.codecFailureRetryTimeout != null) { + pkPlayer.getSettings().setCodecFailureRetryTimeout(initOptions.codecFailureRetryTimeout); + } } @NonNull diff --git a/tvplayer/src/main/java/com/kaltura/tvplayer/PlayerInitOptions.java b/tvplayer/src/main/java/com/kaltura/tvplayer/PlayerInitOptions.java index c8d0d7cc..88d9c581 100644 --- a/tvplayer/src/main/java/com/kaltura/tvplayer/PlayerInitOptions.java +++ b/tvplayer/src/main/java/com/kaltura/tvplayer/PlayerInitOptions.java @@ -74,8 +74,9 @@ public class PlayerInitOptions { public Integer maxAudioBitrate; public Integer maxAudioChannelCount; public MulticastSettings multicastSettings; - public Boolean shutterStaysOnRenderedFirstFrame; + public Integer codecFailureRetryCount; + public Integer codecFailureRetryTimeout; public MediaEntryCacheConfig mediaEntryCacheConfig; public OfflineManager.OfflineProvider offlineProvider = OfflineManager.OfflineProvider.DTG;