From 5058f40e0db10db626e97d9793708b1375c08639 Mon Sep 17 00:00:00 2001 From: Diger Date: Sat, 21 Sep 2024 15:56:35 +0900 Subject: [PATCH 1/2] fix: Avocado ShareURL Bug --- .../web/avocado/parser/AvocadoOriginMapIdParser.kt | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/piikii-output-web/avocado/src/main/kotlin/com/piikii/output/web/avocado/parser/AvocadoOriginMapIdParser.kt b/piikii-output-web/avocado/src/main/kotlin/com/piikii/output/web/avocado/parser/AvocadoOriginMapIdParser.kt index 1d31ad95..4621590b 100644 --- a/piikii-output-web/avocado/src/main/kotlin/com/piikii/output/web/avocado/parser/AvocadoOriginMapIdParser.kt +++ b/piikii-output-web/avocado/src/main/kotlin/com/piikii/output/web/avocado/parser/AvocadoOriginMapIdParser.kt @@ -59,7 +59,12 @@ class ShareUrlIdParser( properties: AvocadoProperties, ) : AvocadoOriginMapIdParser { private val regex: Regex = properties.url.regex.share.toRegex() - private val idParameterRegex: Regex = "id=(\\d+)".toRegex() + private val operateRegexList: List = + mutableListOf( + "place/(\\d+)".toRegex(), + "id=(\\d+)".toRegex(), + ) + private val client: RestClient = RestClient.builder().build() override fun getParserBySupportedUrl(url: String): AvocadoOriginMapIdParser? = takeIf { regex.matches(url) } @@ -70,8 +75,10 @@ class ShareUrlIdParser( .retrieve() .toEntity(Map::class.java) if (response.statusCode.is3xxRedirection && response.headers.location != null) { - return idParameterRegex.find(response.headers.location.toString()) - .parseFromMatchResult() + return operateRegexList.firstNotNullOfOrNull { regex -> + regex.find(response.headers.location.toString()) + ?.groupValues?.getOrNull(1)?.let { OriginMapId(it) } + } } return null } From 7c8a84f9680be9d08942e592e3b290eb945ce4e5 Mon Sep 17 00:00:00 2001 From: Diger Date: Sat, 21 Sep 2024 15:59:58 +0900 Subject: [PATCH 2/2] style: regexList naming --- .../output/web/avocado/parser/AvocadoOriginMapIdParser.kt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/piikii-output-web/avocado/src/main/kotlin/com/piikii/output/web/avocado/parser/AvocadoOriginMapIdParser.kt b/piikii-output-web/avocado/src/main/kotlin/com/piikii/output/web/avocado/parser/AvocadoOriginMapIdParser.kt index 4621590b..87633911 100644 --- a/piikii-output-web/avocado/src/main/kotlin/com/piikii/output/web/avocado/parser/AvocadoOriginMapIdParser.kt +++ b/piikii-output-web/avocado/src/main/kotlin/com/piikii/output/web/avocado/parser/AvocadoOriginMapIdParser.kt @@ -59,7 +59,7 @@ class ShareUrlIdParser( properties: AvocadoProperties, ) : AvocadoOriginMapIdParser { private val regex: Regex = properties.url.regex.share.toRegex() - private val operateRegexList: List = + private val mapIdRegexList: List = mutableListOf( "place/(\\d+)".toRegex(), "id=(\\d+)".toRegex(), @@ -75,7 +75,7 @@ class ShareUrlIdParser( .retrieve() .toEntity(Map::class.java) if (response.statusCode.is3xxRedirection && response.headers.location != null) { - return operateRegexList.firstNotNullOfOrNull { regex -> + return mapIdRegexList.firstNotNullOfOrNull { regex -> regex.find(response.headers.location.toString()) ?.groupValues?.getOrNull(1)?.let { OriginMapId(it) } }