Skip to main content

Asynchronous python module for programatic access to Chrome DevTools Protocol.

Project description

AIOCDP

This library provides an async wrapper around the Chrome DevTools Protocol.

About

To be the underlying engine for any projects using Chrome DevTools Protocol. This library should embody the following:

  1. Flexibility: Allow for any use case that the CDP supports.
  2. Minimal external dependencies: Opt for built-in python libraries where possible.
  3. Clean code: No hacks, workarounds, or spaghetti code.

Usage

Starting Chrome

The following will launch chrome through the command line.

import asyncio

from aiocdp import Chrome


async def setup_chrome():
    chrome = Chrome.init(
        host="localhost",
        port=9222,
    )
    
    chrome.start()
    
    # run your logic here
    

if __name__ == "__main__":
    asyncio.run(setup_chrome())

NOTE: If you had chrome open previously, you may run into connection issues. If this is the case, close your tabs, run the script to relaunch chrome, and then reopen your tabs.

Opening a tab

import asyncio

from aiocdp import Chrome


async def setup_tabs():
    chrome = Chrome.init(
        host="localhost",
        port=9222,
    )

    chrome.start()

    # opens a new tab. Return aiocdp.ITarget instance.
    target = chrome.new_tab("https://www.google.com")
    target = chrome.new_tab("https://www.yahoo.com")
    target = chrome.new_tab("https://www.github.com/amirdevstudio/aiocdp")

    # opens a new tab. The parameter is optional
    target = chrome.new_tab()


if __name__ == "__main__":
    asyncio.run(setup_tabs())

Package

You can find the AIOCDP package published to pypi.org/project/aiocdp

For Developers

Scope

This library is built to be "one and done" except for performance optimizations or design changes. This library should limit the dependencies it has on the CDP unless it's a core feature (opening sessions, etc.).

Dependencies

  • Built-in dataclasses module for classes
  • Built-in typing module for type hints, enum literals, and other goodies
  • Built-in json module for JSON serialization
  • Built-in asyncio module for async functionality
  • External requests module for HTTP communication
  • External websockets module for websocket communication

Internals

Module Organization

  • aiocdp - Root package. Contains core and utility modules
  • aiocdp.core - Core functionality for communicating with the Chrome DevTools Protocol
  • aiocdp.core.chrome.Chrome -> Represents the Chrome instance / process.
  • aiocdp.core.target.Target -> Represents a chrome devtools protocol target (Page, Frame, Worker, etc)
  • aiocdp.core.connection.Connection -> Represents a websocket connection to a target
  • aiocdp.core.session.TargetSession -> Represents a session to a specific target.
  • aiocdp.core.stream.EventStream -> Represents a stream of events from a connection.
  • aiocdp.core.stream.EventStreamReader -> Readonly reader to an event stream.

TODO:

  • Setup proper typehints for setting subclasses. (use a type var in a shared module)
  • documentation

Publishing to PyPi

  1. Update the version in pyproject.toml
  2. Run python -m pip install build twine
  3. Run python -m build
  4. Run twine check dist/*
  5. Run twine upload dist/aiocdp-<MAJOR>.<MINOR>.<PATCH>*

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aiocdp-1.1.8.tar.gz (12.7 kB view details)

Uploaded Source

Built Distribution

aiocdp-1.1.8-py3-none-any.whl (17.6 kB view details)

Uploaded Python 3

File details

Details for the file aiocdp-1.1.8.tar.gz.

File metadata

  • Download URL: aiocdp-1.1.8.tar.gz
  • Upload date:
  • Size: 12.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for aiocdp-1.1.8.tar.gz
Algorithm Hash digest
SHA256 91cf0277c2797e909b4c24c8e7d7783cd7f17291ba2342905eb9633f75bcbbf7
MD5 1d0a27a05d66e679a7b786c47dc1e8d4
BLAKE2b-256 19a31dea2bf259d732906d2461d4a9d9905352893e41737a18efcbfc2745bfe0

See more details on using hashes here.

File details

Details for the file aiocdp-1.1.8-py3-none-any.whl.

File metadata

  • Download URL: aiocdp-1.1.8-py3-none-any.whl
  • Upload date:
  • Size: 17.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for aiocdp-1.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 10d337ee2080e097e72b13b7c25f6c157fcc313e8458174ff7483ba24733ed68
MD5 78d551f962125331540e82bec59d8ce2
BLAKE2b-256 3f4ec98db90fc7618e9dc40dd187307070ca7420f1cf48e4ced637975d97028a

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page