Skip to content

Commit

Permalink
Update autosync command
Browse files Browse the repository at this point in the history
  • Loading branch information
qduanmu committed Nov 21, 2024
1 parent 7645fbe commit 0237e3b
Show file tree
Hide file tree
Showing 4 changed files with 113 additions and 145 deletions.
90 changes: 0 additions & 90 deletions trestlebot/cli/base.py

This file was deleted.

136 changes: 81 additions & 55 deletions trestlebot/cli/commands/autosync.py
Original file line number Diff line number Diff line change
@@ -1,33 +1,83 @@
""" Autosync command"""

import argparse
import logging
from typing import Any, Dict, List

import click

from trestlebot.cli.base import comma_sep_to_list, run
from trestlebot.cli.options.common import git_options
from trestlebot.cli.options.common import git_options, handle_exceptions
from trestlebot.cli.run import comma_sep_to_list
from trestlebot.cli.run import run as bot_run
from trestlebot.tasks.assemble_task import AssembleTask
from trestlebot.tasks.authored import types
from trestlebot.tasks.authored.base_authored import AuthoredObjectBase
from trestlebot.tasks.base_task import ModelFilter, TaskBase
from trestlebot.tasks.regenerate_task import RegenerateTask


logger = logging.getLogger(__name__)


@handle_exceptions
def run(oscal_model: str, ctx_obj: Dict[str, Any]) -> None:
"""Run the autosync for oscal model."""

pre_tasks: List[TaskBase] = []
# Allow any model to be skipped from the args, by default include all
model_filter: ModelFilter = ModelFilter(
skip_patterns=comma_sep_to_list(ctx_obj.get("skip_items", "")),
include_patterns=["*"],
)
authored_object: AuthoredObjectBase = types.get_authored_object(
oscal_model,
ctx_obj.get("working_dir", ""),
ctx_obj.get("ssp_index_path", ""),
)

# Assuming an edit has occurred assemble would be run before regenerate.
# Adding this to the list first
if not ctx_obj.get("skip_assemble"):
assemble_task: AssembleTask = AssembleTask(
authored_object=authored_object,
markdown_dir=ctx_obj["markdown_path"],
version=ctx_obj.get("version", ""),
model_filter=model_filter,
)
pre_tasks.append(assemble_task)
else:
logger.info("Assemble task skipped.")

if not ctx_obj.get("skip_regenerate"):
regenerate_task: RegenerateTask = RegenerateTask(
authored_object=authored_object,
markdown_dir=ctx_obj["markdown_path"],
model_filter=model_filter,
)
pre_tasks.append(regenerate_task)
else:
logger.info("Regeneration task skipped.")

bot_run(pre_tasks, ctx_obj)


