Skip to main content

Thin Python client for the pupptyeer daemon (NDJSON over a unix socket).

Project description

pupptyeer-client

Thin Python client for the pupptyeer daemon: NDJSON over a unix socket, standard library only (no dependencies).

pupptyeer is a local daemon that owns persistent PTY sessions. This client talks to it over the daemon's unix socket; it does not start the daemon. Install and run the daemon separately (see the main README), or npm i -g pupptyeer for the prebuilt binary.

Install

pip install pupptyeer-client

Requires Python >= 3.8.

Usage

import os, sys
from pupptyeer_client import PupptyeerClient

# Connect to the daemon's unix socket (the daemon exports its path via $PUPPTYEER_SOCK).
c = PupptyeerClient.connect(os.environ["PUPPTYEER_SOCK"])

# Spawn a command in a fresh PTY; get back a session id.
sid = c.new_session(command="bash", cols=80, rows=24)

# Stream the session's live output, then attach this connection.
c.on_output(sid, lambda b: sys.stdout.buffer.write(b))
c.attach(sid, cols=80, rows=24)

# Drive it.
c.write_pane(sid, "echo hello\n")

# Read the daemon's authoritative rendered screen once the PTY goes quiet.
screen = c.capture_screen(sid, settle_ms=50)
print("\n".join(screen.lines))

c.close()  # sessions outlive the client

See the protocol spec for the full verb set (new_session, list_sessions, attach/detach, write_pane, capture_pane, resize, kill, gc).

License

MIT

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

pupptyeer_client-0.7.0.tar.gz (5.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pupptyeer_client-0.7.0-py3-none-any.whl (5.9 kB view details)

Uploaded Python 3

File details

Details for the file pupptyeer_client-0.7.0.tar.gz.

File metadata

  • Download URL: pupptyeer_client-0.7.0.tar.gz
  • Upload date:
  • Size: 5.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for pupptyeer_client-0.7.0.tar.gz
Algorithm Hash digest
SHA256 fa799ea1234ae750ea30b437f1730ec6278682b86a764516c94e3265c2a11232
MD5 5a26d9a7fcb1df56ad91fb7e255a5d6f
BLAKE2b-256 70d168777a2ee9b137c602ff830db108d3e50a4e96dd11ed28d5195bc4a23cf9

See more details on using hashes here.

Provenance

The following attestation bundles were made for pupptyeer_client-0.7.0.tar.gz:

Publisher: release.yml on PeterSR/pupptyeer

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pupptyeer_client-0.7.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pupptyeer_client-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1b5a3607a25b58942d610ff6789f7f6c32cc51164758b60c863bf14e0709de75
MD5 fba8e00bd9d97f4eb568c25837361237
BLAKE2b-256 ce4ca146e3eff4940b1cf8cfb28b8c29641ef0ecfdccb576ebb39a343354e91a

See more details on using hashes here.

Provenance

The following attestation bundles were made for pupptyeer_client-0.7.0-py3-none-any.whl:

Publisher: release.yml on PeterSR/pupptyeer

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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