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.2.1.tar.gz (12.5 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.2.1-py3-none-any.whl (14.2 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for green_screen_client-1.2.1.tar.gz
Algorithm Hash digest
SHA256 ee89b1e091d4e08d898f07128b49930f697d9801fd98879c11413042c49f0cb1
MD5 8cc9272aecfd9a8df7ed37ba47f7d8c7
BLAKE2b-256 d80b9ec1d1893bc05bfffd71ffb4fb6b58c2a6f92e4c483427a83ba404bdb34c

See more details on using hashes here.

Provenance

The following attestation bundles were made for green_screen_client-1.2.1.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.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for green_screen_client-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8792db286937b918ca1c9b56cccc6f531b1bf2da5802f1afdcb9b6fbdcf25ef4
MD5 c156f08a99eb02e5de961d48af2340fa
BLAKE2b-256 8eaf4bca9094965a025d4a6bfe741f3c0abafce848510f8b7bd8094213d3e06c

See more details on using hashes here.

Provenance

The following attestation bundles were made for green_screen_client-1.2.1-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