diff --git a/src/main/kotlin/dev/usbharu/hideout/service/post/PostServiceImpl.kt b/src/main/kotlin/dev/usbharu/hideout/service/post/PostServiceImpl.kt index 5b376c68..f4d36084 100644 --- a/src/main/kotlin/dev/usbharu/hideout/service/post/PostServiceImpl.kt +++ b/src/main/kotlin/dev/usbharu/hideout/service/post/PostServiceImpl.kt @@ -6,6 +6,7 @@ import dev.usbharu.hideout.exception.UserNotFoundException import dev.usbharu.hideout.query.PostQueryService import dev.usbharu.hideout.repository.PostRepository import dev.usbharu.hideout.repository.UserRepository +import org.jetbrains.exposed.exceptions.ExposedSQLException import org.springframework.stereotype.Service import java.time.Instant import java.util.* @@ -34,7 +35,7 @@ class PostServiceImpl( private suspend fun internalCreate(post: Post, isLocal: Boolean): Post { val save = try { postRepository.save(post) - } catch (e: Exception) { + } catch (e: ExposedSQLException) { postQueryService.findByApId(post.apId) } timelineService.publishTimeline(save, isLocal) diff --git a/src/main/kotlin/dev/usbharu/hideout/service/reaction/ReactionServiceImpl.kt b/src/main/kotlin/dev/usbharu/hideout/service/reaction/ReactionServiceImpl.kt index 07519bcc..6e56143f 100644 --- a/src/main/kotlin/dev/usbharu/hideout/service/reaction/ReactionServiceImpl.kt +++ b/src/main/kotlin/dev/usbharu/hideout/service/reaction/ReactionServiceImpl.kt @@ -4,6 +4,7 @@ import dev.usbharu.hideout.domain.model.hideout.entity.Reaction import dev.usbharu.hideout.query.ReactionQueryService import dev.usbharu.hideout.repository.ReactionRepository import dev.usbharu.hideout.service.ap.APReactionService +import org.jetbrains.exposed.exceptions.ExposedSQLException import org.slf4j.LoggerFactory import org.springframework.stereotype.Service @@ -20,8 +21,9 @@ class ReactionServiceImpl( reactionRepository.save( Reaction(reactionRepository.generateId(), 0, postId, userId) ) - } catch (_: Exception) { + } catch (e: ExposedSQLException) { LOGGER.warn("FAILED Failure to persist reaction information.") + LOGGER.debug("FAILED", e) } } } diff --git a/src/main/kotlin/dev/usbharu/hideout/service/user/UserServiceImpl.kt b/src/main/kotlin/dev/usbharu/hideout/service/user/UserServiceImpl.kt index 474fa736..2af93ed6 100644 --- a/src/main/kotlin/dev/usbharu/hideout/service/user/UserServiceImpl.kt +++ b/src/main/kotlin/dev/usbharu/hideout/service/user/UserServiceImpl.kt @@ -10,6 +10,7 @@ import dev.usbharu.hideout.query.FollowerQueryService import dev.usbharu.hideout.query.UserQueryService import dev.usbharu.hideout.repository.UserRepository import dev.usbharu.hideout.service.ap.APSendFollowService +import org.jetbrains.exposed.exceptions.ExposedSQLException import org.springframework.stereotype.Service import java.time.Instant @@ -66,7 +67,7 @@ class UserServiceImpl( ) return try { userRepository.save(userEntity) - } catch (e: Exception) { + } catch (e: ExposedSQLException) { userQueryService.findByUrl(user.url) } }