From a6c8f2bc3b78c556106e879d037f2a001306aae5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christian=20Kleinb=C3=B6lting?= Date: Thu, 12 Dec 2024 09:17:34 +0100 Subject: [PATCH] fix: Dummy filenames may not contain a file extension, remove it only if it exists (DEV-4227) (#3442) --- .../v2/responder/valuemessages/ValueMessagesV2.scala | 2 +- .../slice/admin/api/model/MaintenanceRequests.scala | 9 ++++++++- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/webapi/src/main/scala/org/knora/webapi/messages/v2/responder/valuemessages/ValueMessagesV2.scala b/webapi/src/main/scala/org/knora/webapi/messages/v2/responder/valuemessages/ValueMessagesV2.scala index 9d74c5e028..066bcb7d2d 100644 --- a/webapi/src/main/scala/org/knora/webapi/messages/v2/responder/valuemessages/ValueMessagesV2.scala +++ b/webapi/src/main/scala/org/knora/webapi/messages/v2/responder/valuemessages/ValueMessagesV2.scala @@ -713,7 +713,7 @@ object ValueContentV2 { for { sipiService <- ZIO.service[SipiService] assetId <- ZIO - .fromEither(AssetId.from(filename.substring(0, filename.indexOf('.')))) + .fromEither(AssetId.fromFilename(filename)) .mapError(msg => BadRequestException(s"Invalid value for 'fileValueHasFilename': $msg")) meta <- sipiService.getFileMetadataFromDspIngest(shortcode, assetId).mapError { case NotFoundException(_) => diff --git a/webapi/src/main/scala/org/knora/webapi/slice/admin/api/model/MaintenanceRequests.scala b/webapi/src/main/scala/org/knora/webapi/slice/admin/api/model/MaintenanceRequests.scala index 28ce82bdfa..73ff481e28 100644 --- a/webapi/src/main/scala/org/knora/webapi/slice/admin/api/model/MaintenanceRequests.scala +++ b/webapi/src/main/scala/org/knora/webapi/slice/admin/api/model/MaintenanceRequests.scala @@ -21,7 +21,14 @@ import org.knora.webapi.slice.admin.domain.model.KnoraProject.Shortcode object MaintenanceRequests { type AssetId = String Refined MatchesRegex["^[a-zA-Z0-9-_]{4,}$"] - object AssetId extends RefinedTypeOps[AssetId, String] + object AssetId extends RefinedTypeOps[AssetId, String] { + + def fromFilename(filename: String): Either[String, AssetId] = { + val withoutFileExtension = + if filename.contains(".") then filename.substring(0, filename.indexOf('.')) else filename + AssetId.from(withoutFileExtension) + } + } final case class Dimensions(width: Int Refined Positive, height: Int Refined Positive)