Source code for transparentmeta.request.read_request

# SPDX-License-Identifier: GPL-3.0-or-later
# Copyright (c) 2025 Transparent Audio
# Author: Valerio Velardo - valerio@transparentaudio.ai

"""
Defines the Pydantic model for handling metadata read requests.

This model is used to validate user-provided input and structure it for
processing by the metadata read use case. It ensures that the given file path:

1. Exists on disk,
2. Is in a supported audio format,
3. Is a valid, functioning audio file,
"""

from pathlib import Path

from pydantic import BaseModel, field_validator

from transparentmeta.request.file_validators import (
    validate_audio_file_is_functioning,
    validate_audio_format_is_supported,
    validate_file_exists,
)


[docs] class ReadRequest(BaseModel): """Pydantic model representing a request to read metadata from an audio file. Attributes: filepath (Path): Path to the audio file. Validated for existence, supported format, and file integrity. """ filepath: Path
[docs] @field_validator("filepath") @classmethod def validate_filepath(cls, value: Path) -> Path: """Validates the provided filepath using multiple file validation functions. Ensures that: 1. The file exists. 2. The file format is supported. 3. The file is a valid audio file. Args: value (Path): The path to the file. Returns: Path: The validated filepath. Raises: FileNotFoundError: If the file does not exist. UnsupportedAudioFormatError: If the file format is not supported. InvalidAudioFileError: If the file is not a functioning audio file. """ value = validate_file_exists(value) value = validate_audio_format_is_supported(value) value = validate_audio_file_is_functioning(value) return value