Metadata-Version: 2.1
Name: actproxy
Version: 0.1.2
Summary: Sync & asyncio (Requests & AIOHTTP) proxy rotator + utils for actproxy API & services.
Home-page: https://github.com/TensorTom/actproxy
License: MIT
Keywords: python,socks,aiohttp,requests,python3,socks5,proxies,rotate,actproxy
Author: TensorTom
Author-email: 14287229+TensorTom@users.noreply.github.com
Requires-Python: >=3.8.5,<4.0.0
Classifier: Development Status :: 4 - Beta
Classifier: Environment :: Console
Classifier: Framework :: AsyncIO
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Topic :: Internet :: WWW/HTTP
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: System :: Networking
Requires-Dist: aiohttp (>=3.6.2,<4.0.0)
Requires-Dist: aiohttp-socks (>=0.5.5,<0.6.0)
Requires-Dist: mo-dots (>=3.93.20259,<4.0.0)
Requires-Dist: requests[socks] (>=2.24.0,<3.0.0)
Project-URL: Repository, https://github.com/johnfraney/actproxy
Description-Content-Type: text/markdown

# actproxy (Python Package)

This Python package provides actproxy API access and proxy rotation methods for requests (synchronous) and aiohttp
(asyncio).

## Quick-Start (AIOHTTP)

```python
import actproxy
from aiohttp import ClientSession


async def main():
    actproxy_api_key = "xxxxxxxxxxxxxxxxxxxxxxxx"
    # Initialize API. Also returns your proxies.
    await actproxy.aioinit(actproxy_api_key)
    # Use a new AIOHTTP connector which rotates & uses the next proxy.
    async with ClientSession(connector=actproxy.aiohttp_rotate()) as session:
        url = "http://dummy.restapiexample.com/api/v1/employees"
        async with session.get(url) as resp:
            if resp.status == 200:
                resp_json = await resp.json()
                print(resp_json)
```

## Quick-Start (Requests)

```python
import actproxy
import requests

actproxy_api_key = "xxxxxxxxxxxxxxxxxxxxxxxx"
# Initialize API. Also returns your proxies.
actproxy.init(actproxy_api_key)
url = "http://dummy.restapiexample.com/api/v1/employees"
resp = requests.get(url, proxies=actproxy.rotate())
if resp.status_code == 200:
    resp_json = resp.json()
    print(resp_json)
```

## Methods

`actproxy.aioinit(api_key)`: Fetches your proxies from ActProxy & returns them. Must be run before other aiohttp
functions.

`actproxy.init(api_key)`: Fetches your proxies from ActProxy & returns them. Must be run before other synchronous
functions.

`actproxy.aiohttp_rotate()`: Returns an aiohttp connector which uses the next proxy from your list.

`actproxy.rotate()`: Returns the next proxy from your list. Return variable is suitable for use with requests[socks].

`actproxy.random_proxy()`: Returns a random proxy from your list. Return variable is suitable for use with
requests[socks].

`actproxy.aiohttp_random()`: Returns an aiohttp connector which uses uses a random proxy from your list.

`actproxy.one_hot_proxy()`: Similar to rotate() but returns a single proxy dict/object for use in places other than
aiohttp or requests.
