Source code for proxy.core.work.fd.remote
# -*- coding: utf-8 -*-
"""
proxy.py
~~~~~~~~
⚡⚡⚡ Fast, Lightweight, Pluggable, TLS interception capable proxy server focused on
Network monitoring, controls & Application development, testing, debugging.
:copyright: (c) 2013-present by Abhinav Singh and contributors.
:license: BSD, see LICENSE for more details.
"""
import asyncio
from typing import Any, Optional
from multiprocessing import connection
from multiprocessing.reduction import recv_handle
from .fd import ThreadlessFdExecutor
[docs]class RemoteFdExecutor(ThreadlessFdExecutor[connection.Connection]):
"""A threadless executor implementation which receives work over a connection.
NOTE: RemoteExecutor uses ``recv_handle`` to accept file descriptors.
TODO: Refactor and abstract ``recv_handle`` part so that a threaded
remote executor can also accept work over a connection. Currently,
remote executors must be running in a process.
"""
def __init__(self, *args: Any, **kwargs: Any) -> None:
super().__init__(*args, **kwargs)
self._loop: Optional[asyncio.AbstractEventLoop] = None
@property
def loop(self) -> Optional[asyncio.AbstractEventLoop]:
if self._loop is None:
self._loop = asyncio.get_event_loop_policy().get_event_loop()
return self._loop
[docs] def receive_from_work_queue(self) -> bool:
# Acceptor will not send address for
# unix socket domain environments.
addr = None
if not self.flags.unix_socket_path:
addr = self.work_queue.recv()
fileno = recv_handle(self.work_queue)
self.work(fileno, addr, None)
return False