aboutsummaryrefslogtreecommitdiff
path: root/src/jobs/weekly_report.rs
diff options
context:
space:
mode:
authorJoris2021-01-03 13:40:40 +0100
committerJoris2021-01-03 13:54:20 +0100
commit11052951b74b9ad4b6a9412ae490086235f9154b (patch)
tree64526ac926c1bf470ea113f6cac8a33158684e8d /src/jobs/weekly_report.rs
parent371449b0e312a03162b78797b83dee9d81706669 (diff)
downloadbudget-11052951b74b9ad4b6a9412ae490086235f9154b.tar.gz
budget-11052951b74b9ad4b6a9412ae490086235f9154b.tar.bz2
budget-11052951b74b9ad4b6a9412ae490086235f9154b.zip
Rewrite in Rust
Diffstat (limited to 'src/jobs/weekly_report.rs')
-rw-r--r--src/jobs/weekly_report.rs55
1 files changed, 55 insertions, 0 deletions
diff --git a/src/jobs/weekly_report.rs b/src/jobs/weekly_report.rs
new file mode 100644
index 0000000..819d30b
--- /dev/null
+++ b/src/jobs/weekly_report.rs
@@ -0,0 +1,55 @@
+use sqlx::sqlite::SqlitePool;
+use std::collections::HashMap;
+use tera::{Context, Tera};
+
+use crate::db;
+use crate::mail;
+use crate::model::config::Config;
+use crate::payer;
+
+pub async fn send(
+ config: &Config,
+ pool: &SqlitePool,
+ templates: &Tera,
+) -> bool {
+ match get_weekly_report(pool, templates).await {
+ Ok(report) => {
+ let users = db::users::list(pool).await;
+ mail::send(
+ config,
+ users.into_iter().map(|u| (u.email, u.name)).collect(),
+ "Budget — rapport hebdomadaire".to_string(),
+ report,
+ )
+ }
+ Err(err) => {
+ error!("Error preparing weekly report from template: {:?}", err);
+ false
+ }
+ }
+}
+
+async fn get_weekly_report(
+ pool: &SqlitePool,
+ templates: &Tera,
+) -> Result<String, tera::Error> {
+ let users = db::users::list(pool).await;
+ let incomes_from = db::incomes::defined_for_all(pool).await;
+ let user_incomes = match incomes_from {
+ Some(from) => db::incomes::cumulative(pool, from).await,
+ None => HashMap::new(),
+ };
+ let user_payments = db::payments::repartition(pool).await;
+ let exceeding_payers =
+ payer::exceeding(&users, &user_incomes, &user_payments);
+
+ let last_week_payments = db::payments::last_week(pool).await;
+ let last_week_incomes = db::incomes::last_week(pool).await;
+
+ let mut context = Context::new();
+ context.insert("exceeding_payers", &exceeding_payers);
+ context.insert("payments", &last_week_payments);
+ context.insert("incomes", &last_week_incomes);
+
+ templates.render("report/report.j2", &context)
+}