aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorRenjaya Raga Zenta <ragazenta@gmail.com>2024-11-21 15:18:53 +0700
committerRenjaya Raga Zenta <ragazenta@gmail.com>2024-11-23 05:51:12 +0700
commit4c1bf42192db26aa455d94b65d2b9d638720f60b (patch)
treec73c1264920e2aa6e8ad06eae37e578f65ccb232 /src
parent906c8708fd53880d998c595ccd39ab9f08866457 (diff)
downloadgarage-4c1bf42192db26aa455d94b65d2b9d638720f60b.tar.gz
garage-4c1bf42192db26aa455d94b65d2b9d638720f60b.zip
feat: add use_local_tz configuration
Used in lifecycle_worker to determine midnight time
Diffstat (limited to 'src')
-rw-r--r--src/model/s3/lifecycle_worker.rs26
-rw-r--r--src/util/config.rs4
2 files changed, 22 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()
}
diff --git a/src/util/config.rs b/src/util/config.rs
index 59329c0b..a24db84e 100644
--- a/src/util/config.rs
+++ b/src/util/config.rs
@@ -27,6 +27,10 @@ pub struct Config {
#[serde(default)]
pub disable_scrub: bool,
+ /// Use local timezone
+ #[serde(default)]
+ pub use_local_tz: bool,
+
/// Automatic snapshot interval for metadata
#[serde(default)]
pub metadata_auto_snapshot_interval: Option<String>,