ansible-doctor/ansibledoctor/file_registry.py

56 lines
1.7 KiB
Python
Raw Normal View History

2019-10-07 06:52:00 +00:00
#!/usr/bin/env python3
2019-10-08 09:39:27 +00:00
"""File registry to encapsulate file system related operations."""
2019-10-07 06:52:00 +00:00
import glob
import os
2019-10-08 09:39:27 +00:00
import pathspec
from ansibledoctor.config import SingleConfig
from ansibledoctor.contstants import YAML_EXTENSIONS
from ansibledoctor.utils import SingleLog
2019-10-07 06:52:00 +00:00
class Registry:
2020-04-05 21:16:53 +00:00
"""Register all yaml files."""
2019-10-07 06:52:00 +00:00
_doc = {}
log = None
config = None
def __init__(self):
self._doc = []
self.config = SingleConfig()
self.log = SingleLog()
self.logger = self.log.logger
2019-10-07 06:52:00 +00:00
self._scan_for_yamls()
def get_files(self):
return self._doc
def _scan_for_yamls(self):
"""
Search for the yaml files in each project/role root and append to the corresponding object.
:param base: directory in witch we are searching
:return: None
"""
extensions = YAML_EXTENSIONS
base_dir = self.config.config.base_dir
role_name = self.config.config.role_name
2019-10-08 09:30:31 +00:00
excludes = self.config.config.get("exclude_files")
excludespec = pathspec.PathSpec.from_lines("gitwildmatch", excludes)
2019-10-07 06:52:00 +00:00
self.logger.debug(f"Scan for files: {os.path.relpath(base_dir,self.log.ctx)}")
2019-10-07 06:52:00 +00:00
for extension in extensions:
pattern = os.path.join(base_dir, "**/*." + extension)
2019-10-08 09:30:31 +00:00
for filename in glob.iglob(pattern, recursive=True):
if not excludespec.match_file(filename):
2020-04-05 21:16:53 +00:00
self.log.debug(
f"Adding file to role: {role_name}: {os.path.relpath(filename, base_dir)}"
2020-04-05 21:16:53 +00:00
)
2019-10-07 06:52:00 +00:00
self._doc.append(filename)
2019-10-08 09:30:31 +00:00
else:
self.log.debug(f"Excluding file: {os.path.relpath(filename, base_dir)}")