Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions pyrogram/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
# You should have received a copy of the GNU Lesser General Public License
# along with Pyrogram. If not, see <http://www.gnu.org/licenses/>.

__version__ = "1.1.7"
__version__ = "1.1.8"
__license__ = "GNU Lesser General Public License v3 or later (LGPLv3+)"
__copyright__ = "Copyright (C) 2017-2020 Dan <https://github.com/delivrance>"

Expand Down Expand Up @@ -46,4 +46,4 @@ class ContinuePropagation(StopAsyncIteration):

CRYPTO_EXECUTOR_SIZE_THRESHOLD = 512

crypto_executor = ThreadPoolExecutor(2, thread_name_prefix="CryptoWorker")
crypto_executor = ThreadPoolExecutor(1, thread_name_prefix="CryptoWorker")
8 changes: 3 additions & 5 deletions pyrogram/connection/transport/tcp/tcp_abridged_o.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,9 @@

import logging
import os

from typing import Optional

from pyrogram import utils

import pyrogram
from pyrogram.crypto import aes
from .tcp import TCP

Expand Down Expand Up @@ -60,7 +58,7 @@ async def connect(self, address: tuple):
async def send(self, data: bytes, *args):
length = len(data) // 4
data = (bytes([length]) if length <= 126 else b"\x7f" + length.to_bytes(3, "little")) + data
payload = await utils.maybe_run_in_executor(aes.ctr256_encrypt, data, len(data), self.loop, *self.encrypt)
payload = await self.loop.run_in_executor(pyrogram.crypto_executor, aes.ctr256_encrypt, data, *self.encrypt)

await super().send(payload)

Expand All @@ -85,4 +83,4 @@ async def recv(self, length: int = 0) -> Optional[bytes]:
if data is None:
return None

return await utils.maybe_run_in_executor(aes.ctr256_decrypt, data, len(data), self.loop, *self.decrypt)
return await self.loop.run_in_executor(pyrogram.crypto_executor, aes.ctr256_decrypt, data, *self.decrypt)
14 changes: 9 additions & 5 deletions pyrogram/session/session.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
from io import BytesIO

import pyrogram
from pyrogram import __copyright__, __license__, __version__, utils
from pyrogram import __copyright__, __license__, __version__
from pyrogram import raw
from pyrogram.connection import Connection
from pyrogram.crypto import mtproto
Expand Down Expand Up @@ -217,8 +217,10 @@ async def restart(self):
await self.start()

async def handle_packet(self, packet):
data = await utils.maybe_run_in_executor(
mtproto.unpack, BytesIO(packet), len(packet), self.loop,
data = await self.loop.run_in_executor(
pyrogram.crypto_executor,
mtproto.unpack,
BytesIO(packet),
self.session_id,
self.auth_key,
self.auth_key_id
Expand Down Expand Up @@ -360,8 +362,10 @@ async def _send(self, data: TLObject, wait_response: bool = True, timeout: float
log.debug(f"Sent:")
log.debug(message)

payload = await utils.maybe_run_in_executor(
mtproto.pack, message, len(message), self.loop,
payload = await self.loop.run_in_executor(
pyrogram.crypto_executor,
mtproto.pack,
message,
self.current_salt.salt,
self.session_id,
self.auth_key,
Expand Down
8 changes: 0 additions & 8 deletions pyrogram/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -309,11 +309,3 @@ async def parse_text_entities(
"message": text,
"entities": entities
}


async def maybe_run_in_executor(func, data, length, loop, *args):
return (
func(data, *args)
if length <= pyrogram.CRYPTO_EXECUTOR_SIZE_THRESHOLD
else await loop.run_in_executor(pyrogram.crypto_executor, func, data, *args)
)