spys - spys.me/spys.one Python API.

API для получения списка прокси с сайта spys.

pip install -U spys

Пакеты:

spys

from spys import me, one, filters, proxy_view

__all__ = ('me', 'one', 'filters', 'proxy_view')

spys.me

__all__ = ('DATA_REGEX', 'HOST',
           'Getters',
           'ProxyView',
           'parse_proxies', 'get_proxies')

HOST = 'https://spys.me/'
DATA_REGEX = ...  # Регулярное выражение для парсинга ответа от API


class ProxyView(BaseProxyView):
    more_info: bool  # Имеется ли дополнительная информация о прокси (Получение самой информации только из spys.one)
    google_passed: bool

    def __init__(self, host: str, port: str,
                 country: str, anonymity: str, ssl_support: str, more_info: str, google_passed: str):
        ...


def parse_proxies(data: str) -> tuple[str, ProxyViews, str]:
    """Вернёт кортеж из доп. информации о API (str), списка прокси и доп. информации о списке прокси (str)"""
    ...


def get_content(protocol: str) -> str:
    """Отправит запрос на хост, вернёт спаршенную информацию (см. parse_proxies)"""
    ...


def get_proxies(protocol: str) -> ProxyViews:
    """
    Параметр protocol - либо proxy (http) либо socks
    Разрешённые протоколы: proxy, socks | socks5, all, http, https, ssl (https & socks ssl)
    """
    ...


class Getters:
    """Functions to concisely get different proxies"""

    @staticmethod
    def get_http_s_proxies() -> ProxyViews:  # http | https
        return get_proxies('proxy')

    @staticmethod
    def get_socks5_proxies() -> ProxyViews:
        return get_proxies('socks')

    @staticmethod
    def get_http_proxies() -> ProxyViews:
        return filter_proxies(get_proxies('proxy'), lambda x: not x.ssl_support)

    @staticmethod
    def get_https_proxies() -> ProxyViews:
        return filter_proxies(get_proxies('proxy'), lambda x: x.ssl_support)

    @classmethod
    def get_all_proxies(cls) -> ProxyViews:
        return cls.get_http_and_ssl_proxies() + cls.get_socks5_proxies()

    @classmethod
    def get_ssl_proxies(cls, from_proxies: ProxyViews = None) -> ProxyViews:
        return filter_proxies(cls.get_all_proxies() if from_proxies is None else from_proxies, lambda x: x.ssl_support)

spys.one

Не злоупотребляйте методами из этого модуля, существует риск бана.

risk_of_blocking.png

__all__ = ('HOST', 'HTTP_PROXY_LIST_URL',
           'ProxyView',
           'get_content', 'get_proxies', 'parse_table')

HOST = 'https://spys.one/'
HTTP_PROXY_LIST_URL = urllib.parse.urljoin(HOST, 'http-proxy-list/')


class ProxyView(BaseProxyView):
    type: str
    city: str
    hostname: str
    org: str
    latency: float | str
    uptime: int | str
    checks: int | str
    last_check_status: bool
    last_check_ago: str
    check_date: datetime.datetime | str

    def __init__(self,
                 host: str, port: str, type: str, anonymity: str, country_city: tuple[str, str], hostname_org: str,
                 latency: str, uptime: str, check_date: str):
        ...


def get_content(show: int = 0, anm: int = 0, ssl: int = 0, sort: int = 0, port: int | None = 0, type: int = 0
                ) -> Generator[array.array | str | None, int | str | None, None]:
    """
    Низкоуровневая функция, параметры - input data поля см. get_proxies имена параметров.
    Вернёт генератор, если порт это None (xf4), 
        первый next (yield) вернёт список (array.array('H')) доступных портов,
        второй next примит порт (Воспользуйтесь методом send),
        и только третий next вернёт ответ от сайта (str).
    Если порт не None, первый next вернёт ответ от сайта.
    
    Ответ нужно передать в функцию parse_table, для получения списка прокси."""
    ...


def parse_table(content: str) -> ProxyViews:
    """
    Парсит ответ от сайта и превратит данные с таблицы в класс ProxyView.
    Если установлен lxml (pip install lxml), будет использован он.
    """
    ...


def get_proxies(show: filters.ShowTypes = 0,
                anm: filters.AnmTypes = 0,
                ssl: filters.SSLTypes = 0,
                sort: filters.SortTypes = 0,
                port: filters.PortTypes = 0,
                type: filters.TypeTypes = 0) -> ProxyViews:
    ...

spys.filters

"""Модуль для удобного представления input data полей (см spys.one.get_content)"""


class IntChoice:
    """
    Базовый класс.
    Правильное представление данных можно получить передав желаемый фильтр в
    конструктор класса (метод __new__) или через getitem (__class_getitem__)
    """
    values = ()
    type = int

    def __new__(cls, item_or_index) -> type:
        ...

    def __class_getitem__(cls, item_or_index) -> type:
        ...

    @classmethod
    def nearest(cls):
        """
        Если передано значение не из cls.values, то с помощью этого метода будет выбранно близжаешее к тому значение
        """
        ...


class Show(IntChoice):
    values = (30, 50, 100, 200, 300, 500)


class Port(IntChoice):
    values = (0, 3182, 8080, 80)


class StringChoice(IntChoice):
    type = str


class Anm(StringChoice):
    values = ('ALL', 'A+H', 'NOA', 'ANM', 'HIA')


class SSL(StringChoice):
    values = ('ALL', 'SSL+', 'SSL-')


class Type(StringChoice):
    values = ('ALL', 'HTTP', 'SOCKS')


class Sort(StringChoice):
    values = ('DATE', 'SPEED')


ShowTypes = Union[Show.type, Show, type[Show]]
PortTypes = Union[Port.type, Port, type[Port]]
AnmTypes = Union[Anm.type, Anm, type[Anm]]
SSLTypes = Union[SSL.type, SSL, type[SSL]]
TypeTypes = Union[Type.type, Type, type[Type]]
SortTypes = Union[Sort.type, Sort, type[Sort]]

spys.proxy_view

__all__ = ('BaseProxyView', 'ProxyViews')


class BaseProxyView:
    host: str
    port: int | str
    anonymity: str
    country: str
    more_info: str | bool

    def __str__(self): return f'{self.host}:{self.port}'

    def __repr__(self): ...


ProxyViews = Iterable[BaseProxyView]

For English documentation use pydoc

python -m pydoc -p 8081 spys