_export2 no longer blocks event loop during decryption
Removed sorting in get_all_accounts Removed decrypt_multiple function because it is no longer used Now running decrytion of accounts in ProcessPoolExecutor
This commit is contained in:
parent
74844da4ae
commit
281c4a262b
@ -1,5 +1,7 @@
|
||||
import asyncio
|
||||
import functools
|
||||
import gc
|
||||
from concurrent.futures import ProcessPoolExecutor
|
||||
|
||||
import telebot
|
||||
from sqlalchemy.future import Engine
|
||||
@ -534,7 +536,16 @@ async def _export2(
|
||||
)
|
||||
|
||||
accounts = database.get.get_all_accounts(engine, mes.from_user.id)
|
||||
accounts = encryption.other_accounts.decrypt_multiple(accounts, text)
|
||||
with ProcessPoolExecutor() as pool:
|
||||
loop = asyncio.get_running_loop()
|
||||
tasks = []
|
||||
for account in accounts:
|
||||
function = functools.partial(
|
||||
encryption.other_accounts.decrypt, account, text
|
||||
)
|
||||
tasks.append(loop.run_in_executor(pool, function))
|
||||
accounts = await asyncio.gather(*tasks)
|
||||
accounts.sort(key=lambda account: account.name)
|
||||
json_io = accounts_to_json(accounts)
|
||||
await bot.send_document(
|
||||
mes.chat.id,
|
||||
|
@ -36,12 +36,8 @@ def get_accounts(
|
||||
|
||||
def get_all_accounts(engine: Engine, user_id: int) -> list[models.Account]:
|
||||
"""Returns a list of accounts of a user"""
|
||||
statement = (
|
||||
sqlmodel.select(models.Account)
|
||||
.where(
|
||||
models.Account.user_id == user_id,
|
||||
)
|
||||
.order_by(models.Account.name)
|
||||
statement = sqlmodel.select(models.Account).where(
|
||||
models.Account.user_id == user_id,
|
||||
)
|
||||
with sqlmodel.Session(engine) as session:
|
||||
result = session.exec(statement).fetchall()
|
||||
|
@ -1,6 +1,5 @@
|
||||
import base64
|
||||
import os
|
||||
from typing import Iterable, Iterator
|
||||
|
||||
from cryptography.fernet import Fernet
|
||||
from cryptography.hazmat.backends import default_backend
|
||||
@ -71,12 +70,3 @@ def decrypt(
|
||||
login=login,
|
||||
password=password,
|
||||
)
|
||||
|
||||
|
||||
def decrypt_multiple(
|
||||
accounts: Iterable[Account], master_pass: str
|
||||
) -> Iterator[DecryptedAccount]:
|
||||
"""Decrypts an iterable of accounts using master_pass and
|
||||
returns an Iterator of decrypted accounts"""
|
||||
for account in accounts:
|
||||
yield decrypt(account, master_pass)
|
||||
|
Reference in New Issue
Block a user