mirror of https://github.com/huashengdun/webssh
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
123 lines
3.7 KiB
123 lines
3.7 KiB
#!/usr/bin/env python |
|
|
|
# Copyright (C) 2003-2007 Robey Pointer <robeypointer@gmail.com> |
|
# |
|
# This file is part of paramiko. |
|
# |
|
# Paramiko is free software; you can redistribute it and/or modify it under the |
|
# terms of the GNU Lesser General Public License as published by the Free |
|
# Software Foundation; either version 2.1 of the License, or (at your option) |
|
# any later version. |
|
# |
|
# Paramiko is distributed in the hope that it will be useful, but WITHOUT ANY |
|
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR |
|
# A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more |
|
# details. |
|
# |
|
# You should have received a copy of the GNU Lesser General Public License |
|
# along with Paramiko; if not, write to the Free Software Foundation, Inc., |
|
# 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. |
|
|
|
from binascii import hexlify |
|
import socket |
|
# import sys |
|
import threading |
|
# import traceback |
|
|
|
import paramiko |
|
from paramiko.py3compat import u, decodebytes |
|
|
|
|
|
# setup logging |
|
paramiko.util.log_to_file('tests/sshserver.log') |
|
|
|
host_key = paramiko.RSAKey(filename='tests/test_rsa.key') |
|
# host_key = paramiko.DSSKey(filename='test_dss.key') |
|
|
|
print('Read key: ' + u(hexlify(host_key.get_fingerprint()))) |
|
|
|
|
|
class Server (paramiko.ServerInterface): |
|
# 'data' is the output of base64.b64encode(key) |
|
# (using the "user_rsa_key" files) |
|
data = (b'AAAAB3NzaC1yc2EAAAABIwAAAIEAyO4it3fHlmGZWJaGrfeHOVY7RWO3P9M7hp' |
|
b'fAu7jJ2d7eothvfeuoRFtJwhUmZDluRdFyhFY/hFAh76PJKGAusIqIQKlkJxMC' |
|
b'KDqIexkgHAfID/6mqvmnSJf0b5W8v5h2pI/stOSwTQ+pxVhwJ9ctYDhRSlF0iT' |
|
b'UWT10hcuO4Ks8=') |
|
good_pub_key = paramiko.RSAKey(data=decodebytes(data)) |
|
|
|
def __init__(self): |
|
self.event = threading.Event() |
|
|
|
def check_channel_request(self, kind, chanid): |
|
if kind == 'session': |
|
return paramiko.OPEN_SUCCEEDED |
|
return paramiko.OPEN_FAILED_ADMINISTRATIVELY_PROHIBITED |
|
|
|
def check_auth_password(self, username, password): |
|
if (username == 'robey') and (password == 'foo'): |
|
return paramiko.AUTH_SUCCESSFUL |
|
return paramiko.AUTH_FAILED |
|
|
|
def check_auth_publickey(self, username, key): |
|
print('Auth attempt with key: ' + u(hexlify(key.get_fingerprint()))) |
|
if (username == 'robey') and (key == self.good_pub_key): |
|
return paramiko.AUTH_SUCCESSFUL |
|
return paramiko.AUTH_FAILED |
|
|
|
def get_allowed_auths(self, username): |
|
return 'password,publickey' |
|
|
|
def check_channel_shell_request(self, channel): |
|
self.event.set() |
|
return True |
|
|
|
def check_channel_pty_request(self, channel, term, width, height, |
|
pixelwidth, pixelheight, modes): |
|
return True |
|
|
|
|
|
def run_ssh_server(app): |
|
# now connect |
|
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) |
|
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) |
|
sock.bind(('127.0.0.1', 2200)) |
|
sock.listen(100) |
|
|
|
while not app._tear_down: |
|
client, addr = sock.accept() |
|
print('Got a connection!') |
|
|
|
t = paramiko.Transport(client) |
|
t.load_server_moduli() |
|
t.add_server_key(host_key) |
|
server = Server() |
|
try: |
|
t.start_server(server=server) |
|
except Exception as e: |
|
print(e) |
|
continue |
|
|
|
# wait for auth |
|
chan = t.accept(20) |
|
if chan is None: |
|
print('*** No channel.') |
|
continue |
|
|
|
print('Authenticated!') |
|
|
|
server.event.wait(10) |
|
if not server.event.is_set(): |
|
print('*** Client never asked for a shell.') |
|
continue |
|
|
|
chan.send('\r\n\r\nWelcome!\r\n\r\n') |
|
|
|
try: |
|
sock.close() |
|
except Exception: |
|
pass |
|
|
|
|
|
if __name__ == '__main__': |
|
run_ssh_server(False)
|
|
|