Compromised by Endpoint Protection
This was originally posted on blogger here.
In a recent research project, Markus Wulftange of Code White discovered several critical vulnerabilities in the Symantec Endpoint Protection (SEP) suite 12.1, affecting versions prior to 12.1 RU6 MP1 (see SYM15-007).
As with any centralized enterprise management solution, compromising a management server is quite attractive for an attacker, as it generally allows some kind of control over its managed clients. Taking control of the manager can yield a takeover of the whole enterprise network.
In this post, we will take a closer look at some of the discovered vulnerabilities in detail and demonstrate their exploitation. In combination, they effectively allow an unauthenticated attacker the execution of arbitrary commands with 'NT Authority\SYSTEM' privileges on both the SEP Manager (SEPM) server, as well as on SEP clients running Windows. That can result in the full compromise of a whole corporate network.
Vulnerabilities in Symantec Endpoint Protection 12.1
Code White discovered the following vulnerabilities in Symantec Endpoint Protection 12.1:
- SEP Manager
-     - Authentication Bypass (CVE-2015-1486)
- Allows unauthenticated attackers access to SEPM
- Mulitple Path Traversals (CVE-2015-1487, CVE-2015-1488, CVE-2015-1490)
- Allows reading and writing arbitrary files, resulting in the execution of arbitrary commands with 'NT Service\semsrv' privileges
- Privilege Escalation (CVE-2015-1489)
- Allows the execution of arbitrary OS commands with 'NT Authority\SYSTEM' privileges
- Multiple SQL Injections (CVE-2015-1491)
- Allows the execution of arbitrary SQL
 
- SEP Clients
-     - Binary Planting (CVE-2015-1492)
- Allows the execution of arbitrary code with 'NT Authority\SYSTEM' privileges on SEP clients running Windows
 
