From 69146fb318641a212981de051451a06cba734273 Mon Sep 17 00:00:00 2001 From: Max Brunsfeld Date: Fri, 15 Jul 2022 16:30:13 -0700 Subject: [PATCH] Allow the web client to specify activity bucket durations --- crates/collab/src/api.rs | 22 +++++++++++++++++----- 1 file changed, 17 insertions(+), 5 deletions(-) diff --git a/crates/collab/src/api.rs b/crates/collab/src/api.rs index 6ecb43f7fd..5cc8b58cfb 100644 --- a/crates/collab/src/api.rs +++ b/crates/collab/src/api.rs @@ -299,6 +299,13 @@ async fn get_user_activity_timeline( Ok(ErasedJson::pretty(summary)) } +#[derive(Deserialize)] +struct ActiveUserCountParams { + #[serde(flatten)] + period: TimePeriodParams, + durations_in_minutes: String, +} + #[derive(Serialize)] struct ActiveUserSet { active_time_in_minutes: u64, @@ -306,18 +313,23 @@ struct ActiveUserSet { } async fn get_active_user_counts( - Query(params): Query, + Query(params): Query, Extension(app): Extension>, ) -> Result { - let durations_in_minutes = [10, 60, 4 * 60, 8 * 60]; - - let mut user_sets = Vec::with_capacity(durations_in_minutes.len()); + let durations_in_minutes = params.durations_in_minutes.split(','); + let mut user_sets = Vec::new(); for duration in durations_in_minutes { + let duration = duration + .parse() + .map_err(|_| anyhow!("invalid duration: {duration}"))?; user_sets.push(ActiveUserSet { active_time_in_minutes: duration, user_count: app .db - .get_active_user_count(params.start..params.end, Duration::from_secs(duration * 60)) + .get_active_user_count( + params.period.start..params.period.end, + Duration::from_secs(duration * 60), + ) .await?, }) }