Skip to main content

Telnet-3270 to Z tool and library

Project description

CI/CD Status PyPi Status PyPi Downloads OpenSSF Best Practices

tnz

Use a standard terminal emulator as a 3270 terminal interface. Write scripts to automate 3270 terminal interaction. This is both a 3270 terminal emulator and a Python libary. The zti module provides a 3270 user interface through a Windows Command Prompt or a unix/ascii terminal. The tnz module handles the interface to the 3270 data stream. The ati module allows for easier 3270 terminal automation.

Features

  • Runs on many platforms (including z/OS)
  • Secure telnet (TLS) by default
  • Manages multiple 3270 sessions at the same time
  • Lightweight - does not duplicate standard terminal function
  • Code page 310 for APL graphic symbols (i.e. 3278T terminal type)

Installing

Python 3.6 or later is required. Although not required, on platforms other than z/OS, it is suggested you also install the ebcdic package from PyPI. Use pip to install the latest tnz:

pip3 install ebcdic tnz

Usage

Automation

See examples to get started writing a script to automate 3270 interaction.

Emulator

Run the installed zti (Z Terminal Interface) script to start the emulator:

zti

If your path is not set up for running the installed zti console script, you can run zti with python -m tnz.zti instead.

Starting zti takes you into the zti command line interface shell. Key tab for command completion, up/down for command history. screenshot

The goto command takes you to a full screen 3270 interface. When space is available in the terminal screen/window, a status line is provided as well as a session selector.

The basic syntax of goto is:

goto fully-qualified-host-name[:port]

screenshot

In Windows, the Lucida Console font works well with graphic character APL symbols exploited by ISPF. screenshot

Large and arbitrarily-sized screens are supported. screenshot

Standard unix/ascii terminals are supported. In the screenshot below, PuTTY is used as the terminal emulator. The connection was made from PuTTY to z/OS via ssh and zti is running on z/OS. screenshot

The code in this repository aims to be portable. To achieve this, the number of dependencies is kept to a minimum. The only hard requirement across platforms is Python and the Python Standard Library. Though it is likely you will also want additional ebcdic code pages in order to use your code page of choice (i.e. the ebcdic package).

Emulator Features

  • Use Alt+letter to access ISPF menus
  • Mouse click sets cursor position
  • Mouse double-click sets cursor position and send Enter
  • Use any EBCDIC code page available to Python
  • Use of code page 310 for APL graphic symbols
  • Paste multiline block of text

Running zti on Windows

The trapping of the keyboard disables keyboard shortcuts documented in the Control-menu->Edit menu. But the functions can still be accessed through the Control-menu. For example: mouse click top-left corner, E (Edit), F (Find) to find text.

To copy text in Command Prompt, make sure that the Quick Edit Mode option is selected in the Properties accessed through the Control-menu. Then you can hold Shift while using the mouse to select text. Once the text is selected, press Enter to copy the text. There are other ways to select text, but I this to be the easiest.

Before establishing a session, get the window sized the way you want it. Window resizing is not handled well in Windows. If you do resize, just use Esc to get to the command prompt then goto to get back to the session.

Control-menu->Properties will take you to properties for the terminal. The character size and font can be set. I recommend Lucida Console - it is readable and the graphic symbols are fairly good at connecting like they are supposed to.

Documentation

See here.

For additional details, see docstrings in source code.

Contributing

See CONTRIBUTING.md.

Acknowledgments

Hats off to the team responsible for the IBM internal Automated Task Interpreter (ATI) tool: Richard Lynch, Karen Eickemeyer, and Ronald Barber.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

tnz-0.5.2-py3-none-any.whl (128.2 kB view details)

Uploaded Python 3

File details

Details for the file tnz-0.5.2-py3-none-any.whl.

File metadata

  • Download URL: tnz-0.5.2-py3-none-any.whl
  • Upload date:
  • Size: 128.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for tnz-0.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 402ecc17122c7b3e8446be60c7782080b080f2d2eca346836c40269f7a8a81dc
MD5 2da5e9807f373fbe56b549c630cd8f90
BLAKE2b-256 c21f012a515fd6c1469cac4975715e0d9eee37724c8da753d3c1567ff875c300

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