Compare commits
3 Commits
a667c6d98b
...
f5e2be9651
Author | SHA1 | Date | |
---|---|---|---|
f5e2be9651 | |||
cad7822c16 | |||
f78f46b2f3 |
@ -33,6 +33,15 @@ Adw.ApplicationWindow window {
|
||||
valign: center;
|
||||
title: "Server Information";
|
||||
description: "The information the server published on connection";
|
||||
}
|
||||
Adw.PreferencesGroup credentials {
|
||||
vexpand: true;
|
||||
valign: center;
|
||||
title: "Login Information";
|
||||
description: "The credentials that will be used to log in.";
|
||||
Adw.EntryRow{title: "Username:";}
|
||||
Adw.PasswordEntryRow{title: "Password:";}
|
||||
|
||||
}}
|
||||
|
||||
}
|
||||
|
@ -1,3 +1,4 @@
|
||||
use anyhow::Context;
|
||||
use sieverman::ConnectionInfo;
|
||||
use tracing::info;
|
||||
|
||||
@ -12,13 +13,7 @@ pub(crate) async fn run(
|
||||
info!("connecting…");
|
||||
let future_info = info.connect();
|
||||
info!("waiting for the connection to be established");
|
||||
let mut connected = match future_info.await {
|
||||
Ok(v) => v,
|
||||
Err(e) => {
|
||||
info!("Failed to connect: {:?}", e);
|
||||
panic!("Something went wrong");
|
||||
}
|
||||
};
|
||||
let mut connected = future_info.await.context("Something went wrong")?;
|
||||
|
||||
info!("Fully read the introduction:");
|
||||
to_frontend_tx
|
||||
@ -27,5 +22,6 @@ pub(crate) async fn run(
|
||||
))
|
||||
.await
|
||||
.unwrap();
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
88
src/lib.rs
88
src/lib.rs
@ -1,9 +1,10 @@
|
||||
use std::{sync::Arc, time::Duration};
|
||||
|
||||
use anyhow::Context;
|
||||
use managesieve::Capabilities;
|
||||
use thiserror::Error;
|
||||
use tokio::{
|
||||
io::{split, AsyncBufReadExt, BufReader, WriteHalf},
|
||||
io::{split, AsyncBufReadExt, AsyncWriteExt, BufReader, WriteHalf},
|
||||
net::TcpStream,
|
||||
sync::Mutex,
|
||||
};
|
||||
@ -93,7 +94,7 @@ impl ConnectionInfo {
|
||||
trace!("Capabilities read: {:#?}", &caps);
|
||||
Ok(ConnectionConnected {
|
||||
info: self,
|
||||
writer: Arc::new(writer),
|
||||
writer: Arc::new(Mutex::new(writer)),
|
||||
buffer,
|
||||
server_settings: caps,
|
||||
})
|
||||
@ -104,7 +105,7 @@ impl ConnectionInfo {
|
||||
pub struct ConnectionConnected {
|
||||
info: ConnectionInfo,
|
||||
//reader: Arc<ReadHalf<TlsStream<TcpStream>>>,
|
||||
writer: Arc<WriteHalf<TlsStream<TcpStream>>>,
|
||||
writer: Arc<Mutex<WriteHalf<TlsStream<TcpStream>>>>,
|
||||
buffer: Arc<Mutex<String>>,
|
||||
//pub join_handle: Arc<JoinHandle<()>>,
|
||||
server_settings: Capabilities,
|
||||
@ -130,54 +131,51 @@ impl ConnectionConnected {
|
||||
pub async fn log_server_settings(&self) {
|
||||
info!("Serversettings:\n{:?}", self.server_settings)
|
||||
}
|
||||
#[tracing::instrument(name = "gettin the intro")]
|
||||
pub async fn read_introduction(self) -> Result<IsComplete<Self>, anyhow::Error> {
|
||||
|
||||
pub async fn list_scripts(self) -> anyhow::Result<(Vec<(String, bool)>, Self)> {
|
||||
let Self {
|
||||
info,
|
||||
//reader: Arc<ReadHalf<TlsStream<TcpStream>>>,
|
||||
writer,
|
||||
buffer,
|
||||
info,
|
||||
server_settings,
|
||||
} = self;
|
||||
tokio::time::sleep(Duration::from_millis(50)).await;
|
||||
let mut bf = buffer.lock().await;
|
||||
let response = match managesieve::response_capability(&bf.to_string()) {
|
||||
Ok((rest, capability, response)) => {
|
||||
info!("Successfully read the introduction {:?}", response);
|
||||
bf.clear();
|
||||
bf.push_str(rest);
|
||||
drop(bf);
|
||||
Ok(IsComplete::Yes(Self {
|
||||
info,
|
||||
writer: writer.clone(),
|
||||
buffer: buffer.clone(),
|
||||
server_settings: capability,
|
||||
}))
|
||||
}
|
||||
Err(managesieve::Error::IncompleteResponse) => {
|
||||
trace!("incomplete introduction");
|
||||
Ok(IsComplete::No(Self {
|
||||
info,
|
||||
writer,
|
||||
buffer: buffer.clone(),
|
||||
server_settings,
|
||||
}))
|
||||
}
|
||||
Err(managesieve::Error::InvalidResponse) => {
|
||||
error!("invalid response");
|
||||
Err(managesieve::Error::InvalidResponse)?
|
||||
}
|
||||
Err(managesieve::Error::InvalidInput) => {
|
||||
error!("invalid input");
|
||||
Err(managesieve::Error::InvalidResponse)?
|
||||
}
|
||||
Err(managesieve::Error::MissingLine(line)) => {
|
||||
error!("a capability line was missing: {:?}", line);
|
||||
Err(managesieve::Error::InvalidResponse)?
|
||||
}
|
||||
};
|
||||
let command = managesieve::Command::list_scripts();
|
||||
writer
|
||||
.lock()
|
||||
.await
|
||||
.write_all(command.to_string().as_bytes())
|
||||
.await
|
||||
.context("Failed to write LISTSCRIPTS command")?;
|
||||
|
||||
response
|
||||
let scriptslist = loop {
|
||||
let mut buf = buffer.lock().await;
|
||||
trace!("reading new input:\n{}", buf);
|
||||
match managesieve::response_listscripts(&buf.to_string()) {
|
||||
Ok((rest, scriptslist, resp)) => match resp.tag {
|
||||
managesieve::OkNoBye::Ok => {
|
||||
buf.clear();
|
||||
buf.push_str(rest);
|
||||
info!("Read the introduction");
|
||||
break scriptslist;
|
||||
}
|
||||
managesieve::OkNoBye::No | managesieve::OkNoBye::Bye => {
|
||||
trace!("Connection closed!");
|
||||
//panic!("Invalid Response")
|
||||
}
|
||||
},
|
||||
Err(e) => trace!("(temporary) error: {}", e),
|
||||
}
|
||||
tokio::time::sleep(Duration::from_millis(50)).await;
|
||||
};
|
||||
Ok((
|
||||
scriptslist,
|
||||
Self {
|
||||
writer,
|
||||
buffer,
|
||||
info,
|
||||
server_settings,
|
||||
},
|
||||
))
|
||||
}
|
||||
|
||||
pub fn get_greeting(&self) -> String {
|
||||
|
Loading…
Reference in New Issue
Block a user