Skip to main content

Use requests to talk HTTP via a UNIX domain socket

Project description

requests-unixsocket

Latest Version on PyPI pipeline status coverage report Latest Release

Use requests to talk HTTP via a UNIX domain socket.

Usage

Explicit

You can use it by instantiating a special Session object:

import json

import requests_unixsocket

session = requests_unixsocket.Session()

r = session.get('http+unix://%2Fvar%2Frun%2Fdocker.sock/info')
registry_config = r.json()['RegistryConfig']
print(json.dumps(registry_config, indent=4))

Implicit (monkeypatching)

Monkeypatching allows you to use the functionality in this module, while making minimal changes to your code. Note that in the above example we had to instantiate a special requests_unixsocket.Session object and call the get method on that object. Calling requests.get(url) (the easiest way to use requests and probably very common), would not work. But we can make it work by doing monkeypatching.

You can monkeypatch globally:

import requests_unixsocket

requests_unixsocket.monkeypatch()

r = requests.get('http+unix://%2Fvar%2Frun%2Fdocker.sock/info')
assert r.status_code == 200

or you can do it temporarily using a context manager:

import requests_unixsocket

with requests_unixsocket.monkeypatch():
    r = requests.get('http+unix://%2Fvar%2Frun%2Fdocker.sock/info')
    assert r.status_code == 200

Abstract namespace sockets

To connect to an abstract namespace socket (Linux only), prefix the name with a NULL byte (i.e.: \0) - e.g.:

import requests_unixsocket

session = requests_unixsocket.Session()
res = session.get('http+unix://\0test_socket/get')
print(res.text)

For an example program that illustrates this, see examples/abstract_namespace.py in the git repo. Since abstract namespace sockets are specific to Linux, the program will only work on Linux.

See also

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

requests_unixsocket2-0.4.0b1.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

requests_unixsocket2-0.4.0b1-py3-none-any.whl (8.0 kB view details)

Uploaded Python 3

File details

Details for the file requests_unixsocket2-0.4.0b1.tar.gz.

File metadata

File hashes

Hashes for requests_unixsocket2-0.4.0b1.tar.gz
Algorithm Hash digest
SHA256 4c0cdc6409de5cdec9d36e7094ca87a5ae4794fb9d0fb2b120543b47ae2b0190
MD5 cc7739c5be0bc32beb1e84abc946b26a
BLAKE2b-256 dcf12930006b69adcd5cf8af606ade8c014b7d20fd80c059c07f74ece91488e5

See more details on using hashes here.

Provenance

File details

Details for the file requests_unixsocket2-0.4.0b1-py3-none-any.whl.

File metadata

File hashes

Hashes for requests_unixsocket2-0.4.0b1-py3-none-any.whl
Algorithm Hash digest
SHA256 4d5e919930be7fcff53606a11e3dd92ef3d7144ce4510340e35e6b461bc5d83d
MD5 e0e3004a89663f1c9265c32a033769ab
BLAKE2b-256 de61bb228414247dfea028706f03c65e84b8a6b2043e0429909f13e46c633e0a

See more details on using hashes here.

Provenance

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