forked from trinitrix/core
1
0
Fork 0

feature (accounts): implemented session restoring

This commit is contained in:
antifallobst 2023-06-15 21:57:43 +02:00
parent e776d8a631
commit 30e1f4cd6b
3 changed files with 22 additions and 4 deletions

6
.gitignore vendored
View File

@ -1,5 +1,5 @@
target/
data/
# IDE stuff
.idea
# Rust stuff
target/

View File

@ -14,6 +14,7 @@ pub struct Account {
pub async fn account_add(homeserver:&str, username:&str, password:&str) -> anyhow::Result<Account> {
let client = Client::builder()
.homeserver_url(homeserver)
.sled_store("data", Some("supersecure"))?
.build()
.await?;
@ -38,10 +39,21 @@ pub async fn account_add(homeserver:&str, username:&str, password:&str) -> anyho
let serialized_account = serde_json::to_string(&account)?;
println!("serialized account: {}", serialized_account);
// TODO: save serialized account info in userdata dir
Ok(account)
}
pub async fn account_login(account: Account) -> anyhow::Result<()> {
let client = Client::builder()
.homeserver_url(account.homeserver)
.sled_store("data", Some("supersecure"))?
.build()
.await?;
client.restore_login(account.session.clone()).await?;
println!("restored account: {} device ID: {}", &account.session.user_id, &account.session.device_id);
Ok(())
}

View File

@ -1,13 +1,19 @@
mod ui;
mod accounts;
use matrix_sdk::ruma::exports::serde_json;
use tokio::time::{sleep, Duration};
#[tokio::main]
async fn main() -> anyhow::Result<()> {
tracing_subscriber::fmt::init();
accounts::account_add("https://nerdcult.net", "test", "abcd1234").await?;
// accounts::account_add("https://nerdcult.net", "test", "abcd1234").await?;
let serialized_account = "{\"homeserver\":\"https://nerdcult.net\",\"session\":{\"access_token\":\"U2XH1vfu3dJTTPV7BIeZh2yGiMN49vBF\",\"user_id\":\"@test:nerdcult.net\",\"device_id\":\"UsdqFbcEC3\"},\"sync_token\":null}";
let account: accounts::Account = serde_json::from_str(serialized_account)?;
accounts::account_login(account).await?;
Ok(())
}