Source code for pyatlan.model.assets.anaplan_view

# SPDX-License-Identifier: Apache-2.0
# Copyright 2025 Atlan Pte. Ltd.


from __future__ import annotations

from typing import ClassVar, List, Optional, overload

from pydantic.v1 import Field, validator

from pyatlan.model.enums import AtlanConnectorType
from pyatlan.model.fields.atlan_fields import RelationField
from pyatlan.utils import init_guid, validate_required_fields

from .anaplan import Anaplan


[docs] class AnaplanView(Anaplan): """Description""" @overload @classmethod def creator( cls, *, name: str, module_qualified_name: str, ) -> AnaplanView: ... @overload @classmethod def creator( cls, *, name: str, module_qualified_name: str, connection_qualified_name: str, ) -> AnaplanView: ... @classmethod @init_guid def creator( cls, *, name: str, module_qualified_name: str, connection_qualified_name: Optional[str] = None, ) -> AnaplanView: validate_required_fields( ["name", "module_qualified_name"], [name, module_qualified_name] ) attributes = AnaplanView.Attributes.create( name=name, module_qualified_name=module_qualified_name, connection_qualified_name=connection_qualified_name, ) return cls(attributes=attributes) type_name: str = Field(default="AnaplanView", allow_mutation=False) @validator("type_name") def validate_type_name(cls, v): if v != "AnaplanView": raise ValueError("must be AnaplanView") return v def __setattr__(self, name, value): if name in AnaplanView._convenience_properties: return object.__setattr__(self, name, value) super().__setattr__(name, value) ANAPLAN_MODULE: ClassVar[RelationField] = RelationField("anaplanModule") """ TBC """ ANAPLAN_PAGE_DIMENSIONS: ClassVar[RelationField] = RelationField( "anaplanPageDimensions" ) """ TBC """ ANAPLAN_ROW_DIMENSIONS: ClassVar[RelationField] = RelationField( "anaplanRowDimensions" ) """ TBC """ ANAPLAN_COLUMN_DIMENSIONS: ClassVar[RelationField] = RelationField( "anaplanColumnDimensions" ) """ TBC """ _convenience_properties: ClassVar[List[str]] = [ "anaplan_module", "anaplan_page_dimensions", "anaplan_row_dimensions", "anaplan_column_dimensions", ] @property def anaplan_module(self) -> Optional[AnaplanModule]: return None if self.attributes is None else self.attributes.anaplan_module @anaplan_module.setter def anaplan_module(self, anaplan_module: Optional[AnaplanModule]): if self.attributes is None: self.attributes = self.Attributes() self.attributes.anaplan_module = anaplan_module @property def anaplan_page_dimensions(self) -> Optional[List[AnaplanDimension]]: return ( None if self.attributes is None else self.attributes.anaplan_page_dimensions ) @anaplan_page_dimensions.setter def anaplan_page_dimensions( self, anaplan_page_dimensions: Optional[List[AnaplanDimension]] ): if self.attributes is None: self.attributes = self.Attributes() self.attributes.anaplan_page_dimensions = anaplan_page_dimensions @property def anaplan_row_dimensions(self) -> Optional[List[AnaplanDimension]]: return ( None if self.attributes is None else self.attributes.anaplan_row_dimensions ) @anaplan_row_dimensions.setter def anaplan_row_dimensions( self, anaplan_row_dimensions: Optional[List[AnaplanDimension]] ): if self.attributes is None: self.attributes = self.Attributes() self.attributes.anaplan_row_dimensions = anaplan_row_dimensions @property def anaplan_column_dimensions(self) -> Optional[List[AnaplanDimension]]: return ( None if self.attributes is None else self.attributes.anaplan_column_dimensions ) @anaplan_column_dimensions.setter def anaplan_column_dimensions( self, anaplan_column_dimensions: Optional[List[AnaplanDimension]] ): if self.attributes is None: self.attributes = self.Attributes() self.attributes.anaplan_column_dimensions = anaplan_column_dimensions class Attributes(Anaplan.Attributes): anaplan_module: Optional[AnaplanModule] = Field( default=None, description="" ) # relationship anaplan_page_dimensions: Optional[List[AnaplanDimension]] = Field( default=None, description="" ) # relationship anaplan_row_dimensions: Optional[List[AnaplanDimension]] = Field( default=None, description="" ) # relationship anaplan_column_dimensions: Optional[List[AnaplanDimension]] = Field( default=None, description="" ) # relationship @classmethod @init_guid def create( cls, *, name: str, module_qualified_name: str, connection_qualified_name: Optional[str] = None, ) -> AnaplanView.Attributes: validate_required_fields( ["name", "module_qualified_name"], [name, module_qualified_name], ) if connection_qualified_name: connector_name = AtlanConnectorType.get_connector_name( connection_qualified_name ) else: connection_qn, connector_name = AtlanConnectorType.get_connector_name( module_qualified_name, "module_qualified_name", 6 ) fields = module_qualified_name.split("/") workspace_name = fields[3] model_name = fields[4] module_name = fields[5] return AnaplanView.Attributes( name=name, qualified_name=f"{module_qualified_name}/{name}", connection_qualified_name=connection_qualified_name or connection_qn, connector_name=connector_name, anaplan_workspace_qualified_name=f"{fields[0]}/{fields[1]}/{fields[2]}/{fields[3]}", anaplan_workspace_name=workspace_name, anaplan_model_qualified_name=f"{fields[0]}/{fields[1]}/{fields[2]}/{fields[3]}/{fields[4]}", anaplan_model_name=model_name, anaplan_module_qualified_name=module_qualified_name, anaplan_module_name=module_name, anaplan_module=AnaplanModule.ref_by_qualified_name( module_qualified_name ), ) attributes: AnaplanView.Attributes = Field( default_factory=lambda: AnaplanView.Attributes(), description=( "Map of attributes in the instance and their values. " "The specific keys of this map will vary by type, " "so are described in the sub-types of this schema." ), )
from .anaplan_dimension import AnaplanDimension # noqa: E402, F401 from .anaplan_module import AnaplanModule # noqa: E402, F401 AnaplanView.Attributes.update_forward_refs()