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.2.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.2-py3-none-any.whl (14.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: green_screen_client-1.2.2.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.2.tar.gz
Algorithm Hash digest
SHA256 a4f080d40d01f8ab2910b82b4876f115b57afb313caaff0a78ded6c276948c2d
MD5 df58a8bd4c2ff27d16652e3bd1b00321
BLAKE2b-256 12e122af295645539f82b9f7bfd8dadc04bb3ccf5807c02fc2198367df56c005

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for green_screen_client-1.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 ca3eb5fa34f5c9a15bb1be22b0ef0f1606826e4fec974a0dd60c64ec44ee0efc
MD5 113256844653cdb333fb033a2149575b
BLAKE2b-256 cf10e24931a6620ae71d88e3a14fb9184e9fa8c81c92c10a3443ab2844cae53d

See more details on using hashes here.

Provenance

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