Skip to main content

A lightweight UTF-8 web based terminal

Project description

Achilterm is a lightweight UTF-8 web based terminal.

https://raw.githubusercontent.com/fgallaire/achilterm/master/img/achilterm.png

Achilterm is written in Python (and some AJAX javascript for client side).

Achilterm is very simple to install on Linux, MacOS X, FreeBSD, Solaris, cygwin and any Unix that runs Python.

Achilterm is initially forked from Ajaxterm which was inspired by Anyterm.

Achilterm is developed by Florent Gallaire fgallaire@gmail.com.

Website: http://fgallaire.github.io/achilterm.

Download and Install

To install the last stable version from PyPI:

$ sudo pip install achilterm

To install the development version from GitHub:

$ git clone https://github.com/fgallaire/achilterm
$ cd achilterm
$ sudo python setup.py install

To run Achilterm after installation:

$ achilterm

To run Achilterm from the source without installation:

$ ./achilterm/achilterm.py

Then point your browser to this URL: http://localhost:8022/

Documentation and Caveats

  • Achilterm support Python 2.5 and above and Python 3.2 and above

  • Achilterm require WebOb >= 1.0

  • If run as root achilterm will run /bin/login, otherwise it will run ssh localhost. To use an other command use the -c option.

  • By default Achilterm only listen at 127.0.0.1:8022. For remote access, it is strongly recommended to use https SSL/TLS, and that is simple to configure if you use the apache web server using mod_proxy.

    Using ssl will also speed up achilterm (probably because of keepalive).

  • Using GET HTTP request seems to speed up achilterm, just click on GET in the interface, but be warned that your keystrokes might be loggued (by apache or any proxy). I usually enable it after the login.

Achiltermlite

Achiltermlite is a stripped-down client-side version of Achilterm.

https://raw.githubusercontent.com/fgallaire/achilterm/master/img/achiltermlite.png

Commandline usage

usage: achilterm [options]

options:
  --version                  show program's version number and exit
  -h, --help                 show this help message and exit
  -p PORT, --port=PORT       set the TCP port (default: 8022)
  -c CMD, --command=CMD      set the command (default: /bin/login or ssh localhost)
  -l, --log                  log requests to stderr (default: quiet mode)
  -d, --daemon               run as daemon in the background
  -P PIDFILE, --pidfile=PIDFILE
                            set the pidfile (default: /var/run/achilterm.pid)
  -i INDEX_FILE, --index=INDEX_FILE
                             default index file (default: achilterm.html)
  -u UID, --uid=UID          set the daemon's user id
  -L, --lite                 use Achiltermlite
  -w WIDTH, --width=WIDTH    set the width (default: 80)
  -H HEIGHT, --height=HEIGHT set the height (default: 25)

Configuration example

Listen 443
NameVirtualHost *:443

<VirtualHost *:443>
   ServerName localhost
   SSLEngine On
   SSLCertificateKeyFile ssl/apache.pem
   SSLCertificateFile ssl/apache.pem

   ProxyRequests Off
   <Proxy *>
           Order deny,allow
           Allow from all
   </Proxy>
   ProxyPass /achilterm/ http://localhost:8022/
   ProxyPassReverse /achilterm/ http://localhost:8022/
</VirtualHost>

Old versions

  • Achilterm 0.13 require Python 2.5 and above

Older Achilterm versions only support latin1, if you use Ubuntu or any LANG==en_US.UTF-8 distribution don’t forget to $ unset LANG:

  • Achilterm 0.12 require WebOb >= 1.2 (use it with Python 2.6 and 2.7)

  • Achilterm 0.11 require WebOb < 1.0 (use it with Python 2.5)

Compared to anyterm

  • There are no partial updates, achilterm updates either all the screen or nothing. That make the code simpler and I also think it’s faster. HTTP replies are always gzencoded. When used in 80x25 mode, almost all of them are below the 1500 bytes (size of an ethernet frame) and we just replace the screen with the reply (no javascript string handling).

  • Achilterm polls the server for updates with an exponentially growing timeout when the screen hasn’t changed. The timeout is also resetted as soon as a key is pressed. Anyterm blocks on a pending request and use a parallel connection for keypresses. The anyterm approch is better when there aren’t any keypress.

License

Achilterm files are released under the GNU AGPLv3 or above license.

Achilterm codebase from Ajaxterm by Antony Lesuisse (email: al AT udev.org), License Public Domain.

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

Achilterm-0.21.tar.gz (106.3 kB view details)

Uploaded Source

Built Distribution

Achilterm-0.21-py2.py3-none-any.whl (22.0 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file Achilterm-0.21.tar.gz.

File metadata

  • Download URL: Achilterm-0.21.tar.gz
  • Upload date:
  • Size: 106.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for Achilterm-0.21.tar.gz
Algorithm Hash digest
SHA256 06a0a5134451364714aa65c5c19f3dcbbb98a9bd8bf599e2201abfe420c62c0a
MD5 e7c581a527d4b1b7fd117e442f3b6063
BLAKE2b-256 b84135e0b1bf58cf4cb55cdee49d4579cf927b4f7f862b4c574a6fcef35cc22d

See more details on using hashes here.

File details

Details for the file Achilterm-0.21-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for Achilterm-0.21-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 c6d386583c8aea8a6e0e082a98e59644143be45a16369f45a4551725ca94af06
MD5 174487f5cf68965cf6cc78fdc7fee65d
BLAKE2b-256 11d30b879c80e1dfd72bcc08856b6074630ecbdaa568d2d595ca982199b577e6

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