From 7f3c70998e6d4487a9d567c84aa2d0efac203fc7 Mon Sep 17 00:00:00 2001 From: Vika Date: Sun, 25 Aug 2024 20:25:33 +0300 Subject: Use a provided SoupSession for Micropub --- src/lib.rs | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) (limited to 'src/lib.rs') diff --git a/src/lib.rs b/src/lib.rs index 52a18ef..23b7be7 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -44,7 +44,7 @@ pub struct App { } impl App { - async fn get_login_state(schema: &libsecret::Schema) -> Result, glib::Error> { + async fn get_login_state(schema: &libsecret::Schema, http: soup::Session) -> Result, glib::Error> { let mut retrievables = libsecret::password_search_future(Some(schema), { let mut attrs = std::collections::HashMap::default(); attrs.insert(crate::secrets::TOKEN_KIND, crate::secrets::ACCESS_TOKEN); @@ -92,6 +92,7 @@ impl App { }; let micropub = crate::micropub::Client::new( + http.clone(), micropub_uri, retrievable.retrieve_secret_future().await // SAFETY: see above @@ -202,11 +203,14 @@ impl AsyncComponent for App { sender: AsyncComponentSender, ) -> AsyncComponentParts { let secret_schema = crate::secrets::get_schema(); - let state = App::get_login_state(&secret_schema).await.unwrap(); let http = soup::Session::builder() .user_agent(concat!(env!("CARGO_PKG_NAME"),"/",env!("CARGO_PKG_VERSION")," ")) .build(); + let state = App::get_login_state( + &secret_schema, http.clone() + ).await.unwrap(); + let model = App { submit_busy_guard: None, @@ -284,7 +288,7 @@ impl AsyncComponent for App { } self.micropub = Some(crate::micropub::Client::new( - data.micropub.clone(), data.access_token.clone() + self.http.clone(), data.micropub.clone(), data.access_token.clone() )); }, Input::SubmitButtonPressed => { -- cgit 1.4.1