From 0236ef78776e110cab2f1ce04fb1882b040ee6c4 Mon Sep 17 00:00:00 2001 From: Alexander Neff Date: Mon, 6 Jan 2025 08:43:49 -0500 Subject: [PATCH] Fix logic bug when creating smbv1 connection and add timeout check for smbv3 --- nxc/protocols/smb.py | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/nxc/protocols/smb.py b/nxc/protocols/smb.py index 4b29341ee..924d72db1 100755 --- a/nxc/protocols/smb.py +++ b/nxc/protocols/smb.py @@ -156,8 +156,8 @@ def __init__(self, args, db, host): self.remote_ops = None self.bootkey = None self.output_filename = None - self.smbv1 = None - self.smbv3 = None + self.smbv1 = None # Check if SMBv1 is supported + self.smbv3 = None # Check if SMBv3 is supported self.is_timeouted = False self.signing = False self.smb_share_name = smb_share_name @@ -554,7 +554,8 @@ def create_smbv1_conn(self, check=False): preferredDialect=SMB_DIALECT, timeout=self.args.smb_timeout, ) - if check: + self.smbv1 = True + if not check: self.conn = conn except OSError as e: if "Connection reset by peer" in str(e): @@ -583,8 +584,13 @@ def create_smbv3_conn(self): self.port, timeout=self.args.smb_timeout, ) + self.smbv3 = True except (Exception, NetBIOSTimeout, OSError) as e: - self.logger.info(f"Error creating SMBv3 connection to {self.host}: {e}") + if "timed out" in str(e): + self.is_timeouted = True + self.logger.debug(f"Timeout creating SMBv3 connection to {self.host}") + else: + self.logger.info(f"Error creating SMBv3 connection to {self.host}: {e}") return False return True