Skip to main content

AsyncSSH: Asynchronous SSHv2 client and server library

Project description

AsyncSSH is a Python package which provides an asynchronous client and server implementation of the SSHv2 protocol on top of the Python 3.6+ asyncio framework.

import asyncio, asyncssh, sys

async def run_client():
    async with asyncssh.connect('localhost') as conn:
        result = await conn.run('echo "Hello!"', check=True)
        print(result.stdout, end='')

try:
    asyncio.get_event_loop().run_until_complete(run_client())
except (OSError, asyncssh.Error) as exc:
    sys.exit('SSH connection failed: ' + str(exc))

Check out the examples to get started!

Features

  • Full support for SSHv2, SFTP, and SCP client and server functions

    • Shell, command, and subsystem channels

    • Environment variables, terminal type, and window size

    • Direct and forwarded TCP/IP channels

    • OpenSSH-compatible direct and forwarded UNIX domain socket channels

    • Local and remote TCP/IP port forwarding

    • Local and remote UNIX domain socket forwarding

    • Dynamic TCP/IP port forwarding via SOCKS

    • X11 forwarding support on both the client and the server

    • SFTP protocol version 3 with OpenSSH extensions

    • SCP protocol support, including third-party remote to remote copies

  • Multiple simultaneous sessions on a single SSH connection

  • Multiple SSH connections in a single event loop

  • Byte and string based I/O with settable encoding

  • A variety of key exchange, encryption, and MAC algorithms

  • Support for gzip compression

    • Including OpenSSH variant to delay compression until after auth

  • User and host-based public key, password, and keyboard-interactive authentication methods

  • Many types and formats of public keys and certificates

    • Including support for X.509 certificates as defined in RFC 6187

  • Support for accessing keys managed by ssh-agent on UNIX systems

    • Including agent forwarding support on both the client and the server

  • Support for accessing keys managed by PuTTY’s Pageant agent on Windows

  • Support for accessing host keys via OpenSSH’s ssh-keysign

  • OpenSSH-style known_hosts file support

  • OpenSSH-style authorized_keys file support

  • Compatibility with OpenSSH “Encrypt then MAC” option for better security

  • Time and byte-count based session key renegotiation

  • Designed to be easy to extend to support new forms of key exchange, authentication, encryption, and compression algorithms

License

This package is released under the following terms:

Copyright (c) 2013-2019 by Ron Frederick <ronf@timeheart.net> and others.

This program and the accompanying materials are made available under the terms of the Eclipse Public License v2.0 which accompanies this distribution and is available at:

http://www.eclipse.org/legal/epl-2.0/

This program may also be made available under the following secondary licenses when the conditions for such availability set forth in the Eclipse Public License v2.0 are satisfied:

GNU General Public License, Version 2.0, or any later versions of that license

SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later

For more information about this license, please see the Eclipse Public License FAQ.

Prerequisites

To use AsyncSSH 2.0 or later, you need the following:

  • Python 3.6 or later

  • cryptography (PyCA) 2.8 or later

Installation

Install AsyncSSH by running:

pip install asyncssh

Optional Extras

There are some optional modules you can install to enable additional functionality:

AsyncSSH defines the following optional PyPI extra packages to make it easy to install any or all of these dependencies:

bcrypt
gssapi
libnacl
pyOpenSSL
pypiwin32

For example, to install bcrypt, gssapi, libnacl, and pyOpenSSL on UNIX, you can run:

pip install 'asyncssh[bcrypt,gssapi,libnacl,pyOpenSSL]'

To install bcrypt, libnacl, pyOpenSSL, and pypiwin32 on Windows, you can run:

pip install 'asyncssh[bcrypt,libnacl,pyOpenSSL,pypiwin32]'

Note that you will still need to manually install the libsodium library listed above for libnacl to work correctly and/or libnettle for UMAC support. Unfortunately, since libsodium and libnettle are not Python packages, they cannot be directly installed using pip.

Installing the development branch

If you would like to install the development branch of asyncssh directly from Github, you can use the following command to do this:

pip install git+https://github.com/ronf/asyncssh@develop

Mailing Lists

Three mailing lists are available for AsyncSSH:

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

asyncssh-2.0.0.tar.gz (322.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

asyncssh-2.0.0-py3-none-any.whl (289.5 kB view details)

Uploaded Python 3

File details

Details for the file asyncssh-2.0.0.tar.gz.

File metadata

  • Download URL: asyncssh-2.0.0.tar.gz
  • Upload date:
  • Size: 322.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Python-urllib/3.6

File hashes

Hashes for asyncssh-2.0.0.tar.gz
Algorithm Hash digest
SHA256 3642ec4828757b835a7922fad9dc21c89705ebd06a15a1dcbfbc0182ffc454bc
MD5 aeabd5fda18b05315e8f20482a38b03b
BLAKE2b-256 e738cebc20ffc85b8465cdcfda68e11b9171e3a93b0a8519a641b4db78c912a0

See more details on using hashes here.

File details

Details for the file asyncssh-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: asyncssh-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 289.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Python-urllib/3.6

File hashes

Hashes for asyncssh-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 606d1c6fe5dec4a3bebcbe34d348797dfa8dec663d0c179f387804bd2379a3f3
MD5 4fbd0d919e31da59bec27bc5c07133e9
BLAKE2b-256 e26ee71dfe916e9e889f8825d76abb43fd2109caba77491ab37a4aa24b4e24d6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page