The objective of our research was to find a direct way to take over a whole Windows domain and thus aimed at a full compromise of the SEPM server and the SEP clients running on Windows. Executing post exploitation techniques, like lateral movement, would be the next step if the domain controller hasn't already been compromised by this.
Therefore, we focused on SEPM's Remote Java or Web Console, which is probably the most exposed interface (accessible via TCP ports 8443 and 9090) and offers most of the functionalities of SEPM's remote interfaces. There are further entry points, which may also be vulnerable and exploitable to gain access to SEPM, its server, or the SEP clients. For example, SEP clients for Mac and Linux may also be vulnerable to Binary Planting.
Attack Vector and Exploitation
A full compromise of the SEPM server and SEP clients running Windows was possible through the following steps:
- Gaining administrative access to the SEP Manager (CVE-2015-1486)
- Full compromise of SEP Manager server (CVE-2015-1487 and CVE-2015-1489)
- Full compromise of SEP clients running Windows (CVE-2015-1492)
CVE-2015-1486: SEPM Authentication Bypass
SEPM uses sessions after the initial authentication.  User information is stored in a AdminCredential object, which is associated to the user's session.  Assigning the AdminCredential object to a session is implemented in the setAdminCredential method of ConsoleSession, which again holds an HttpSession object.
This setAdminCredential method is only called at two points within the whole application: once in the LoginHandler and once in the ResetPasswordHandler.
Its purpose in LoginHandler is obvious.  But why is it used in the ResetPasswordHandler?  Let's have a look at it!
Password reset requests are handled by the ResetPasswordHandler handler class.  The implementation of the handleRequest method of this handler class can be observed in the following listing:
After the prologue in lines 72-84, the call to the init method calls the findAdminEmail method for looking up the recipient's e-mail address.
Next, the getCredential method is called in line 92 to retrieve the AdminCredential object of the corresponding administrator.  The AdminCredential object holds information on the administrator, e. g., if it's a system administrator or a domain administrator as well as an instance of the SemAdministrator class, which finally holds information such as the name, e-mail address, and hashed password of the administrator.
The implementation of the getCredential method can be seen in the following listing:
Line 367 creates a new session, which effectively results in issuing a new JSESSIONID cookie to the client.  In line 368, the doGetAdminCredentialWithoutAuthentication method is called to get the AdminCredential object without any authentication based on the provided UserID and Domain parameters.
Finally – and fatally –, the looked up AdminCredential object is associated to the newly created session in line 369, making it a valid and authentic administrator's session.  This very session is then handed back to the user who requested the password reset.  So by requesting a password reset, you'll also get an authenticated administrator's session!
An example of what a request for a password reset for the built-in system administrator 'admin' might look like can be seen in the following listing:
And the response to the request:
The response contains the JSESSIONID cookie of the newly created session with the admin's AdminCredential object associated to it.
Note that this session cannot be used with the Web console as it is missing some attribute required for AjaxSwing. However, it can be used to communicate with the other APIs like the SPC web services, which, for example, allows creating a new SEPM administrator.
CVE-2015-1487: SEPM Arbitrary File Write
The UploadPackage action of the BinaryFile handler is vulnerable to path traversal, which allows arbitrary files to be written.  It is implemented by the BinaryFileHandler handler class.  Its handleRequest method handles the requests and the implementation can be observed in the following listing:
Handling of the UploadPackage action starts at line 189.  The PackageFile parameter value is used as file name and the KnownHosts parameter value as directory name.  Interestingly, the provided directory name is checked for path traversal by looking for directory separators '/' and '\' (see line 196, possibly related to CVE-2014-3439).  However, the file name is not, which still allows to specify any arbitrary file location.
The following request results in writing the given POST request body data to the file located at '[…]\Symantec\Symantec Endpoint Protection Manager\tomcat\webapps\ROOT\exec.jsp':
Writing a JSP web shell as shown allows the execution of arbitrary OS commands with 'NT Service\semsrv' privileges.
CVE-2015-1489: SEPM Privilege Escalation
The Symantec Endpoint Protection Launcher executable SemLaunchSvc.exe is running as a service on the SEPM server with 'NT Authority\SYSTEM' privileges.  It is used to launch processes that require elevated privileges (e. g., LiveUpdate, ClientRemote, etc.).  The service is listening on the loopback port 8447 and SEPM communicates with the service via encrypted messages.  The communication endpoint in SEPM is the SemLaunchService class.  One of the supported tasks is the CommonCMD, which results in command line parameters of a cmd.exe call.
Since we are able to execute arbitrary Java code within SEPM's web server context, we can effectively execute commands with 'NT Authority\SYSTEM' privileges on the SEPM server.
CVE-2015-1492: SEP Client Binary Planting
The client deployment process on Windows clients is vulnerable to Binary Planting.  It is an attack exploiting the behavior of how Windows searches for files of dynamically loaded libraries when loading them via LoadLibrary only by their name.  If it is possible for an attacker to place a custom DLL in one of the locations the DLL is searched in, it is possible to execute arbitrary code with the DllMain entry point function, which gets executed automatically on load.
Symantec Endpoint Protection is vulnerable to this flaw: During the installation of a deployment package on a Windows client, the SEP client service ccSvcHst.exe starts the smcinst.exe from the installation package as a service.  This service tries to load several DLLs, e. g., the UxTheme.dll.
By deploying a specially crafted client installation package with a custom DLL, it is possible to execute arbitrary code with 'NT Authority\SYSTEM' privileges.
A custom installation package containing a custom DLL can be constructed and deployed in SEPM with the following steps.
- Export Package
- Download an existing client installation package for Windows as a template:     - Go to 'Admin', 'Installation Packages'.
- Select a directory where you want to export it to.
- Select one of the existing packages for Windows and click on 'Export a Client Installation Package'.
- Untick the 'Create a single .EXE file for this package'.
- Untick the 'Export packages with policies from the following groups'.
- Click 'OK'.
 
- Modify Package
- Tamper with the client installation package template:     - Within the downloaded installation package files, delete the packlist.xmlfile.
- Open the setAid.inifile, delete thePackageChecksumline and increase the values ofServerVersionandClientVersionto something like12.2.0000instead of12.1.5337.
- Open the Setup.inifile and increase theProductVersionvalue accordingly.
- Copy the custom DLL into the package directory and rename it UxTheme.dll.
 
- Within the downloaded installation package files, delete the 
- Import and deploy Package
- Create a new client installation package from the tampered files and deploy it to the clients:     - Go to 'Admin', 'Installation Packages'.
- Click 'Add a Client Installation Package'.
- Give it a name, select the directory of the tampered client installation package files, and upload it.
- Click 'Upgrade Clients with Package'.
- Choose the newly created client installation package and the group it should be deployed to.
- Open the 'Upgrade Settings', untick 'Maintain existing client features when upgrading' and select the default feature set for the target group, e. g., 'Full Protection for Clients'.
- Upgrade the clients by clicking 'Next'.
 
The loading of the planted binary may take some while, probably due to some scheduling of the smcinst.exe service.
Conclusion
We have successfully demonstrated that a centralized enterprise management solution like the Symantec Endpoint Protection suite is a critical asset in a corporate network as unauthorized access to the manager can have unforeseen influence on the managed clients. In this case, an exposed Symantec Endpoint Protection Manager can result in the full compromise of a whole corporate domain.