Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/carlmontanari/ssh2net
Python 3.6+ SSH Client for network devices built on ssh2-python
https://github.com/carlmontanari/ssh2net
Last synced: 2 months ago
JSON representation
Python 3.6+ SSH Client for network devices built on ssh2-python
- Host: GitHub
- URL: https://github.com/carlmontanari/ssh2net
- Owner: carlmontanari
- License: mit
- Created: 2019-09-02T18:09:11.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2020-04-11T18:11:18.000Z (over 4 years ago)
- Last Synced: 2023-10-08T07:46:53.218Z (about 1 year ago)
- Language: Python
- Homepage: https://carlmontanari.github.io/ssh2net/
- Size: 416 KB
- Stars: 11
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
Check out [scrapli](https://github.com/carlmontanari/scrapli) instead, ssh2net's much improved successor!
![](https://github.com/carlmontanari/ssh2net/workflows/build/badge.svg)
[![PyPI version](https://badge.fury.io/py/ssh2net.svg)](https://badge.fury.io/py/ssh2net)
[![Python 3.6](https://img.shields.io/badge/python-3.6-blue.svg)](https://www.python.org/downloads/release/python-360/)
[![Python 3.7](https://img.shields.io/badge/python-3.7-blue.svg)](https://www.python.org/downloads/release/python-370/)
[![Python 3.8](https://img.shields.io/badge/python-3.8-blue.svg)](https://www.python.org/downloads/release/python-380/)
[![Code Style](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/ambv/black)ssh2net
=======Library focusing on connecting to and communicating with network devices via SSH. Built on [ssh2-python](https://github.com/ParallelSSH/ssh2-python) which provides bindings to libssh2.
ssh2net is focused on being lightweight and pluggable so that it *should* be flexible enough to be adapted to handle connecting to, sending commands, and reading output from most network devices.
# Documentation
Documentation is auto-generated [using pdoc3](https://github.com/pdoc3/pdoc). Documentation is linted (see Linting and Testing section) via [pydocstyle](https://github.com/PyCQA/pydocstyle/) and [darglint](https://github.com/terrencepreilly/darglint).
Documentation is hosted via GitHub Pages and can be found [here.](https://carlmontanari.github.io/ssh2net/docs/ssh2net/index.html) You can also view the readme as a web page [here.](https://carlmontanari.github.io/ssh2net/)
To regenerate documentation locally, use the following make command:
```
make docs
```# Platforms
In theory ssh2net should be able to connect to lots of different network devices. At the moment the following devices are included in the "functional" tests and should be pretty reliable:
- Cisco IOS-XE (tested on: 16.04.01)
- Cisco NX-OS (tested on: 9.2.4)
- Juniper JunOS (tested on: 17.3R2.10)
- Cisco IOS-XR (tested on: 6.5.3)I would like to add functional tests for:
- Arista EOS (currently blocked - at least for password based auth via keyboard_interactive)
Any additional platforms would likely not be included in the "core" platform (and therefore functional testing). Additional platforms could be considered, however a pre-requisite for additional platforms would be the capability to create vrnetlab containers for that platform.
As for platforms to *run* ssh2net on -- it has and will be tested on MacOS and Ubuntu regularly and should work on any POSIX system. It has had minimal testing on Windows, however I have no plans on supporting Windows as I don't have access or desire to do so. In general I believe everything other than the TextFSM support should work though!
## Platform Drivers
SSH2Net supports "core" and "community" platform drivers. This is similar to a "device_type" in Netmiko, for example. The intent of a "driver" is to handle device specific operations, to include privilege escalation and deescalation. The "core" drivers will support Cisco IOS-XE, NX-OS and IOS-XR, Juniper JunOS, and hopefully/eventually Arista EOS. Community drivers can be merged in for other platforms but will not be tested or supported officially.
Example IOS-XE driver setup:
```
from ssh2net import SSH2Net
from ssh2net.core.cisco_iosxe.driver import IOSXEDrivermy_device = {"setup_host": "1.2.3.4", "auth_user": "person", "auth_password": "password"}
with SSH2Net(**my_device) as conn:
driver = IOSXEDriver(conn)
```Once the driver is setup, "netmiko-like" operations are supported:
```
version = driver.send_command("show version")
print(version[0])
results = driver.send_config_set("["interface loopback123", "description ssh2net was here"])
print(results)
```The major caveat here is that SSH2Net returns a LIST of results (hence the "version[0]" above) as all operations support passing lists of commands.
## Platform Regex
The `comms_prompt_regex` is perhaps the most important argument to getting SSH2Net working.
The "base" pattern is:
`"^[a-z0-9.\-@()/:]{1,20}[#>$]$"`
This pattern works for (tested on show commands only, but should work on config commands for at least IOS-XE, and NX-OS) IOS-XE, NX-OS, JunOS, and IOS-XR.
If you do not wish to match cisco "config" level prompts you can use:
`"^[a-z0-9.-@]{1,20}[#>$]$"`
If you use a platform driver, the base prompt is set in the driver so you don't really need to worry about this!
# Installation
You should be able to pip install it "normally":
```
pip install ssh2net
```To install from this repositories master branch:
```
pip install git+https://github.com/carlmontanari/ssh2net
```To install from source:
```
git clone https://github.com/carlmontanari/ssh2net
cd ssh2net
python setup.py install
```# Examples
- [Basic "native" SSH2Net operations](/examples/basic_usage/basic_usage_ssh2net_native_style.py)
- [Basic "driver" SSH2Net operations](/examples/basic_usage/basic_usage_ssh2net_driver_style.py)
- [Basic "ConnectHandler" (i.e. Netmiko) SSH2Net operations](/examples/basic_usage/basic_usage_ssh2net_connecthandler_style.py)
- [Setting session and channel logging](/examples/logging/session_and_channel_log_diff_files.py)
- [Using SSH Key for authentication](/examples/ssh_keys/ssh_key_basic.py)# FAQ
- Question: Why build this? Netmiko exists, Paramiko exists, Ansible exists, etc...?
- Answer: To learn and build hopefully a really cool thing!
- Question: Is this better than Netmiko/Paramiko/Ansible?
- Answer: Nope! It is different though! The main focus is just to be stupid fast. It is very much that. It *should* be super reliable too as the timeouts are very easy/obvious to control, but that said it for sure has not been tested thoroughly with latent devices.
- Question: Is this easy to use?
- Answer: Yep! The "native" usage is pretty straight forward -- the thing to remember is that it doesn't do "things" for you like Netmiko does for example, so its a lot more like Paramiko in that regard. That said you can use one of the available drivers to have a more Netmiko-like experience -OR- write your own driver as this has been built with the thought of being easily extended.
- Other questions? Ask away!# Linting and Testing
## Linting
This project uses [black](https://github.com/psf/black) for auto-formatting. In addition to black, tox will execute [pylama](https://github.com/klen/pylama), and [pydocstyle](https://github.com/PyCQA/pydocstyle) for linting purposes. I have began playing with adding type hinting and testing this with [mypy](https://github.com/python/mypy), however I've not added this to tox at this point. I've also added docstring linting with [darglint](https://github.com/terrencepreilly/darglint) which has been quite handy!
All commits to this repository will trigger a GitHub action which runs tox, but of course its nicer to just run that before making a commit to ensure that it will pass all tests!
## Testing
I broke testing into two main categories -- unit and functional. Unit is what you would expect -- unit testing the code. Functional testing connects to virtual devices in order to more accurately test the code.
### Unit Tests
Unit tests can be executed via pytest or using the following make command:
```
make test_unit
```This will also print out a coverage report as well as create an html coverage report. The long term goal would be >=75% coverage with unit tests, and more if possible of course! Right now that number is more like >=50%.
### Setting up Functional Test Environment
Executing the functional tests is a bit more complicated! First, thank you to Kristian Larsson for his great tool [vrnetlab](https://github.com/plajjan/vrnetlab)! All functional tests are built on this awesome platform that allows for easy creation of containerized network devices.
Basic functional tests exist for all "core" platform types (IOSXE, NXOS, IOSXR, EOS, Junos). Vrnetlab currently only supports the older emulation style NX-OS devices, and *not* the newer VM image n9kv. I have made some very minor tweaks to vrnetlab locally in order to get the n9kv image running -- I have raised a PR to add this to vrnetlab proper. Minus the n9kv tweaks, getting going with vrnetlab is fairly straightforward -- simply follow Kristian's great readme docs. For the Arista EOS image -- prior to creating the container you should boot the device and enter the `zerotouch disable` command. This allows for the config to actually be saved and prevents the interfaces from cycling through interface types in the container (I'm not clear why it does that but executing this command before building the container "fixes" this!). After creating the image(s) that you wish to test, rename the image to the following format:
```
ssh2net[PLATFORM]
```The docker-compose file here will be looking for the container images matching this pattern, so this is an important bit! The container image names should be:
```
ssh2netiosxe
ssh2netnxos
ssh2netiosxr
ssh2netjunos
```You can tag the image names on creation (following the vrnetlab readme docs), or create a new tag once the image is built:
```
docker tag [TAG OF IMAGE CREATED] ssh2netnxos
```Once you have created the images, you can start the containers with a make command:
```
make start_dev_env
```Conversely you can terminate the containers:
```
make stop_dev_env
```To start a specific platform container:
```
make start_dev_env_iosxe
```Substitute "iosxe" for the platform type you want to start.
Most of the containers don't take too long to fire up, maybe a few minutes (running on my old macmini with Ubuntu, so not exactly a powerhouse!). That said, the IOS-XR device takes about 15 minutes to go to "healthy" status. Once booted up you can connect to their console or via SSH:
| Device | Local IP |
| --------------|---------------|
| iosxe | 172.18.0.11 |
| nxos | 172.18.0.12 |
| iosxr | 172.18.0.13 |
| eos (future)| 172.18.0.14 |
| junos | 172.18.0.15 |The console port for all devices is 5000, so to connect to the console of the iosxe device you can simply telnet to that port locally:
```
telnet 172.18.0.11 5000
```Credentials for all devices use the default vrnetlab credentials:
Username: vrnetlab
Password: VR-netlab9
Once the container(s) are ready, you can use the make commands to execute tests as needed:
- `test_functional` will execute all currently implemented functional tests
- `test_all` will execute all currently implemented functional tests as well as the unit tests
- `test_iosxe` will execute all unit tests and iosxe functional tests
- `test_nxos` will execute all unit tests and nxos functional tests
- `test_iosxr` will execute all unit tests and iosxr functional tests
- `test_junos` will execute all unit tests and junos functional tests**Note** - the functional tests test the "native" SSH2Net functionality, but as of now do *not* test the "driver" functionality (i.e. it does not test anything in ssh2net/core/).