feat(webhooks): add validation mode support and enhance start notifications

Add a validation_mode flag to prevent sending start webhooks during config validation.
Enhance webhook payload with enabled commands and execution options for better notification details.
This commit is contained in:
bobokun 2025-09-16 22:18:49 -04:00
parent 462cab9246
commit 2f8e9d9ca1
No known key found for this signature in database
GPG key ID: B73932169607D927
3 changed files with 28 additions and 2 deletions

View file

@ -1 +1 @@
4.6.3-develop14 4.6.3-develop15

View file

@ -901,6 +901,7 @@ class WebAPI:
temp_args = self.args.copy() temp_args = self.args.copy()
temp_args["config_file"] = temp_config_path.name # Use temp file name temp_args["config_file"] = temp_config_path.name # Use temp file name
temp_args["_from_web_api"] = True temp_args["_from_web_api"] = True
temp_args["validation_mode"] = True # Flag to indicate this is validation, not a real run
temp_args["time"] = now.strftime("%H:%M") temp_args["time"] = now.strftime("%H:%M")
temp_args["time_obj"] = now temp_args["time_obj"] = now
temp_args["run"] = True temp_args["run"] = True

View file

@ -100,12 +100,35 @@ class Webhooks:
def start_time_hooks(self, start_time): def start_time_hooks(self, start_time):
"""Send a webhook to notify that the run has started.""" """Send a webhook to notify that the run has started."""
if self.run_start_webhooks: # Skip sending start notifications during config validation
if self.run_start_webhooks and not self.config.args.get("validation_mode", False):
dry_run = self.config.commands["dry_run"] dry_run = self.config.commands["dry_run"]
if dry_run: if dry_run:
start_type = "Dry-" start_type = "Dry-"
else: else:
start_type = "" start_type = ""
# Get enabled commands
enabled_commands = [
cmd
for cmd in [
"recheck",
"cat_update",
"tag_update",
"rem_unregistered",
"tag_tracker_error",
"rem_orphaned",
"tag_nohardlinks",
"share_limits",
]
if self.config.commands.get(cmd, False)
]
# Get execution options
execution_options = [
opt for opt in ["skip_cleanup", "dry_run", "skip_qb_version_check"] if self.config.commands.get(opt, False)
]
self._request( self._request(
self.run_start_webhooks, self.run_start_webhooks,
{ {
@ -115,6 +138,8 @@ class Webhooks:
"start_time": start_time.strftime("%Y-%m-%d %H:%M:%S"), "start_time": start_time.strftime("%Y-%m-%d %H:%M:%S"),
"dry_run": self.config.commands["dry_run"], "dry_run": self.config.commands["dry_run"],
"web_api_used": self.web_api_used, "web_api_used": self.web_api_used,
"commands": enabled_commands,
"execution_options": execution_options,
}, },
) )