Skip to main content

Write Command to Virtual Terminal.

Project description

wrtty

wrtty is a Python script to write commands to a virtual terminal.

Note: wrtty elevates permissions with sudo because it needs root permissions.

By "virtual terminal", it is meant what is often called the "console", which is slightly different. In this case it is the "virtual terminal" controlled by commands such as chvt (e.g. sudo chvt 3).

Writing to the console can make text appear, but it won't make it execute as a command in a shell. Writing to the virtual terminal, such as /dev/tty1, commands can be run, login on console, etc.

This may be used in a situation where you have ssh access to a machine, but no X/Wayland/VNC running, but you need to run as if you are in front of the machine. This in effect simulates an operator standing in front of a machine, typing on the local keyboard.

Install

Quick install from PyPI. Python setups vary correctly, similar to this should work, such as with Debian:

sudo apt install python3-venv python3-pip
pip install -U setuptools pip wheel
pip install wrtty

PyPi project info:

Help

Help output:

$ wrtty --help
usage: wrtty [-h] [-s STRING] [-t TTY]

write string to tty virtual terminal

options:
  -h, --help            show this help message and exit
  -s STRING, --string STRING
                        string to write (default echo)
  -t TTY, --tty TTY     TTY to use (default /dev/tty1)

Use

Use examples:

wrtty
wrtty -s "date -uR"
wrtty -t /dev/tty2 --cmd "clear"

Build

Developers build thusly.

Under Debian stable (Bookworm/12).

Python setup, suit to taste:

git clone https://spacecruft.org/deepcrayon/wrtty
cd wrtty/
pyenv local 3.11 # if pyenv
python -m venv venv
source venv/bin/activate
pip install -U setuptools pip wheel poetry
poetry install

Sources

Git source code repository:

Status

WORKSFORME.

Upstream

I don't know of another application that specifically does this. There are a few old snippets in perl, C, and Python in StackExchange and blogs, but just small examples.

Some linkies:

fcntl — The fcntl and ioctl system calls

Faking input with IOCTL/TIOCSTI

RichardBronosky writevt.c

Construct a command by putting a string into a tty

Unable to fake terminal input with termios.TIOCSTI

send command to another terminal

Can I send some text to the STDIN of an active process running in a screen session?

Linux Kernel Note

I see this configuration option and note in a 6.5 kernel:

CONFIG_LEGACY_TIOCSTI:
Historically the kernel has allowed TIOCSTI, which will push
characters into a controlling TTY. This continues to be used
as a malicious privilege escalation mechanism, and provides no
meaningful real-world utility any more. Its use is considered
a dangerous legacy operation, and can be disabled on most
systems.

Say Y here only if you have confirmed that your system's
userspace depends on this functionality to continue operating
normally.

Processes which run with CAP_SYS_ADMIN, such as BRLTTY, can
use TIOCSTI even when this is set to N.

This functionality can be changed at runtime with the
dev.tty.legacy_tiocsti sysctl. This configuration option sets
the default value of the sysctl.

Symbol: LEGACY_TIOCSTI [=y]
Type  : bool
Defined at drivers/tty/Kconfig:152
Prompt: Allow legacy TIOCSTI usage
Depends on: TTY [=y]
  Location:
    -> Device Drivers
      -> Character devices
        -> Enable TTY (TTY [=y])
          -> Allow legacy TIOCSTI usage (LEGACY_TIOCSTI [=y])

:)

License

MIT.

Copyright © 2023, 2024, Jeff Moe.

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

wrtty-0.6.1.tar.gz (4.6 kB view details)

Uploaded Source

Built Distribution

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

wrtty-0.6.1-py3-none-any.whl (5.6 kB view details)

Uploaded Python 3

File details

Details for the file wrtty-0.6.1.tar.gz.

File metadata

  • Download URL: wrtty-0.6.1.tar.gz
  • Upload date:
  • Size: 4.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.11.6

File hashes

Hashes for wrtty-0.6.1.tar.gz
Algorithm Hash digest
SHA256 b764fa3cf8b7b5bf4ab8d0e4285a356c2b8d8b0ab467f2dfb30b493b909bd7e7
MD5 2cf3c01f2b4d4688044150232acb5332
BLAKE2b-256 7488bcce0e924130b77a9ed3b550e441351dd43894885fc6101d391de3acaae0

See more details on using hashes here.

File details

Details for the file wrtty-0.6.1-py3-none-any.whl.

File metadata

  • Download URL: wrtty-0.6.1-py3-none-any.whl
  • Upload date:
  • Size: 5.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.11.6

File hashes

Hashes for wrtty-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 226220fe8807e2808eba81f37ad81e62ee6aed8220692c1b4ac6e8d2406de75d
MD5 e8b3b3f4f8018dea37fcaefe907e999d
BLAKE2b-256 26ef083fa1505e48b420d0b57d833e578a28e4e0bb83676ef26bb4e62a7dbf6e

See more details on using hashes here.

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