validation.php 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. <?php
  2. /**
  3. * lib/validation.php
  4. *
  5. * Input validation helper functions.
  6. */
  7. /**
  8. * Sanitize string input
  9. */
  10. function sanitizeString(?string $value, int $maxLength = 255): string
  11. {
  12. if ($value === null) return '';
  13. $sanitized = trim($value);
  14. $sanitized = filter_var($sanitized, FILTER_SANITIZE_STRING, FILTER_FLAG_NO_ENCODE_QUOTES);
  15. return substr($sanitized, 0, $maxLength);
  16. }
  17. /**
  18. * Validate numeric input
  19. */
  20. function validateNumeric(?string $value, float $min = null, float $max = null): ?float
  21. {
  22. if ($value === '' || $value === null) return null;
  23. $numeric = filter_var($value, FILTER_VALIDATE_FLOAT);
  24. if ($numeric === false) {
  25. throw new ValidationException('Invalid numeric value: ' . $value);
  26. }
  27. if ($min !== null && $numeric < $min) {
  28. throw new ValidationException('Value below minimum: ' . $numeric);
  29. }
  30. if ($max !== null && $numeric > $max) {
  31. throw new ValidationException('Value above maximum: ' . $numeric);
  32. }
  33. return $numeric;
  34. }
  35. /**
  36. * Custom exception for validation errors
  37. */
  38. class ValidationException extends Exception {}
  39. ?>