Start receive message
This commit is contained in:
parent
ba276d9b00
commit
130d6bebfc
14
src/main.rs
14
src/main.rs
|
@ -52,7 +52,7 @@ fn main() {
|
||||||
|
|
||||||
let tabs_store = gio::ListStore::new::<Tab>();
|
let tabs_store = gio::ListStore::new::<Tab>();
|
||||||
|
|
||||||
let xmpp_receiver = xmpp_client::client(&username, &password);
|
let (xmpp_receiver, cmd_sender) = xmpp_client::client(&username, &password);
|
||||||
let tabs_store_copy = tabs_store.clone();
|
let tabs_store_copy = tabs_store.clone();
|
||||||
glib::spawn_future_local(async move {
|
glib::spawn_future_local(async move {
|
||||||
while let Ok(event) = xmpp_receiver.recv().await {
|
while let Ok(event) = xmpp_receiver.recv().await {
|
||||||
|
@ -155,10 +155,22 @@ fn main() {
|
||||||
});
|
});
|
||||||
|
|
||||||
let win2 = win.clone();
|
let win2 = win.clone();
|
||||||
|
let cmd_sender2 = cmd_sender.clone();
|
||||||
win.entry().connect_activate(move |entry| {
|
win.entry().connect_activate(move |entry| {
|
||||||
let text = entry.text();
|
let text = entry.text();
|
||||||
entry.set_text("");
|
entry.set_text("");
|
||||||
println!("Send: {text}");
|
println!("Send: {text}");
|
||||||
|
let current_tab: Tab = win2
|
||||||
|
.tabs_selection()
|
||||||
|
.selected_item()
|
||||||
|
.and_downcast()
|
||||||
|
.unwrap();
|
||||||
|
cmd_sender2
|
||||||
|
.send_blocking(xmpp_client::XMPPCommand::SendPM(
|
||||||
|
xmpp::BareJid::new(¤t_tab.jid()).unwrap(),
|
||||||
|
text.as_str().to_string(),
|
||||||
|
))
|
||||||
|
.unwrap();
|
||||||
let message = Message::now(&get_own_nick(), &text);
|
let message = Message::now(&get_own_nick(), &text);
|
||||||
let selection = win2.selection();
|
let selection = win2.selection();
|
||||||
let store = selection
|
let store = selection
|
||||||
|
|
|
@ -1,16 +1,22 @@
|
||||||
use async_channel::Receiver;
|
use async_channel::{Receiver, Sender};
|
||||||
use tokio::runtime::Runtime;
|
use tokio::runtime::Runtime;
|
||||||
use xmpp::{BareJid, ClientBuilder, ClientFeature, Event};
|
use xmpp::{BareJid, ClientBuilder, ClientFeature, Event};
|
||||||
|
|
||||||
use std::sync::OnceLock;
|
use std::sync::OnceLock;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug)]
|
||||||
|
pub enum XMPPCommand {
|
||||||
|
SendPM(BareJid, String),
|
||||||
|
}
|
||||||
|
|
||||||
fn tokio_runtime() -> &'static Runtime {
|
fn tokio_runtime() -> &'static Runtime {
|
||||||
static RUNTIME: OnceLock<Runtime> = OnceLock::new();
|
static RUNTIME: OnceLock<Runtime> = OnceLock::new();
|
||||||
RUNTIME.get_or_init(|| Runtime::new().expect("Setting up tokio runtime needs to succeed."))
|
RUNTIME.get_or_init(|| Runtime::new().expect("Setting up tokio runtime needs to succeed."))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn client(jid: &str, password: &str) -> Receiver<xmpp::Event> {
|
pub(crate) fn client(jid: &str, password: &str) -> (Receiver<xmpp::Event>, Sender<XMPPCommand>) {
|
||||||
let (event_sender, event_receiver) = async_channel::bounded::<xmpp::Event>(1);
|
let (event_sender, event_receiver) = async_channel::bounded::<xmpp::Event>(1);
|
||||||
|
let (cmd_sender, cmd_receiver) = async_channel::bounded::<XMPPCommand>(1);
|
||||||
|
|
||||||
let jid = jid.to_string();
|
let jid = jid.to_string();
|
||||||
let password = password.to_string();
|
let password = password.to_string();
|
||||||
|
@ -21,22 +27,34 @@ pub(crate) fn client(jid: &str, password: &str) -> Receiver<xmpp::Event> {
|
||||||
.enable_feature(ClientFeature::ContactList)
|
.enable_feature(ClientFeature::ContactList)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
while let Some(events) = client.wait_for_events().await {
|
loop {
|
||||||
for event in events {
|
tokio::select! {
|
||||||
match event {
|
Some(events) = client.wait_for_events() => {
|
||||||
Event::ContactAdded(_) => {
|
for event in events {
|
||||||
event_sender.send(event).await.expect("BOOOOOOHOOOO");
|
match event {
|
||||||
|
Event::ContactAdded(_) => {
|
||||||
|
event_sender.send(event).await.expect("BOOOOOOHOOOO");
|
||||||
|
}
|
||||||
|
Event::ChatMessage(_, _, _, _) => {
|
||||||
|
event_sender.send(event).await.expect("BOOOHOOOO");
|
||||||
|
}
|
||||||
|
_ => {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
Event::ChatMessage(_, _, _, _) => {
|
}
|
||||||
event_sender.send(event).await.expect("BOOOHOOOO");
|
|
||||||
}
|
command = cmd_receiver.recv() => {
|
||||||
_ => {
|
match command.unwrap() {
|
||||||
continue;
|
XMPPCommand::SendPM(jid, content) => {
|
||||||
|
client.send_message(jid.into(), xmpp::parsers::message::MessageType::Chat, "en", &content).await;
|
||||||
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
event_receiver
|
(event_receiver, cmd_sender)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user