aboutsummaryrefslogtreecommitdiff
path: root/src/model/s3/lifecycle_worker.rs
diff options
context:
space:
mode:
authormaximilien <me@mricher.fr>2024-12-01 13:23:24 +0000
committermaximilien <me@mricher.fr>2024-12-01 13:23:24 +0000
commit3661a597fa40e6396049e4dd9fef50c14fa9e9d9 (patch)
treeb48aa0763a6d99902011b1058bf5e3273ab69d49 /src/model/s3/lifecycle_worker.rs
parent906c8708fd53880d998c595ccd39ab9f08866457 (diff)
parent0fd3c0e794e7b77548c4ed1c5074b299c5a5b374 (diff)
downloadgarage-3661a597fa40e6396049e4dd9fef50c14fa9e9d9.tar.gz
garage-3661a597fa40e6396049e4dd9fef50c14fa9e9d9.zip
Merge pull request 'feat: add use_local_tz configuration' (#908) from ragazenta/garage:feat/local-timezone into main
Reviewed-on: https://git.deuxfleurs.fr/Deuxfleurs/garage/pulls/908 Reviewed-by: maximilien <me@mricher.fr>
Diffstat (limited to 'src/model/s3/lifecycle_worker.rs')
-rw-r--r--src/model/s3/lifecycle_worker.rs26
1 files changed, 18 insertions, 8 deletions
diff --git a/src/model/s3/lifecycle_worker.rs b/src/model/s3/lifecycle_worker.rs
index 9ecf168c..38212a1c 100644
--- a/src/model/s3/lifecycle_worker.rs
+++ b/src/model/s3/lifecycle_worker.rs
@@ -70,7 +70,7 @@ pub fn register_bg_vars(
impl LifecycleWorker {
pub fn new(garage: Arc<Garage>, persister: PersisterShared<LifecycleWorkerPersisted>) -> Self {
- let today = today();
+ let today = today(garage.config.use_local_tz);
let last_completed = persister.get_with(|x| {
x.last_completed
.as_deref()
@@ -205,8 +205,9 @@ impl Worker for LifecycleWorker {
async fn wait_for_work(&mut self) -> WorkerState {
match &self.state {
State::Completed(d) => {
+ let use_local_tz = self.garage.config.use_local_tz;
let next_day = d.succ_opt().expect("no next day");
- let next_start = midnight_ts(next_day);
+ let next_start = midnight_ts(next_day, use_local_tz);
loop {
let now = now_msec();
if now < next_start {
@@ -218,7 +219,7 @@ impl Worker for LifecycleWorker {
break;
}
}
- self.state = State::start(std::cmp::max(next_day, today()));
+ self.state = State::start(std::cmp::max(next_day, today(use_local_tz)));
}
State::Running { .. } => (),
}
@@ -385,10 +386,16 @@ fn check_size_filter(version_data: &ObjectVersionData, filter: &LifecycleFilter)
true
}
-fn midnight_ts(date: NaiveDate) -> u64 {
- date.and_hms_opt(0, 0, 0)
- .expect("midnight does not exist")
- .timestamp_millis() as u64
+fn midnight_ts(date: NaiveDate, use_local_tz: bool) -> u64 {
+ let midnight = date.and_hms_opt(0, 0, 0).expect("midnight does not exist");
+ if use_local_tz {
+ return midnight
+ .and_local_timezone(Local)
+ .single()
+ .expect("bad local midnight")
+ .timestamp_millis() as u64;
+ }
+ midnight.timestamp_millis() as u64
}
fn next_date(ts: u64) -> NaiveDate {
@@ -399,6 +406,9 @@ fn next_date(ts: u64) -> NaiveDate {
.expect("no next day")
}
-fn today() -> NaiveDate {
+fn today(use_local_tz: bool) -> NaiveDate {
+ if use_local_tz {
+ return Local::now().naive_local().date();
+ }
Utc::now().naive_utc().date()
}