From 6d4fc56faee68d3a4764f1f80f84710635bdaf05 Mon Sep 17 00:00:00 2001 From: Eric Hibbs Date: Thu, 19 Dec 2024 10:19:35 -0800 Subject: [PATCH] manifest file search now case-insensitive (#35) --- socketsecurity/__init__.py | 2 +- socketsecurity/core/__init__.py | 38 +++++++++++++++++++++------------ 2 files changed, 25 insertions(+), 15 deletions(-) diff --git a/socketsecurity/__init__.py b/socketsecurity/__init__.py index 3b32376..2cb21d0 100644 --- a/socketsecurity/__init__.py +++ b/socketsecurity/__init__.py @@ -1,2 +1,2 @@ __author__ = 'socket.dev' -__version__ = '1.0.37' +__version__ = '1.0.38' diff --git a/socketsecurity/core/__init__.py b/socketsecurity/core/__init__.py index a27de59..0291a40 100644 --- a/socketsecurity/core/__init__.py +++ b/socketsecurity/core/__init__.py @@ -410,12 +410,15 @@ def match_supported_files(files: list) -> bool: patterns = socket_globs[ecosystem] for file_name in patterns: pattern = patterns[file_name]["pattern"] - # path_pattern = f"**/{pattern}" for file in files: if "\\" in file: file = file.replace("\\", "/") - if PurePath(file).match(pattern): - matched_files.append(file) + # Split path and filename + path_parts = PurePath(file).parts + if path_parts: + # Compare only the filename portion case-insensitively + if PurePath(path_parts[-1].lower()).match(pattern.lower()): + matched_files.append(file) if len(matched_files) == 0: not_matched = True return not_matched @@ -435,17 +438,24 @@ def find_files(path: str) -> list: patterns = socket_globs[ecosystem] for file_name in patterns: pattern = patterns[file_name]["pattern"] - file_path = f"{path}/**/{pattern}" - - log.debug(f"Globbing {file_path}") - glob_start = time.time() - glob_files = glob(file_path, recursive=True) - for glob_file in glob_files: - if glob_file not in files: - files.add(glob_file) - glob_end = time.time() - glob_total_time = glob_end - glob_start - log.debug(f"Glob for pattern {file_path} took {glob_total_time:.2f} seconds") + # Keep path as-is but try filename variations + file_paths = [ + f"{path}/**/{pattern}", + f"{path}/**/{pattern.lower()}", + f"{path}/**/{pattern.upper()}", + f"{path}/**/{pattern.capitalize()}" + ] + + for file_path in file_paths: + log.debug(f"Globbing {file_path}") + glob_start = time.time() + glob_files = glob(file_path, recursive=True) + for glob_file in glob_files: + if glob_file not in files: + files.add(glob_file) + glob_end = time.time() + glob_total_time = glob_end - glob_start + log.debug(f"Glob for pattern {file_path} took {glob_total_time:.2f} seconds") log.debug("Finished Find Files") end_time = time.time()