Added more paralization to allow better multi-user perfomace
This commit is contained in:
parent
ecf74fb50f
commit
17e4f1892c
1
Cargo.lock
generated
1
Cargo.lock
generated
@ -1569,6 +1569,7 @@ dependencies = [
|
||||
"anyhow",
|
||||
"chacha20poly1305",
|
||||
"dotenv",
|
||||
"futures",
|
||||
"log",
|
||||
"migration",
|
||||
"pbkdf2",
|
||||
|
@ -15,6 +15,7 @@ members = [".", "migration"]
|
||||
anyhow = "1.0.70"
|
||||
chacha20poly1305 = { version = "0.10.1", features = ["std"] }
|
||||
dotenv = "0.15.0"
|
||||
futures = "0.3.28"
|
||||
log = "0.4.17"
|
||||
migration = { version = "0.1.0", path = "migration" }
|
||||
pbkdf2 = "0.12.1"
|
||||
|
@ -1,6 +1,7 @@
|
||||
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.2
|
||||
|
||||
use chacha20poly1305::{aead::Aead, AeadCore, ChaCha20Poly1305, KeyInit};
|
||||
use futures::{Stream, StreamExt};
|
||||
use pbkdf2::pbkdf2_hmac_array;
|
||||
use rand::{rngs::OsRng, RngCore};
|
||||
use sea_orm::{prelude::*, ActiveValue::Set, QuerySelect};
|
||||
@ -88,14 +89,18 @@ impl Model {
|
||||
|
||||
impl Entity {
|
||||
/// Gets a list of account names of a user
|
||||
pub async fn get_names(user_id: u64, db: &DatabaseConnection) -> crate::Result<Vec<String>> {
|
||||
Self::find()
|
||||
pub async fn get_names(
|
||||
user_id: u64,
|
||||
db: &DatabaseConnection,
|
||||
) -> crate::Result<impl Stream<Item = crate::Result<String>> + '_> {
|
||||
let result = Self::find()
|
||||
.select_only()
|
||||
.column(Column::Name)
|
||||
.filter(Column::UserId.eq(user_id))
|
||||
.into_tuple()
|
||||
.all(db)
|
||||
.await
|
||||
.map_err(|err| err.into())
|
||||
.stream(db)
|
||||
.await?
|
||||
.map(|item| item.map_err(Into::into));
|
||||
Ok(result)
|
||||
}
|
||||
}
|
||||
|
@ -2,6 +2,7 @@ use crate::entity::account;
|
||||
use crate::handlers::{utils::package_handler, MainDialogue, State};
|
||||
use sea_orm::prelude::*;
|
||||
use teloxide::{adaptors::Throttle, prelude::*};
|
||||
use tokio::task::spawn_blocking;
|
||||
|
||||
async fn get_master_pass(
|
||||
bot: Throttle<Bot>,
|
||||
@ -13,15 +14,13 @@ async fn get_master_pass(
|
||||
password: String,
|
||||
master_pass: String,
|
||||
) -> crate::Result<()> {
|
||||
let user_id = msg.from().unwrap().id.0;
|
||||
let _ = bot.delete_message(msg.chat.id, msg.id).await;
|
||||
dialogue.exit().await?;
|
||||
let account = account::ActiveModel::from_unencrypted(
|
||||
msg.from().unwrap().id.0,
|
||||
name,
|
||||
&login,
|
||||
&password,
|
||||
&master_pass,
|
||||
)?;
|
||||
let account = spawn_blocking(move || {
|
||||
account::ActiveModel::from_unencrypted(user_id, name, &login, &password, &master_pass)
|
||||
})
|
||||
.await??;
|
||||
account.insert(&db).await?;
|
||||
bot.send_message(msg.chat.id, "Success").await?;
|
||||
Ok(())
|
||||
|
@ -1,8 +1,8 @@
|
||||
use crate::entity::{account, prelude::Account};
|
||||
use crate::handlers::{utils::package_handler, MainDialogue, State};
|
||||
use sea_orm::prelude::*;
|
||||
use teloxide::{adaptors::Throttle, prelude::*, types::ParseMode};
|
||||
|
||||
use crate::handlers::{utils::package_handler, MainDialogue, State};
|
||||
use tokio::task::spawn_blocking;
|
||||
|
||||
async fn get_master_pass(
|
||||
bot: Throttle<Bot>,
|
||||
@ -20,7 +20,7 @@ async fn get_master_pass(
|
||||
.one(&db)
|
||||
.await?
|
||||
.unwrap();
|
||||
let (login, password) = account.decrypt(&master_pass)?;
|
||||
let (login, password) = spawn_blocking(move || account.decrypt(&master_pass)).await??;
|
||||
let message = format!("Name:\n`{name}`\nLogin:\n`{login}`\nPassword:\n`{password}`");
|
||||
bot.send_message(msg.chat.id, message)
|
||||
.parse_mode(ParseMode::MarkdownV2)
|
||||
|
@ -1,4 +1,5 @@
|
||||
use crate::entity::prelude::Account;
|
||||
use futures::TryStreamExt;
|
||||
use sea_orm::prelude::*;
|
||||
use teloxide::{adaptors::Throttle, prelude::*, types::ParseMode};
|
||||
|
||||
@ -8,20 +9,20 @@ pub async fn get_accounts(
|
||||
db: DatabaseConnection,
|
||||
) -> crate::Result<()> {
|
||||
let user_id = msg.from().unwrap().id.0;
|
||||
let mut account_names = Account::get_names(user_id, &db).await?.into_iter();
|
||||
let mut result = match account_names.next() {
|
||||
let mut account_names = Account::get_names(user_id, &db).await?;
|
||||
let mut result = match account_names.try_next().await? {
|
||||
Some(name) => format!("Accounts:\n`{name}`"),
|
||||
None => {
|
||||
bot.send_message(msg.chat.id, "No accounts found").await?;
|
||||
return Ok(());
|
||||
}
|
||||
};
|
||||
for name in account_names {
|
||||
result.reserve(name.len() + 3);
|
||||
result.push_str("\n`");
|
||||
result.push_str(&name);
|
||||
result.push('`')
|
||||
}
|
||||
account_names
|
||||
.try_for_each(|name| {
|
||||
result.push_str(&format!("\n`{}`", name));
|
||||
async { Ok(()) }
|
||||
})
|
||||
.await?;
|
||||
bot.send_message(msg.chat.id, result)
|
||||
.parse_mode(ParseMode::MarkdownV2)
|
||||
.await?;
|
||||
|
Loading…
x
Reference in New Issue
Block a user