@click.group(name="autosync", help="Autosync operations")
@click.option(
"--working-dir",
help="Working directory wit git repository",
type=click.Path(exists=True),
)
@click.option(
"--dry-run",
help="Run tasks, but do not push to the repository",
is_flag=True,
)
prompt="Enter path to git repo (workspace directory)",
default=".",
) # TODO: use path in config
@click.option(
"--markdown-path",
help="Path to Trestle markdown files",
type=click.Path(exists=True), # Should it exist?
type=click.Path(exists=True),
prompt="Enter path to to Trestle markdown files",
)
@click.option(
"--skip-items",
help="Comma-separated list of glob patterns to skip when running tasks",
type=str, # What's the type?
type=str,
)
@click.option(
"--skip-assemble",
Expand All @@ -48,6 +98,11 @@
help="Version of the OSCAL model to set during assembly into JSON",
type=str,
)
@click.option(
"--dry-run",
help="Run tasks, but do not push to the repository",
is_flag=True,
)
@git_options
@click.pass_context
def autosync_cmd(
Expand All @@ -69,43 +124,7 @@ def autosync_cmd(
) -> None:
"""Command to autosync catalog, profile, compdef and ssp."""

need_to_prompt = any(
(
not working_dir,
not markdown_path,
not branch,
not committer_email,
not committer_name,
)
)
if need_to_prompt:
click.echo("\n* Welcome to the Trestle-bot CLI *\n")
click.echo("Please provide the following values to start autosync operations.")
if not working_dir:
working_dir = click.prompt(
"Enter path to working directory wit git repository",
default=".",
type=click.Path(exists=True),
)
if not markdown_path:
markdown_path = click.prompt(
"Enter path to to Trestle markdown files",
type=click.Path(exists=True),
)
if not branch:
branch = click.prompt(
"Enter branch name to push changes to",
)
if not committer_email:
committer_email = click.prompt(
"Enter email for committer",
)
if not committer_name:
committer_name = click.prompt(
"Enter name of committer",
)

ctx.trestle_args = argparse.Namespace(
ctx.obj = dict(
working_dir=working_dir,
markdown_path=markdown_path,
skip_items=skip_items,
Expand All @@ -119,37 +138,44 @@ def autosync_cmd(
committer_email=committer_email,
author_name=author_name,
author_email=author_email,
# target_branch=target_branch,
# pull_request_title=pull_request_title,
dry_run=dry_run,
)


@autosync_cmd.command("ssp")
@click.option(
"--ssp-index-path",
help="Path to ssp index file",
type=click.File("r"),
)
@click.pass_context
@click.option("--ssp-index-path", help="Path to ssp index file", type=click.File("r"))
def autosync_ssp_cmd(ctx: click.Context, ssp_index_path: str) -> None:
if not ssp_index_path:
ssp_index_path = click.prompt(
"Enter path to ssp index file",
type=click.Path(exists=True),
)
run("ssp", ctx.parent.trestle_args, ssp_index_path)
ctx.obj.update(
{
"ssp_index_path": ssp_index_path,
}
)
run("ssp", ctx.obj)


@autosync_cmd.command("compdef")
@click.pass_context
def autosync_compdef_cmd(ctx: click.Context) -> None:
run("compdef", ctx.parent.trestle_args)
run("compdef", ctx.obj)


@autosync_cmd.command("catalog")
@click.pass_context
def autosync_catalog_cmd(ctx: click.Context) -> None:
run("catalog", ctx.parent.trestle_args)
run("catalog", ctx.obj)


@autosync_cmd.command("profile")
@click.pass_context
def autosync_profile_cmd(ctx: click.Context) -> None:
run("profile", ctx.parent.trestle_args)
run("profile", ctx.obj)
3 changes: 3 additions & 0 deletions trestlebot/cli/options/common.py
Original file line number Diff line number Diff line change
Expand Up @@ -111,16 +111,19 @@ def git_options(f: F) -> Any:
"--branch",
help="Branch name to push changes to",
type=str,
prompt="Enter branch name to push changes to",
)
@click.option(
"--committer-name",
help="Name of committer",
type=str,
prompt="Enter name for committer",
)
@click.option(
"--committer-email",
help="Email for committer",
type=str,
prompt="Enter email for committer",
)
@click.option(
"--file-patterns",
Expand Down
29 changes: 29 additions & 0 deletions trestlebot/cli/run.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
from typing import Any, Dict, List

from trestlebot.bot import TrestleBot
from trestlebot.tasks.base_task import TaskBase


def comma_sep_to_list(string: str) -> List[str]:
"""Convert comma-sep string to list of strings and strip."""
string = string.strip() if string else ""
return list(map(str.strip, string.split(","))) if string else []


def run(pre_tasks: List[TaskBase], kwargs: Dict[Any, Any]) -> None:
"""Reusable logic for all commands."""
# Configure and run the bot
bot = TrestleBot(
working_dir=kwargs["working_dir"],
branch=kwargs["branch"],
commit_name=kwargs["committer_name"],
commit_email=kwargs["committer_email"],
author_name=kwargs.get("author_name", ""),
author_email=kwargs.get("author_email", ""),
)
bot.run(
pre_tasks=pre_tasks,
patterns=comma_sep_to_list(kwargs.get("patterns", "")),
commit_message=kwargs.get("commit_message", "Automatic updates from bot"),
dry_run=kwargs.get("dry_run", False),
)

0 comments on commit 0237e3b

Please sign in to comment.