Tornado websocket backend for the Xterm.js Javascript terminal emulator library.
Project description
Terminado
This is a Tornado websocket backend for the Xterm.js Javascript terminal emulator library.
It evolved out of pyxterm, which was part of GraphTerm (as lineterm.py), v0.57.0 (2014-07-18), and ultimately derived from the public-domain Ajaxterm code, v0.11 (2008-11-13) (also on Github as part of QWeb).
Modules:
terminado.management
: controls launching virtual terminals, connecting them to Tornado's event loop, and closing them down.terminado.websocket
: Provides a websocket handler for communicating with a terminal.terminado.uimodule
: Provides aTerminal
Tornado UI Module.
JS:
terminado/_static/terminado.js
: A lightweight wrapper to set up a term.js terminal with a websocket.
Local Installation:
$ pip install -e .[test]
Usage example:
import os.path
import tornado.web
import tornado.ioloop
# This demo requires tornado_xstatic and XStatic-term.js
import tornado_xstatic
import terminado
STATIC_DIR = os.path.join(os.path.dirname(terminado.__file__), "_static")
class TerminalPageHandler(tornado.web.RequestHandler):
def get(self):
return self.render(
"termpage.html",
static=self.static_url,
xstatic=self.application.settings["xstatic_url"],
ws_url_path="/websocket",
)
if __name__ == "__main__":
term_manager = terminado.SingleTermManager(shell_command=["bash"])
handlers = [
(r"/websocket", terminado.TermSocket, {"term_manager": term_manager}),
(r"/", TerminalPageHandler),
(
r"/xstatic/(.*)",
tornado_xstatic.XStaticFileHandler,
{"allowed_modules": ["termjs"]},
),
]
app = tornado.web.Application(
handlers,
static_path=STATIC_DIR,
xstatic_url=tornado_xstatic.url_maker("/xstatic/"),
)
# Serve at http://localhost:8765/ N.B. Leaving out 'localhost' here will
# work, but it will listen on the public network interface as well.
# Given what terminado does, that would be rather a security hole.
app.listen(8765, "localhost")
try:
tornado.ioloop.IOLoop.instance().start()
finally:
term_manager.shutdown()
See the demos
directory for
more examples. This is a simplified version of the single.py
demo.
Run the unit tests with:
$ pytest
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
terminado-0.18.1.tar.gz
(32.7 kB
view hashes)
Built Distribution
terminado-0.18.1-py3-none-any.whl
(14.2 kB
view hashes)
Close
Hashes for terminado-0.18.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | a4468e1b37bb318f8a86514f65814e1afc977cf29b3992a4500d9dd305dcceb0 |
|
MD5 | 076268047feb0fd0f9473aa8ceddd51d |
|
BLAKE2b-256 | 6a9e2064975477fdc887e47ad42157e214526dcad8f317a948dee17e1659a62f |