thinking
This commit is contained in:
parent
bcf4783234
commit
c172eda415
1 changed files with 79 additions and 81 deletions
160
src/matrixbot.rs
160
src/matrixbot.rs
|
@ -216,96 +216,94 @@ pub async fn login_and_sync(
|
|||
// `sync_forever`
|
||||
let mut settings = SyncSettings::default().token(client.sync_token().await.unwrap());
|
||||
|
||||
tokio::spawn(async move {
|
||||
let client_ref = &client;
|
||||
client
|
||||
.sync_forever(settings, async move |response| {
|
||||
let client = &client_ref;
|
||||
let client_ref = &client;
|
||||
client
|
||||
.sync_forever(settings, async move |response| {
|
||||
let client = &client_ref;
|
||||
|
||||
for event in &response.to_device.events {
|
||||
let e_maybe = event.deserialize();
|
||||
for event in &response.to_device.events {
|
||||
let e_maybe = event.deserialize();
|
||||
|
||||
match e_maybe {
|
||||
Ok(AnyToDeviceEvent::KeyVerificationStart(e)) => {
|
||||
let sas = client
|
||||
.get_verification(&e.content.transaction_id)
|
||||
.await
|
||||
.expect("Sas object wasn't created");
|
||||
sas.accept().await.unwrap();
|
||||
match e_maybe {
|
||||
Ok(AnyToDeviceEvent::KeyVerificationStart(e)) => {
|
||||
let sas = client
|
||||
.get_verification(&e.content.transaction_id)
|
||||
.await
|
||||
.expect("Sas object wasn't created");
|
||||
sas.accept().await.unwrap();
|
||||
}
|
||||
|
||||
Ok(AnyToDeviceEvent::KeyVerificationKey(e)) => {
|
||||
let sas = client
|
||||
.get_verification(&e.content.transaction_id)
|
||||
.await
|
||||
.expect("Sas object wasn't created");
|
||||
|
||||
tokio::spawn(wait_for_confirmation(sas));
|
||||
}
|
||||
|
||||
Ok(AnyToDeviceEvent::KeyVerificationMac(e)) => {
|
||||
let sas = client
|
||||
.get_verification(&e.content.transaction_id)
|
||||
.await
|
||||
.expect("Sas object wasn't created");
|
||||
|
||||
if sas.is_done() {
|
||||
print_result(sas);
|
||||
}
|
||||
}
|
||||
Ok(_) => (), // Unknown or unhandled event
|
||||
Err(error) => {
|
||||
eprintln!(
|
||||
"Couldn't deserialize to to-device event: {:?} from {:?}",
|
||||
error, event
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Ok(AnyToDeviceEvent::KeyVerificationKey(e)) => {
|
||||
let sas = client
|
||||
.get_verification(&e.content.transaction_id)
|
||||
.await
|
||||
.expect("Sas object wasn't created");
|
||||
for (room_id, room) in response.rooms.join {
|
||||
for rawevent in &room.timeline.events {
|
||||
let event = rawevent.deserialize().unwrap();
|
||||
|
||||
tokio::spawn(wait_for_confirmation(sas));
|
||||
}
|
||||
// Check if it's a message type
|
||||
if let Message(msg) = event {
|
||||
match msg {
|
||||
CallCandidates(_e) => {}
|
||||
CallInvite(e) => {
|
||||
println!("incoming debug: {:?}", e);
|
||||
let SyncMessageEvent {
|
||||
content: InviteEventContent { call_id, offer, .. },
|
||||
sender,
|
||||
..
|
||||
} = e;
|
||||
let user_id = sender.localpart();
|
||||
let user_server = sender.server_name();
|
||||
println!("Content: {:?}", call_id);
|
||||
|
||||
Ok(AnyToDeviceEvent::KeyVerificationMac(e)) => {
|
||||
let sas = client
|
||||
.get_verification(&e.content.transaction_id)
|
||||
.await
|
||||
.expect("Sas object wasn't created");
|
||||
|
||||
if sas.is_done() {
|
||||
print_result(sas);
|
||||
handle_call_invite(
|
||||
client,
|
||||
&room_id,
|
||||
call_id,
|
||||
user_id.to_string(),
|
||||
user_server.to_string(),
|
||||
offer,
|
||||
)
|
||||
.await;
|
||||
}
|
||||
}
|
||||
Ok(_) => (), // Unknown or unhandled event
|
||||
Err(error) => {
|
||||
eprintln!(
|
||||
"Couldn't deserialize to to-device event: {:?} from {:?}",
|
||||
error, event
|
||||
);
|
||||
}
|
||||
CallHangup(_e) => {}
|
||||
CallAnswer(_e) => {}
|
||||
e => {
|
||||
println!("unhandled debug: {:?}", e);
|
||||
}
|
||||
};
|
||||
} else {
|
||||
println!("Got unknown event type here: {:?}", event);
|
||||
}
|
||||
}
|
||||
|
||||
for (room_id, room) in response.rooms.join {
|
||||
for rawevent in &room.timeline.events {
|
||||
let event = rawevent.deserialize().unwrap();
|
||||
|
||||
// Check if it's a message type
|
||||
if let Message(msg) = event {
|
||||
match msg {
|
||||
CallCandidates(_e) => {}
|
||||
CallInvite(e) => {
|
||||
println!("incoming debug: {:?}", e);
|
||||
let SyncMessageEvent {
|
||||
content: InviteEventContent { call_id, offer, .. },
|
||||
sender,
|
||||
..
|
||||
} = e;
|
||||
let user_id = sender.localpart();
|
||||
let user_server = sender.server_name();
|
||||
println!("Content: {:?}", call_id);
|
||||
|
||||
handle_call_invite(
|
||||
client,
|
||||
&room_id,
|
||||
call_id,
|
||||
user_id.to_string(),
|
||||
user_server.to_string(),
|
||||
offer,
|
||||
)
|
||||
.await;
|
||||
}
|
||||
CallHangup(_e) => {}
|
||||
CallAnswer(_e) => {}
|
||||
e => {
|
||||
println!("unhandled debug: {:?}", e);
|
||||
}
|
||||
};
|
||||
} else {
|
||||
println!("Got unknown event type here: {:?}", event);
|
||||
}
|
||||
}
|
||||
}
|
||||
})
|
||||
.await;
|
||||
});
|
||||
}
|
||||
})
|
||||
.await;
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue