Interactive embedded web terminal
Project description
IEWT(Interactive Embedded Web Terminal)
This release provides several improvements over the previous ones.
Tmux has been integrated with the application. All terminals will hence be created upon tmux. This provides a lot of advantages:
The terminals as well as the commands that run on it are preserved in the events of page reload. Also, the application tracks commands for status and time even in the case of a reload.
No need for a database server. Hence the application is simpler to configure and also lighter.
Frontend is simplified since command id need not be explicitly maintained for command tracking.
There is no need to prevent sessions from closing immediately(to preserve commands during reload events). Hence the application is more flexible and simpler.
The logging has been improved. A separate logs directory will be created. One log per terminal session will be created in the logs directory.
No logging is made on the browser console to prevent clogging by unnecessary messages.
The application makes a post request with all command information to a server on port 5000 on localhost(only if it is available). Hence, the other server can be primarily used to store command information for future analysis or other purposes and its implementation is completely left to the user. This is suitable for a MicroServices setup for optional analysis. The app first checks if the server is alive by pinging localhost:5000/test. If successful, it makes post requests to localhost:5000/command.
The microservices setup is further strengthened by the attempt to abstract several functions from the backend to the frontend. For example, the special commands(script,exit) are checked in the frontend instead of the backend. The frontend also generates an internal command id which the backend generated previously. The backend is only responsible for the terminals, command execution and tracking of commands.
Note: The command execution time obtained in the case of reload events is the time between the restoration of the terminal and the retrieval of the status and not the actual execution time.
Installation:
Run pip install iewt to install iewt package.
To test the application you need to have
A computer/VM with a Unix(Linux, MacOS etc.) OS.
Tmux installed on the computer/VM.
SSH server running on the computer/VM.
Network access to the SSH server.
Once all the above steps are performed, run the command iewt. Open a browser and goto localhost:8888
Enter the SSH credentials in the form at the bottom of the screen. The terminal will appear soon after. To automatically execute commands, type the commands in the input field and click on the send command button. The command is executed in the terminal and after its completion its time will appear in the readonly input field below the command status button. The command status turns green on success and red on failure.
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
Built Distribution
File details
Details for the file iewt-1.2.0.tar.gz
.
File metadata
- Download URL: iewt-1.2.0.tar.gz
- Upload date:
- Size: 163.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 13d7fe93a6b9bf63f17078bbbc4a8c0a4abc4583c823aaf2dc93dadf851c0060 |
|
MD5 | 86f184db8267a78b60a0e849c7197e3b |
|
BLAKE2b-256 | 9662392abd12470e3391ecbc20e7c454de0ce5c6a6671ab5f7b3ee88983d8167 |
File details
Details for the file iewt-1.2.0-py2.py3-none-any.whl
.
File metadata
- Download URL: iewt-1.2.0-py2.py3-none-any.whl
- Upload date:
- Size: 165.9 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e72d14b166a52544ae752ac0ea8c4d4b78ae117d67a730f2e8cff67f8a7b660d |
|
MD5 | 2eb63d7160fa42175666fe4fabb95eb1 |
|
BLAKE2b-256 | d303cbf7ce9ecd7a1c6536a26c84c39287a7b63d48baeeb00b8c0c283509d202 |