Skip to content
Merged
Changes from 15 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 10 additions & 5 deletions cycode/cli/files_collector/file_excluder.py
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,14 @@ def apply_scan_config(self, scan_type: str, scan_config: 'models.ScanConfigurati
if scan_config.scannable_extensions:
self._scannable_extensions[scan_type] = tuple(scan_config.scannable_extensions)

def _is_file_prefix_supported(self, scan_type: str, file_path: str) -> bool:
scannable_prefixes = self._scannable_prefixes.get(scan_type)
if scannable_prefixes:
path = Path(file_path)
file_name = path.name.lower()
return file_name.startswith(scannable_prefixes)
return False

def _is_file_extension_supported(self, scan_type: str, filename: str) -> bool:
filename = filename.lower()

Expand All @@ -80,10 +88,6 @@ def _is_file_extension_supported(self, scan_type: str, filename: str) -> bool:
if non_scannable_extensions:
return not filename.endswith(non_scannable_extensions)

scannable_prefixes = self._scannable_prefixes.get(scan_type)
if scannable_prefixes:
return filename.startswith(scannable_prefixes)

return True

def _is_relevant_file_to_scan_common(self, scan_type: str, filename: str) -> bool:
Expand All @@ -100,7 +104,8 @@ def _is_relevant_file_to_scan_common(self, scan_type: str, filename: str) -> boo
)
return False

if not self._is_file_extension_supported(scan_type, filename):
if (not self._is_file_extension_supported(scan_type, filename)
and not self._is_file_prefix_supported(scan_type, filename)):
logger.debug(
'The document is irrelevant because its extension is not supported, %s',
{'scan_type': scan_type, 'filename': filename},
Expand Down
Loading