some updates to the rust server

This commit is contained in:
Chris Cochrun 2024-06-21 17:12:21 -05:00
parent 400ad2ad5b
commit 9b70af3dba
4 changed files with 164 additions and 25 deletions

View file

@ -10,25 +10,25 @@ use lettre::{
#[derive(Debug, MultipartForm, Default)]
struct HealthForm {
#[multipart(rename = "firstname")]
#[multipart(rename = "first-name")]
first_name: Option<Text<String>>,
#[multipart(rename = "lastname")]
#[multipart(rename = "last-name")]
last_name: Option<Text<String>>,
#[multipart(rename = "parentfirstname")]
#[multipart(rename = "parent-first-name")]
parent_first_name: Option<Text<String>>,
#[multipart(rename = "parentlastname")]
#[multipart(rename = "parent-last-name")]
parent_last_name: Option<Text<String>>,
birthdate: Option<Text<String>>,
street: Option<Text<String>>,
city: Option<Text<String>>,
state: Option<Text<String>>,
zip: Option<Text<String>>,
#[multipart(rename = "cellphone")]
#[multipart(rename = "cell-phone")]
parent_cellphone: Option<Text<String>>,
homephone: Option<Text<String>>,
#[multipart(rename = "add-emergency-contact")]
#[multipart(rename = "additional-emergency-contact")]
contact: Option<Text<String>>,
#[multipart(rename = "add-emergency-contact-phone")]
#[multipart(rename = "addtional-emergency-contact-phone")]
contact_phone: Option<Text<String>>,
doctorname: Option<Text<String>>,
doctorcity: Option<Text<String>>,
@ -58,6 +58,7 @@ struct HealthForm {
agreement: Option<Text<String>>,
#[multipart(rename = "image")]
file: Option<TempFile>,
registration: Option<Text<String>>,
}
#[post("/health-form")]
@ -78,6 +79,15 @@ pub async fn health_form(MultipartForm(form): MultipartForm<HealthForm>) -> Http
})
.0
.clone();
let full_name = format!("{} {}", first, last);
let registration = form
.registration
.as_ref()
.unwrap_or(&Text {
0: String::from(""),
})
.0
.clone();
let email_subject = format!("{} {} filled out a health form!", first, last);
let filename_noext = String::from(format!("{}_{}", first, last));
let parent = format!(
@ -475,7 +485,7 @@ pub async fn health_form(MultipartForm(form): MultipartForm<HealthForm>) -> Http
.unwrap(),
)
.to("Chris Cochrun <chris@tfcconnection.org>".parse().unwrap())
.to("Ethan Rose <ethan@tfcconnection.org>".parse().unwrap())
// .to("Ethan Rose <ethan@tfcconnection.org>".parse().unwrap())
.subject(email_subject)
.multipart(multi)
{
@ -496,5 +506,65 @@ pub async fn health_form(MultipartForm(form): MultipartForm<HealthForm>) -> Http
log::info!("Email incorrect");
}
HttpResponse::Ok().body("hi")
match registration.as_str() {
"now" => {
log::info!("Sending them to pay for registration now");
HttpResponse::Ok()
.insert_header(("Access-Control-Expose-Headers", "*"))
.insert_header((
"HX-Redirect",
"https://secure.myvanco.com/L-Z772/campaign/C-13JPJ",
))
.finish()
}
"full" => {
log::info!("Sending them to pay for the full registration now");
HttpResponse::Ok()
.insert_header(("Access-Control-Expose-Headers", "*"))
.insert_header((
"HX-Redirect",
"https://secure.myvanco.com/L-Z772/campaign/C-13JQE",
))
.finish()
}
"later" => {
log::info!("{} would like to pay later", full_name);
let html = markup::new! {
div {
class { "mt-8" }
h2 {
@format!("Thank you, {}!", full_name)
}
p { "Can't wait to see you at camp!" }
p {
class { "" }
"If you'd like to pay for your registration go to the donate tab in the top right when you are ready and find the camp registration option."
}
}
};
HttpResponse::Ok().body(html.to_string())
}
_ => {
log::error!("Got registration error.....");
let html = markup::new! {
div {
class { "mt-8" }
h2 {
@format!("Thank you, {}!", full_name)
}
p { "Can't wait to see you at camp!" }
p {
class { "" }
"If you'd like to pay for your registration go to the donate tab in the top right when you are ready and find the camp registration option."
}
}
};
HttpResponse::Ok().body(html.to_string())
}
}
// HttpResponse::Ok().body("hi")
}
async fn post_health_form(form: HealthForm) -> bool {
todo!()
}