PyserSSH is a free and open-source Python library designed to facilitate the creation of customizable SSH terminal servers. Initially developed for research purposes to address the lack of suitable SSH server libraries in Python, PyserSSH provides a flexible and user-friendly solution for implementing SSH servers, making it easier for developers to handle user interactions and command processing.
The project was started by a solo developer to create a more accessible and flexible tool for managing SSH connections and commands. It offers a simplified API compared to other libraries, such as Paramiko, SSHim, and Twisted, which are either outdated or complex for new users.
This project is part from damp11113-library
PyserSSH version 1.0 (real filename is "test277.py") was created in 2023/9/3 for experimental purposes only. Because I couldn't find the best ssh server library for python and I started this project only for research. But I have time to develop this research into a real library for use. In software or server.
Read full history from docs
Install from pypi
pip install PyserSSH
Install with openRemoDesk protocol
pip install PyserSSH[RemoDesk]
Install from Github
pip install git+https://github.com/damp11113/PyserSSH.git
Install from DPCloudev Git
pip install git+https://git.damp11113.xyz/DPSoftware-Foundation/PyserSSH.git
This Server use port 2222 for default port
from PyserSSH import Server, Send, AccountManager
useraccount = AccountManager(anyuser=True)
ssh = Server(useraccount)
@ssh.on_user("command")
def command(client, command: str):
if command == "hello":
Send(client, "world!")
ssh.run("your private key file")
This example you can connect with ssh admin@localhost -p 2222
and press enter on login
If you input hello
the response is world
Warning
For use in product please generate new private key! If you still use this demo private key maybe your product getting hacked! up to 90%. Please don't use this demo private key for real product.
Recording.2024-03-17.205602.mp4
I intend to leaked private key because that key i generated new. I recommend to generate new key if you want to use on your host because that key is for demo only. why i talk about this? because when i push private key into this repo in next 5 min++ i getting new email from GitGuardian. in that email say " GitGuardian has detected the following RSA Private Key exposed within your GitHub account" i dont knows what is GitGuardian and i not install this app into my account.