ansible-doctor/ansibledoctor/cli.py

128 lines
3.9 KiB
Python
Raw Permalink Normal View History

2019-10-07 08:52:00 +02:00
#!/usr/bin/env python3
2019-10-08 11:44:35 +02:00
"""Entrypoint and CLI handler."""
2019-10-07 08:52:00 +02:00
import argparse
import os
2019-10-07 08:52:00 +02:00
import ansibledoctor.exception
2019-10-07 08:52:00 +02:00
from ansibledoctor import __version__
from ansibledoctor.config import SingleConfig
from ansibledoctor.doc_generator import Generator
from ansibledoctor.doc_parser import Parser
from ansibledoctor.utils import SingleLog
2019-10-07 08:52:00 +02:00
class AnsibleDoctor:
"""Create main object."""
2019-10-07 08:52:00 +02:00
def __init__(self):
self.log = SingleLog()
self.logger = self.log.logger
self.args = self._cli_args()
self.config = self._get_config()
self._execute()
2019-10-07 08:52:00 +02:00
def _cli_args(self):
"""
Use argparse for parsing CLI arguments.
:return: args objec
"""
2019-10-09 00:56:39 +02:00
# TODO: add function to print to stdout instead of file
2019-10-07 08:52:00 +02:00
parser = argparse.ArgumentParser(
2020-04-05 23:16:53 +02:00
description="Generate documentation from annotated Ansible roles using templates"
)
parser.add_argument(
"base_dir", nargs="?", help="base directory (default: current working directory)"
2020-04-05 23:16:53 +02:00
)
parser.add_argument(
"-c", "--config", dest="config_file", help="path to configuration file"
2020-04-05 23:16:53 +02:00
)
parser.add_argument(
"-o", "--output", dest="output_dir", action="store", help="output directory"
)
parser.add_argument(
"-r",
"--recursive",
dest="recursive",
action="store_true",
default=None,
help="run recursively over the base directory subfolders",
2020-04-05 23:16:53 +02:00
)
parser.add_argument(
"-f",
"--force",
dest="force_overwrite",
action="store_true",
default=None,
help="force overwrite output file",
2020-04-05 23:16:53 +02:00
)
parser.add_argument(
"-d",
"--dry-run",
dest="dry_run",
action="store_true",
default=None,
help="dry run without writing",
2020-04-05 23:16:53 +02:00
)
2021-07-27 22:01:56 +02:00
parser.add_argument(
"-n",
"--no-role-detection",
dest="role_detection",
action="store_false",
default=None,
help="disable automatic role detection",
2021-07-27 22:01:56 +02:00
)
2020-04-05 23:16:53 +02:00
parser.add_argument(
"-v", dest="logging.level", action="append_const", const=-1, help="increase log level"
)
parser.add_argument(
"-q", dest="logging.level", action="append_const", const=1, help="decrease log level"
)
parser.add_argument("--version", action="version", version=f"%(prog)s {__version__}")
2019-10-07 08:52:00 +02:00
return parser.parse_args().__dict__
2019-10-07 08:52:00 +02:00
def _get_config(self):
2019-10-08 11:30:31 +02:00
try:
config = SingleConfig(args=self.args)
except ansibledoctor.exception.ConfigError as e:
2019-10-08 11:30:31 +02:00
self.log.sysexit_with_message(e)
return config
2019-10-08 11:43:55 +02:00
def _execute(self):
cwd = self.config.base_dir
walkdirs = [cwd]
2019-10-08 11:30:31 +02:00
if self.config.recursive:
walkdirs = [f.path for f in os.scandir(cwd) if f.is_dir()]
for item in walkdirs:
os.chdir(item)
self.config.set_config(base_dir=os.getcwd())
try:
self.log.set_level(self.config.config["logging"]["level"])
except ValueError as e:
self.log.sysexit_with_message(f"Can not set log level.\n{e!s}")
self.logger.info(f"Using config file: {self.config.config_file}")
self.logger.debug(f"Using working dir: {item}")
if self.config.config["role_detection"]:
if self.config.is_role:
self.logger.info(f"Ansible role detected: {self.config.config['role_name']}")
else:
self.log.sysexit_with_message("No Ansible role detected")
else:
self.logger.info("Ansible role detection disabled")
doc_parser = Parser()
doc_generator = Generator(doc_parser)
doc_generator.render()
2020-12-31 14:16:00 +01:00
def main():
AnsibleDoctor()