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

Uploaded Source

Built Distribution

requests_unixsocket2-0.4.2-py3-none-any.whl (7.8 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for requests_unixsocket2-0.4.2.tar.gz
Algorithm Hash digest
SHA256 929c58ecc5981f3d127661ceb9ec8c76e0f08d31c52e44ab1462ac0dcd55b5f5
MD5 f55a79dd0f8065d9918b571cf4c69331
BLAKE2b-256 146688737c8720685f44e6a1c04cb2185301a6ec4538ac82324f0f33c9dc5fd5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for requests_unixsocket2-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 701fcd49d74bc0f759bbe45c4dfda0045fd89652948c2b473b1a312214c3770b
MD5 1645389d9099dac77c882ecaefa07433
BLAKE2b-256 4334b1072b2b1310572d8b801adcf3b148197eea2f8207f3750f73fcd2a6db5d

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