# DO NOT modify this file by hand, changes will be overwritten import sys from dataclasses import dataclass from inspect import getmembers, isclass from typing import ( AbstractSet, Any, Generic, Mapping, MutableMapping, Optional, Sequence, Type, TypeVar, ) from cloudformation_cli_python_lib.interface import ( BaseModel, BaseResourceHandlerRequest, ) from cloudformation_cli_python_lib.recast import recast_object from cloudformation_cli_python_lib.utils import deserialize_list T = TypeVar("T") def set_or_none(value: Optional[Sequence[T]]) -> Optional[AbstractSet[T]]: if value: return set(value) return None @dataclass class ResourceHandlerRequest(BaseResourceHandlerRequest): # pylint: disable=invalid-name desiredResourceState: Optional["ResourceModel"] previousResourceState: Optional["ResourceModel"] typeConfiguration: Optional["TypeConfigurationModel"] @dataclass class ResourceModel(BaseModel): Id: Optional[str] Events: Optional[Sequence[str]] Filters: Optional[Sequence["_KeyVal"]] BucketArn: Optional[str] TargetArn: Optional[str] TargetType: Optional[str] @classmethod def _deserialize( cls: Type["_ResourceModel"], json_data: Optional[Mapping[str, Any]], ) -> Optional["_ResourceModel"]: if not json_data: return None dataclasses = {n: o for n, o in getmembers(sys.modules[__name__]) if isclass(o)} recast_object(cls, json_data, dataclasses) return cls( Id=json_data.get("Id"), Events=json_data.get("Events"), Filters=deserialize_list(json_data.get("Filters"), KeyVal), BucketArn=json_data.get("BucketArn"), TargetArn=json_data.get("TargetArn"), TargetType=json_data.get("TargetType"), ) # work around possible type aliasing issues when variable has same name as a model _ResourceModel = ResourceModel @dataclass class KeyVal(BaseModel): Name: Optional[str] Value: Optional[str] @classmethod def _deserialize( cls: Type["_KeyVal"], json_data: Optional[Mapping[str, Any]], ) -> Optional["_KeyVal"]: if not json_data: return None return cls( Name=json_data.get("Name"), Value=json_data.get("Value"), ) # work around possible type aliasing issues when variable has same name as a model _KeyVal = KeyVal @dataclass class TypeConfigurationModel(BaseModel): @classmethod def _deserialize( cls: Type["_TypeConfigurationModel"], json_data: Optional[Mapping[str, Any]], ) -> Optional["_TypeConfigurationModel"]: if not json_data: return None return cls( ) # work around possible type aliasing issues when variable has same name as a model _TypeConfigurationModel = TypeConfigurationModel