1
0
mirror of https://github.com/TeamNewPipe/NewPipe synced 2025-01-11 09:50:32 +00:00

Save the fetched duration to the database so that it can render the view correctly.

This commit is contained in:
Nathan Schulzke 2021-07-29 20:59:23 -06:00
parent bdd16e06e0
commit 0e12cdea7c

View File

@ -101,31 +101,31 @@ public class HistoryRecordManager {
final OffsetDateTime currentTime = OffsetDateTime.now(ZoneOffset.UTC); final OffsetDateTime currentTime = OffsetDateTime.now(ZoneOffset.UTC);
return Maybe.fromCallable(() -> database.runInTransaction(() -> { return Maybe.fromCallable(() -> database.runInTransaction(() -> {
final long streamId = streamTable.upsert(new StreamEntity(info));
long duration = info.getDuration();
// Duration will not exist if the item was loaded with fast mode, so fetch it if empty // Duration will not exist if the item was loaded with fast mode, so fetch it if empty
if (duration < 0) { if (info.getDuration() < 0) {
duration = ExtractorHelper.getStreamInfo( final long duration = ExtractorHelper.getStreamInfo(
info.getServiceId(), info.getServiceId(),
info.getUrl(), info.getUrl(),
false) false)
.subscribeOn(Schedulers.io()) .subscribeOn(Schedulers.io())
.blockingGet() .blockingGet()
.getDuration(); .getDuration();
info.setDuration(duration);
} }
// Upsert to get a stream ID and update durations if we fetched one
final long streamId = streamTable.upsert(new StreamEntity(info));
// Update the stream progress to the full duration of the video // Update the stream progress to the full duration of the video
final List<StreamStateEntity> states = streamStateTable.getState(streamId) final List<StreamStateEntity> states = streamStateTable.getState(streamId)
.blockingFirst(); .blockingFirst();
if (!states.isEmpty()) { if (!states.isEmpty()) {
final StreamStateEntity entity = states.get(0); final StreamStateEntity entity = states.get(0);
entity.setProgressMillis(duration * 1000); entity.setProgressMillis(info.getDuration() * 1000);
streamStateTable.update(entity); streamStateTable.update(entity);
} else { } else {
final StreamStateEntity entity = new StreamStateEntity( final StreamStateEntity entity = new StreamStateEntity(
streamId, streamId,
duration * 1000 info.getDuration() * 1000
); );
streamStateTable.insert(entity); streamStateTable.insert(entity);
} }