From f0e8ba6565d15697cc07c30de82989a7bb2412a2 Mon Sep 17 00:00:00 2001 From: Yang Date: Sat, 25 Nov 2023 22:03:14 +1100 Subject: [PATCH] Scheduled cache refresh. --- .../backend/KSBackendApplication.kt | 2 ++ .../scheduling/ScheduledCacheRefresh.kt | 21 +++++++++++++++++++ 2 files changed, 23 insertions(+) create mode 100644 src/main/kotlin/io/github/reactivecircus/kstreamlined/backend/scheduling/ScheduledCacheRefresh.kt diff --git a/src/main/kotlin/io/github/reactivecircus/kstreamlined/backend/KSBackendApplication.kt b/src/main/kotlin/io/github/reactivecircus/kstreamlined/backend/KSBackendApplication.kt index b581aa2..ca38927 100644 --- a/src/main/kotlin/io/github/reactivecircus/kstreamlined/backend/KSBackendApplication.kt +++ b/src/main/kotlin/io/github/reactivecircus/kstreamlined/backend/KSBackendApplication.kt @@ -2,8 +2,10 @@ package io.github.reactivecircus.kstreamlined.backend import org.springframework.boot.autoconfigure.SpringBootApplication import org.springframework.boot.runApplication +import org.springframework.scheduling.annotation.EnableScheduling @SpringBootApplication +@EnableScheduling class KSBackendApplication fun main(args: Array) { diff --git a/src/main/kotlin/io/github/reactivecircus/kstreamlined/backend/scheduling/ScheduledCacheRefresh.kt b/src/main/kotlin/io/github/reactivecircus/kstreamlined/backend/scheduling/ScheduledCacheRefresh.kt new file mode 100644 index 0000000..9de2fdd --- /dev/null +++ b/src/main/kotlin/io/github/reactivecircus/kstreamlined/backend/scheduling/ScheduledCacheRefresh.kt @@ -0,0 +1,21 @@ +package io.github.reactivecircus.kstreamlined.backend.scheduling + +import io.github.reactivecircus.kstreamlined.backend.datafetcher.FeedEntryDataFetcher +import io.github.reactivecircus.kstreamlined.backend.schema.generated.types.FeedSourceKey +import kotlinx.coroutines.runBlocking +import org.springframework.beans.factory.annotation.Autowired +import org.springframework.scheduling.annotation.Scheduled +import org.springframework.stereotype.Component +import java.util.concurrent.TimeUnit + +@Component +class ScheduledCacheRefresh { + + @Autowired + private lateinit var feedEntryDataFetcher: FeedEntryDataFetcher + + @Scheduled(fixedDelay = 1, timeUnit = TimeUnit.HOURS) + fun refreshFeedEntryCache() = runBlocking { + feedEntryDataFetcher.feedEntries(FeedSourceKey.entries) + } +}