Skip to Main Content
January 22, 2015

Introducing SHIPS - Centralized Password Management

Written by Geoff Walton
Penetration Testing Security Testing & Analysis
The Shared Host Integrated Password System (SHIPS) is an open-source solution created by Geoff Walton from TrustedSec to provide unique and rotated local super user or administrator passwords for environments where it is not possible or not appropriate to disable these local accounts. Our goal is to make post exploitation more difficult and provide a simplistic way to manage multiple systems in an environment where Windows does not necessarily support an alternative. SHIPS supports both Linux and Windows password management. Clients may be configured to rotate passwords automatically. Stored passwords can be retrieved by desktop support personnel as required, or updated when a password has to be manually changed in the course of system maintenance. By having unique passwords on each machine and logging of password retrievals, security can be improved by making networks more resistant to lateral movement by attackers and enhancing the ability to attribute actions to individual persons. When performing penetration tests, our common attack vector is through compromising one host and pivoting to other systems with the information obtained. It is common to see large-scale breaches utilizing this method and that is where SHIPS comes into play. SHIPS is designed to make post-exploitation more difficult and minimize what systems attackers gain access to. Once SHIPS is set up, there isn’t much else that is needed and it’s simple to integrate into existing business processes. A script is deployed to the endpoints, servers, and any other systems through group policy or similar deployment tools. The script is run on a determined timeframe from the organization. The script makes a password request to the server, which generates unique password string that it stores and transmits to the client. The client script than applies the new password on the client. TrustedSec recommends deploying SHIPS to servers, workstations, or any other windows or linux-based systems. The passwords will now be unique per individual server and workstation. For organizations where client and server support roles are segregated to different groups of employees, multiple instances of the SHIPS server can be run on a single host. Simply change the listing port on one of server instances and configure each to authorize the appropriate users. TrustedSec recommends using the alternate listening port for the instance supporting server infrastructure. In most cases accommodating requests on the alternate port from servers will be easier than frequently more mobile clients, with regard to firewalls or proxies. When users with permission to access account passwords wish to retrieve them, they simply log into the SHIPS admin server and do a lookup of the machine name. The web application will display the current password associated with the device. SHIPS authorization can be tied to external systems such as LDAP. To download SHIPS, visit our github page and click on download the most recent master zipfile or check it out via git clone. There are additional techniques or tactics that an organization can perform in a Windows environment that can also disable local admins. Blog post reference here: https://www.trustedsec.com/february-2012/disabling-local-administrators-through-gpo-on-server-2008/. It's whatever you prefer from an organization perspective. For a full installation tutorial and to read up more on SHIPS including functionality and tweaking, visit the github link to download the PDF document: https://github.com/trustedsec/SHIPS/raw/master/doc/SHIPS_Installation_v1.pdf To download SHIPS, head over to the TrustedSec SHIPS download page: https://www.trustedsec.com/ships/