#!/usr/bin/env python3 """Custom validator for php-version-detect action.""" from __future__ import annotations from pathlib import Path import sys # Add validate-inputs directory to path to import validators validate_inputs_path = Path(__file__).parent.parent / "validate-inputs" sys.path.insert(0, str(validate_inputs_path)) from validators.base import BaseValidator from validators.version import VersionValidator class CustomValidator(BaseValidator): """Custom validator for php-version-detect action.""" def __init__(self, action_type: str = "php-version-detect") -> None: """Initialize php-version-detect validator.""" super().__init__(action_type) self.version_validator = VersionValidator() def validate_inputs(self, inputs: dict[str, str]) -> bool: """Validate php-version-detect action inputs.""" valid = True # Validate default-version if provided if "default-version" in inputs: value = inputs["default-version"] # Empty string should fail validation if value == "": self.add_error("PHP version cannot be empty") valid = False elif value: # Use the PHP version validator which handles version ranges result = self.version_validator.validate_php_version(value, "default-version") # Propagate errors from the version validator for error in self.version_validator.errors: if error not in self.errors: self.add_error(error) # Clear the version validator's errors after propagating self.version_validator.clear_errors() if not result: valid = False return valid def get_required_inputs(self) -> list[str]: """Get list of required inputs.""" return [] def get_validation_rules(self) -> dict: """Get validation rules.""" return { "default-version": { "type": "php_version", "required": False, "description": "Default PHP version to use", } }