mirror of https://github.com/jtesta/ssh-audit.git
77 lines
2.6 KiB
Markdown
77 lines
2.6 KiB
Markdown
# ssh-audit
|
|
**ssh-audit** is a tool for ssh server auditing.
|
|
|
|
## Features
|
|
- SSH1 and SSH2 protocol server support;
|
|
- grab banner, recognize device or software and operating system, detect compression;
|
|
- gather key-exchange, host-key, encryption and message authentication code algorithms;
|
|
- output algorithm information (available since, removed/disabled, unsafe/weak/legacy, etc);
|
|
- output security information (related issues, assigned CVE list, etc);
|
|
- analyze SSH version compatibility based on algorithm information;
|
|
- historical information from OpenSSH and Dropbear SSH;
|
|
- no dependencies, compatible with Python2 and Python3;
|
|
|
|
## Usage
|
|
```
|
|
usage: ssh-audit.py [-bnv] [-l <level>] <host[:port]>
|
|
|
|
-1, --ssh1 force ssh version 1 only
|
|
-2, --ssh2 force ssh version 1 only
|
|
-b, --batch batch output
|
|
-n, --no-colors disable colors
|
|
-v, --verbose verbose output
|
|
-l, --level=<level> minimum output level (info|warn|fail)
|
|
|
|
```
|
|
* batch flag `-b` will output sections without header and without empty lines (implies verbose flag).
|
|
* verbose flag `-v` will prefix each line with section type and algorithm name.
|
|
|
|
### example
|
|
![screenshot](https://cloud.githubusercontent.com/assets/7356025/17623665/da5281c8-60a9-11e6-9582-13f9971c22e0.png)
|
|
|
|
## ChangeLog
|
|
|
|
### v1.5.0 (2016-09-20)
|
|
- create security section for related security information
|
|
- match and output assigned CVE list and security issues for Dropbear SSH
|
|
- implement full SSH1 support with fingerprint information
|
|
- automatically fallback to SSH1 on protocol mismatch
|
|
- add new options to force SSH1 or SSH2 (both allowed by default)
|
|
- parse banner information and convert it to specific sofware and OS version
|
|
- do not use padding in batch mode
|
|
- several fixes (Cisco sshd, rare hangs, error handling, etc)
|
|
|
|
### v1.0.20160902
|
|
- implement batch output option
|
|
- implement minimum output level option
|
|
- fix compatibility with Python 2.6
|
|
|
|
### v1.0.20160812
|
|
- implement SSH version compatibility feature
|
|
- fix wrong mac algorithm warning
|
|
- fix Dropbear SSH version typo
|
|
- parse pre-banner header
|
|
- better errors handling
|
|
|
|
### v1.0.20160803
|
|
- use OpenSSH 7.3 banner
|
|
- add new key-exchange algorithms
|
|
|
|
### v1.0.20160207
|
|
- use OpenSSH 7.2 banner
|
|
- additional warnings for OpenSSH 7.2
|
|
- fix OpenSSH 7.0 failure messages
|
|
- add rijndael-cbc failure message from OpenSSH 6.7
|
|
|
|
### v1.0.20160105
|
|
- multiple additional warnings
|
|
- support for none algorithm
|
|
- better compression handling
|
|
- ensure reading enough data (fixes few Linux SSH)
|
|
|
|
### v1.0.20151230
|
|
- Dropbear SSH support
|
|
|
|
### v1.0.20151223
|
|
- initial version
|