Source code for ensysmod.schemas.energy_source

from pydantic import Field, model_validator

from ensysmod.model import EnergyComponentType
from ensysmod.schemas.base_schema import MAX_STR_LENGTH, MIN_STR_LENGTH, BaseSchema, ReturnSchema
from ensysmod.schemas.energy_commodity import EnergyCommoditySchema
from ensysmod.schemas.energy_component import EnergyComponentCreate, EnergyComponentSchema, EnergyComponentUpdate
from ensysmod.utils import validators


class EnergySourceBase(BaseSchema):
    """
    Shared attributes for an energy source. Used as a base class for all schemas.
    """

    type: EnergyComponentType = EnergyComponentType.SOURCE

    commodity_cost: float | None = Field(
        default=None,
        description="Cost of the energy source per unit of energy.",
        examples=[42.2],
        ge=0,
    )
    yearly_limit: float | None = Field(
        default=None,
        description="The yearly limit of the energy source. If specified, commodity_limit_id must be specified as well.",
        examples=[366.5],
        ge=0,
    )
    commodity_limit_id: str | None = Field(
        default=None,
        description="Commodity limit ID of the energy source. If specified, yearly_limit must be specified as well.",
        examples=["CO2"],
        max_length=MAX_STR_LENGTH,
    )

    # validators
    _valid_yearly_limit_and_commodity_limit_id = model_validator(mode="after")(validators.validate_yearly_limit_and_commodity_limit_id)


[docs] class EnergySourceCreate(EnergySourceBase, EnergyComponentCreate): """ Attributes to receive via API on creation of an energy source. """ commodity_name: str = Field( default=..., description="Commodity the energy source is based on.", examples=["electricity"], min_length=MIN_STR_LENGTH, max_length=MAX_STR_LENGTH, )
class EnergySourceUpdate(EnergySourceBase, EnergyComponentUpdate): """ Attributes to receive via API on update of an energy source. """ commodity_name: str | None = Field( default=None, description="Commodity the energy source is based on.", examples=["electricity"], min_length=MIN_STR_LENGTH, max_length=MAX_STR_LENGTH, ) class EnergySourceSchema(EnergySourceBase, ReturnSchema): """ Attributes to return via API for an energy source. """ component: EnergyComponentSchema commodity: EnergyCommoditySchema