Skip to main content

Python client for green-screen-proxy — typed async REST + WebSocket adapter for TN5250/TN3270/VT/HP6530 terminal emulation

Project description

green-screen-client

Python client for green-screen-proxy — typed async REST + WebSocket adapter for TN5250, TN3270, VT, and HP 6530 terminal emulation.

This is a standalone package. It is not bundled with or required by green-screen-react — install it separately when your integration runs on Python.

Install

pip install green-screen-client

Three layers, pick what fits

1. Low-level REST (RestClient)

Thin wrapper over the proxy's HTTP endpoints. One method per endpoint, dataclasses in/out.

from green_screen_client import RestClient, ConnectConfig

async with RestClient("http://proxy:3001") as client:
    await client.connect(ConnectConfig(
        host="pub400.com",
        protocol="tn5250",
        username="alice",
        password="secret",
    ))
    screen = await client.get_screen()
    print(screen.content)
    await client.send_text("1")
    await client.send_key("Enter")

2. Low-level WebSocket (WsClient)

Single WebSocket, real-time screen pushes, reattach for session recovery, lifecycle events (session.lost, session.resumed).

from green_screen_client import WsClient

async with WsClient("http://proxy:3001") as client:
    await client.reattach("abc-123")   # reattach after page reload / process restart
    client.on_screen(lambda s: print("screen update:", s.cursor_row, s.cursor_col))
    client.on_session_lost(lambda sid, status: print("lost:", sid, status.status))
    async for event in client.events():
        if event.type == "screen":
            ...

3. High-level ProxyTerminalClient + ScreenBuffer

Drop-in shape for integrations that already read client.screen.fields, client.screen.cursor_row, etc.

from green_screen_client import ProxyTerminalClient

async with ProxyTerminalClient("http://proxy:3001", host="pub400.com") as client:
    await client.login("alice", "secret")
    await client.send_key("PF3")
    print(client.screen.cursor_row, client.screen.cursor_col)
    for field in client.screen.fields:
        print(field)

v1.2.0 primitives

  • read_mdt(modified_only=True) — cheap post-write verification via per-field MDT bits.
  • resume_session(session_id) — REST probe for "is this session still alive?"
  • mark_authenticated(username) — flip session status after your own sign-on cascade (the proxy stays protocol-generic).
  • wait_for_fields(min_fields, timeout_ms=...) — wait until a form with N input fields appears.

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

green_screen_client-1.3.8.tar.gz (14.1 kB view details)

Uploaded Source

Built Distribution

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

green_screen_client-1.3.8-py3-none-any.whl (15.9 kB view details)

Uploaded Python 3

File details

Details for the file green_screen_client-1.3.8.tar.gz.

File metadata

  • Download URL: green_screen_client-1.3.8.tar.gz
  • Upload date:
  • Size: 14.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for green_screen_client-1.3.8.tar.gz
Algorithm Hash digest
SHA256 fcfd74c687d4dcbb5c362503e65bf4eb095c182162bae09cf9e39820d5871a9b
MD5 ea1219fcd0f6ee5388955f32205b0814
BLAKE2b-256 5371781f2a497fb95575b2da043b022cedbba199a3038956b72a1fdbea955c36

See more details on using hashes here.

Provenance

The following attestation bundles were made for green_screen_client-1.3.8.tar.gz:

Publisher: publish-pypi.yml on visionbridge-solutions/green-screen-react

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

File details

Details for the file green_screen_client-1.3.8-py3-none-any.whl.

File metadata

File hashes

Hashes for green_screen_client-1.3.8-py3-none-any.whl
Algorithm Hash digest
SHA256 59bedc628cddd982371b993ce4f6d9e0fef4fcc6be5f8ea8c0858c99a913a605
MD5 b968b91bd48813a908d74adca45e5508
BLAKE2b-256 780f46b4b807250d25860b8620854e27f7b1d642bd7ba0dfd77f6b721bb089b2

See more details on using hashes here.

Provenance

The following attestation bundles were made for green_screen_client-1.3.8-py3-none-any.whl:

Publisher: publish-pypi.yml on visionbridge-solutions/green-screen-react

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