Skip to main content

Use requests to talk HTTP via a UNIX domain socket

Project description

requests-unixsocket2

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.0.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

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

Uploaded Python 3

File details

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

File metadata

  • Download URL: requests_unixsocket2-0.4.0.tar.gz
  • Upload date:
  • Size: 6.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.0 CPython/3.11.9

File hashes

Hashes for requests_unixsocket2-0.4.0.tar.gz
Algorithm Hash digest
SHA256 06d0bb51551a8552e7ce67937a3e19c5516f62b97ccd412b17e94a0b4c4980b9
MD5 3e434db7717df3f18069ea8da314d69a
BLAKE2b-256 7ffc23d7312a1d210b6b6e39a2193c2b2e8262ea4ccfb54a297a76a01ab795c6

See more details on using hashes here.

Provenance

File details

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

File metadata

File hashes

Hashes for requests_unixsocket2-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8d3cafcc7b2feb18f85b0a5e37e4ff7b1a64777000ebd1a883df33012a07f16f
MD5 26e7e45eb64872d8996e54fa22ebf286
BLAKE2b-256 513a60c77c2cea5b11609179cc6a172179d6ae900826b42438848255c43e38e0

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