From 06797b9b31dc049b098e91adf04f1a1a970ee37b Mon Sep 17 00:00:00 2001 From: Dani Palou Date: Thu, 17 Feb 2022 10:29:01 +0100 Subject: [PATCH] MOBILE-3799 filepool: Fix regression when checking outdated files --- src/core/services/filepool.ts | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/src/core/services/filepool.ts b/src/core/services/filepool.ts index 49d639d12..30d857010 100644 --- a/src/core/services/filepool.ts +++ b/src/core/services/filepool.ts @@ -383,7 +383,7 @@ export class CoreFilepoolProvider { if (!alreadyFixed) { // Fix the URL and use the fixed data. - const file = await this.fixPluginfileURL(siteId, fileUrl); + const file = await this.fixPluginfileURL(siteId, fileUrl, timemodified); fileUrl = CoreFileHelper.getFileUrl(file); timemodified = file.timemodified ?? timemodified; @@ -1030,11 +1030,11 @@ export class CoreFilepoolProvider { throw new CoreError('File system cannot be used.'); } - const file = await this.fixPluginfileURL(siteId, fileUrl); + const file = await this.fixPluginfileURL(siteId, fileUrl, timemodified); fileUrl = CoreFileHelper.getFileUrl(file); options = Object.assign({}, options); // Create a copy to prevent modifying the original object. - options.timemodified = file.timemodified ?? timemodified ?? 0; + options.timemodified = file.timemodified ?? timemodified; options.revision = revision ?? this.getRevisionFromUrl(fileUrl); const fileId = this.getFileIdByUrl(fileUrl); @@ -2340,10 +2340,12 @@ export class CoreFilepoolProvider { * @param timemodified The time this file was modified. * @param Whether the file is outdated. */ - protected isFileOutdated(entry: CoreFilepoolFileEntry, revision?: number, timemodified?: number): boolean { - return !!entry.stale || - (revision !== undefined && (entry.revision === undefined || revision > entry.revision)) || - (timemodified !== undefined && (entry.timemodified === undefined || timemodified > entry.timemodified)); + protected isFileOutdated(entry: CoreFilepoolFileEntry, revision = 0, timemodified = 0): boolean { + // Don't allow undefined values, convert them to 0. + const entryTimemodified = entry.timemodified ?? 0; + const entryRevision = entry.revision ?? 0; + + return !!entry.stale || revision > entryRevision || timemodified > entryTimemodified; } /** @@ -2565,8 +2567,8 @@ export class CoreFilepoolProvider { const fileId = item.fileId; const fileUrl = item.url; const options = { - revision: item.revision ?? undefined, - timemodified: item.timemodified ?? undefined, + revision: item.revision ?? 0, + timemodified: item.timemodified ?? 0, isexternalfile: item.isexternalfile ?? undefined, repositorytype: item.repositorytype ?? undefined, };