src.cdm.product.common.schedule.ParametricDates.py Maven / Gradle / Ivy
# pylint: disable=line-too-long, invalid-name, missing-function-docstring, missing-module-docstring, superfluous-parens
# pylint: disable=wrong-import-position, unused-import, unused-wildcard-import, wildcard-import, wrong-import-order, missing-class-docstring
from __future__ import annotations
from typing import List, Optional
from datetime import date
from datetime import time
from datetime import datetime
from decimal import Decimal
from pydantic import Field
from rosetta.runtime.utils import *
__all__ = ['ParametricDates']
class ParametricDates(BaseDataClass):
"""
Defines rules for the dates on which the price will be determined.
"""
dayType: DayTypeEnum = Field(..., description="Denotes the enumerated values to specify the day type classification used in counting the number of days between two dates.")
"""
Denotes the enumerated values to specify the day type classification used in counting the number of days between two dates.
"""
dayDistribution: Optional[DayDistributionEnum] = Field(None, description="Denotes the method by which the pricing days are distributed across the pricing period.")
"""
Denotes the method by which the pricing days are distributed across the pricing period.
"""
dayOfWeek: List[DayOfWeekEnum] = Field([], description="Indicates the days of the week on which the price will be determined.")
"""
Indicates the days of the week on which the price will be determined.
"""
@rosetta_condition
def cardinality_dayOfWeek(self):
return check_cardinality(self.dayOfWeek, 0, 7)
dayFrequency: Optional[Decimal] = Field(None, description="Defines the occurrence of the dayOfWeek within the pricing period on which pricing will take place, e.g. the 3rd Friday within each Calculation Period. If omitted, every dayOfWeek will be a pricing day.")
"""
Defines the occurrence of the dayOfWeek within the pricing period on which pricing will take place, e.g. the 3rd Friday within each Calculation Period. If omitted, every dayOfWeek will be a pricing day.
"""
lag: Optional[Lag] = Field(None, description="The pricing period per calculation period if the pricing days do not wholly fall within the respective calculation period.")
"""
The pricing period per calculation period if the pricing days do not wholly fall within the respective calculation period.
"""
businessCenters: BusinessCenters = Field(..., description="The enumerated values to specify the business centers.")
"""
The enumerated values to specify the business centers.
"""
@rosetta_condition
def condition_0_ParametricDatesChoice(self):
return self.check_one_of_constraint('dayDistribution', 'dayOfWeek', necessity=True)
@rosetta_condition
def condition_1_DayOfWeekMethod(self):
def _then_fn0():
return ((_resolve_rosetta_attr(self, "dayFrequency")) is not None)
def _else_fn0():
return True
return if_cond_fn(((_resolve_rosetta_attr(self, "dayOfWeek")) is not None), _then_fn0, _else_fn0)
from cdm.base.datetime.DayTypeEnum import DayTypeEnum
from cdm.product.asset.DayDistributionEnum import DayDistributionEnum
from cdm.base.datetime.DayOfWeekEnum import DayOfWeekEnum
from cdm.product.common.schedule.Lag import Lag
from cdm.base.datetime.BusinessCenters import BusinessCenters
ParametricDates.update_forward_refs()
© 2015 - 2025 Weber Informatics LLC | Privacy Policy